1. 02 Jun, 2015 2 commits
  2. 01 Jun, 2015 7 commits
  3. 31 May, 2015 2 commits
  4. 30 May, 2015 5 commits
  5. 29 May, 2015 4 commits
  6. 28 May, 2015 3 commits
  7. 27 May, 2015 6 commits
  8. 26 May, 2015 5 commits
  9. 25 May, 2015 1 commit
  10. 21 May, 2015 3 commits
  11. 20 May, 2015 2 commits
    • Jan Lindström's avatar
      MDEV-8182: Failing assertion: 1 == UT_LIST_GET_LEN(space->chain) · 925b6412
      Jan Lindström authored
      Analysis: At fil_spage_get_space there is small change that space
      is found from tablespace list but we have not yet created node
      for it (and added it to space->chain) and as we hold fil_system
      mutex here fil_node_create can't continue.
      
      Fixed by allowing UT_LIST_GET_LEN(space->chain) == 0|| 1 and
      introducint two new functions that access filespace list
      and before returning space check that node is also created.
      925b6412
    • Jan Lindström's avatar
      MDEV-8173: InnoDB; Failing assertion: crypt_data->type == 1 · 3e55ef26
      Jan Lindström authored
      Make sure that when we publish the crypt_data we access the
      memory cache of the tablespace crypt_data. Make sure that
      crypt_data is stored whenever it is really needed.
      
      All this is not yet enough in my opinion because:
      
      sql/encryption.cc has DBUG_ASSERT(scheme->type == 1) i.e.
      crypt_data->type == CRYPT_SCHEME_1
      
      However, for InnoDB point of view we have global crypt_data
      for every tablespace. When we change variables on crypt_data
      we take mutex. However, when we use crypt_data for
      encryption/decryption we use pointer to this global
      structure and no mutex to protect against changes on
      crypt_data.
      
      Tablespace encryption starts in fil_crypt_start_encrypting_space
      from crypt_data that has crypt_data->type = CRYPT_SCHEME_UNENCRYPTED
      and later we write page 0 CRYPT_SCHEME_1 and finally whe publish
      that to memory cache.
      3e55ef26