• unknown's avatar
    A follow up after the patch for Bug#21074 - even though · f434f45d
    unknown authored
    we now have exclusive name lock on the table name in mysql_rm_table_part2,
    we still should keep LOCK_open - some storage engines are not
    ready for locking scope change and assume that LOCK_open is kept.
    Still, the binary logging and query cache invalidation calls
    moved out of LOCK_open scope.
    Fixes some of the broken 5.1-runtime tests (tests break on asserts).
    
    
    sql/ha_ndbcluster.cc:
      Do not lock LOCK_open for mysql_rm_table_part2 - it does that
      for us now.
    sql/mysql_priv.h:
      Remove an unused flag.
    sql/sql_class.h:
      Fix an unrelated compiler warning.
    sql/sql_db.cc:
      Adjust to the changed signature.
    sql/sql_table.cc:
      mysql_rm_table_part2: we need to keep LOCK_open while calling
      storage engine functions, even though now 
      we have an exclusive lock on the table name. Some of them assume that it's 
      kept and attempt to unlock it.
    f434f45d
mysql_priv.h 86.6 KB