Commit 01b66f3f authored by unknown's avatar unknown
Browse files

Fix crash caused by calling DES_ENCRYPT() without the --des-key-file

option having been passed to the server. (Bug #11643)


sql/des_key_file.cc:
  Split initialization of mutex to new function, and make sure static
  initialization variable is initialized.
sql/item_strfunc.cc:
  Make sure to initialize mutex before using it
sql/mysql_priv.h:
  Add init_des_key_file() declaration
mysql-test/r/func_des_encrypt.result:
  New BitKeeper file ``mysql-test/r/func_des_encrypt.result''
mysql-test/t/func_des_encrypt.test:
  New BitKeeper file ``mysql-test/t/func_des_encrypt.test''
BitKeeper/etc/config:
  Disable openlogging
parent 0f063423
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -24,7 +24,7 @@ description: MySQL - fast and reliable SQL database
# repository is commercial it can be an internal email address or "none"
# to disable logging.
# 
logging:  logging@openlogging.org
logging: none
# 
# If this field is set, all checkins will appear to be made by this user,
# in effect making this a single user package.  Single user packages are
+3 −0
Original line number Diff line number Diff line
select des_encrypt('hello');
des_encrypt('hello')
€Ö2nV“Ø}
+9 −0
Original line number Diff line number Diff line
-- source include/have_openssl.inc

# This test can't be in func_encrypt.test, because it requires
# --des-key-file to not be set.

#
# Bug #11643: des_encrypt() causes server to die
#
select des_encrypt('hello');
+12 −6
Original line number Diff line number Diff line
@@ -22,7 +22,17 @@
struct st_des_keyschedule des_keyschedule[10];
uint   des_default_key;
pthread_mutex_t LOCK_des_key_file;
static int initialized;
static int initialized= 0;

void
init_des_key_file()
{
  if (!initialized)
  {
    initialized=1;
    pthread_mutex_init(&LOCK_des_key_file,MY_MUTEX_INIT_FAST);
  }
}

/*
 Function which loads DES keys from plaintext file into memory on MySQL
@@ -45,11 +55,7 @@ load_des_key_file(const char *file_name)
  DBUG_ENTER("load_des_key_file");
  DBUG_PRINT("enter",("name: %s",file_name));

  if (!initialized)
  {
    initialized=1;
    pthread_mutex_init(&LOCK_des_key_file,MY_MUTEX_INIT_FAST);
  }
  init_des_key_file();

  VOID(pthread_mutex_lock(&LOCK_des_key_file));
  if ((file=my_open(file_name,O_RDONLY | O_BINARY ,MYF(MY_WME))) < 0 ||
+11 −0
Original line number Diff line number Diff line
@@ -388,6 +388,9 @@ String *Item_func_des_encrypt::val_str(String *str)

  if (arg_count == 1)
  {
    /* Make sure LOCK_des_key_file was initialized. */
    init_des_key_file();

    /* Protect against someone doing FLUSH DES_KEY_FILE */
    VOID(pthread_mutex_lock(&LOCK_des_key_file));
    keyschedule= des_keyschedule[key_number=des_default_key];
@@ -398,6 +401,10 @@ String *Item_func_des_encrypt::val_str(String *str)
    key_number= (uint) args[1]->val_int();
    if (key_number > 9)
      goto error;

    /* Make sure LOCK_des_key_file was initialized. */
    init_des_key_file();

    VOID(pthread_mutex_lock(&LOCK_des_key_file));
    keyschedule= des_keyschedule[key_number];
    VOID(pthread_mutex_unlock(&LOCK_des_key_file));
@@ -485,6 +492,10 @@ String *Item_func_des_decrypt::val_str(String *str)
    // Check if automatic key and that we have privilege to uncompress using it
    if (!(current_thd->master_access & SUPER_ACL) || key_number > 9)
      goto error;

    /* Make sure LOCK_des_key_file was initialized. */
    init_des_key_file();

    VOID(pthread_mutex_lock(&LOCK_des_key_file));
    keyschedule= des_keyschedule[key_number];
    VOID(pthread_mutex_unlock(&LOCK_des_key_file));
Loading