/******************************************************************//**
Takes a block out of the LRU list and page hash table.
If the block is compressed-only (BUF_BLOCK_ZIP_PAGE),
the object will be freed and buf_pool->zip_mutex will be released.

If a compressed page or a compressed-only block descriptor is freed,
other compressed pages or compressed-only block descriptors may be
relocated.
@return the new state of the block (BUF_BLOCK_ZIP_FREE if the state
was BUF_BLOCK_ZIP_PAGE, or BUF_BLOCK_REMOVE_HASH otherwise) */
static
enum buf_page_state
buf_LRU_block_remove_hashed_page(
/*=============================*/
    buf_page_t*    bpage,    /*!< in: block, must contain a file page and
                be in a state where it can be freed; there
                may or may not be a hash index to the page */
    ibool        zip)    /*!< in: TRUE if should remove also the
                compressed page of an uncompressed page */
{
    ulint            fold;
    const buf_page_t*    hashed_bpage;
    buf_pool_t*        buf_pool = buf_pool_from_bpage(bpage);

    ut_ad(bpage);
    ut_ad(buf_pool_mutex_own(buf_pool));
    ut_ad(mutex_own(buf_page_get_mutex(bpage)));

    ut_a(buf_page_get_io_fix(bpage) == BUF_IO_NONE);
    ut_a(bpage->buf_fix_count == );

#if UNIV_WORD_SIZE == 4
    /* On 32-bit systems, there is no padding in
    buf_page_t.  On other systems, Valgrind could complain
    about uninitialized pad bytes. */
    UNIV_MEM_ASSERT_RW(bpage, sizeof *bpage);
#endif

    buf_LRU_remove_block(bpage);

    buf_pool->freed_page_clock += ;

    switch (buf_page_get_state(bpage)) {
    case BUF_BLOCK_FILE_PAGE:
        UNIV_MEM_ASSERT_W(bpage, sizeof(buf_block_t));
        UNIV_MEM_ASSERT_W(((buf_block_t*) bpage)->frame,
                  UNIV_PAGE_SIZE);
        buf_block_modify_clock_inc((buf_block_t*) bpage);
        if (bpage->zip.data) {
            const page_t*    page = ((buf_block_t*) bpage)->frame;
            const ulint    zip_size
                = page_zip_get_size(&bpage->zip);

            ut_a(!zip || bpage->oldest_modification == );

            switch (UNIV_EXPECT(fil_page_get_type(page),
                        FIL_PAGE_INDEX)) {
            case FIL_PAGE_TYPE_ALLOCATED:
            case FIL_PAGE_INODE:
            case FIL_PAGE_IBUF_BITMAP:
            case FIL_PAGE_TYPE_FSP_HDR:
            case FIL_PAGE_TYPE_XDES:
                /* These are essentially uncompressed pages. */
                if (!zip) {
                    /* InnoDB writes the data to the
                    uncompressed page frame.  Copy it
                    to the compressed page, which will
                    be preserved. */
                    memcpy(bpage->zip.data, page,
                           zip_size);
                }
                break;
            case FIL_PAGE_TYPE_ZBLOB:
            case FIL_PAGE_TYPE_ZBLOB2:
                break;
            case FIL_PAGE_INDEX:
#ifdef UNIV_ZIP_DEBUG
                ut_a(page_zip_validate(
                         &bpage->zip, page,
                         ((buf_block_t*) bpage)->index));
#endif /* UNIV_ZIP_DEBUG */
                break;
            default:
                ut_print_timestamp(stderr);
                fputs("  InnoDB: ERROR: The compressed page"
                      " to be evicted seems corrupt:", stderr);
                ut_print_buf(stderr, page, zip_size);
                fputs("\nInnoDB: Possibly older version"
                      " of the page:", stderr);
                ut_print_buf(stderr, bpage->zip.data,
                         zip_size);
                putc('\n', stderr);
                ut_error;
            }

            break;
        }
        /* fall through */
    case BUF_BLOCK_ZIP_PAGE:
        ut_a(bpage->oldest_modification == );
        UNIV_MEM_ASSERT_W(bpage->zip.data,
                  page_zip_get_size(&bpage->zip));
        break;
    case BUF_BLOCK_ZIP_FREE:
    case BUF_BLOCK_ZIP_DIRTY:
    case BUF_BLOCK_NOT_USED:
    case BUF_BLOCK_READY_FOR_USE:
    case BUF_BLOCK_MEMORY:
    case BUF_BLOCK_REMOVE_HASH:
        ut_error;
        break;
    }

    fold = buf_page_address_fold(bpage->space, bpage->offset);
    hashed_bpage = buf_page_hash_get_low(
        buf_pool, bpage->space, bpage->offset, fold);

    if (UNIV_UNLIKELY(bpage != hashed_bpage)) {
        fprintf(stderr,
            "InnoDB: Error: page %lu %lu not found"
            " in the hash table\n",
            (ulong) bpage->space,
            (ulong) bpage->offset);
        if (hashed_bpage) {
            fprintf(stderr,
                "InnoDB: In hash table we find block"
                " %p of %lu %lu which is not %p\n",
                (const void*) hashed_bpage,
                (ulong) hashed_bpage->space,
                (ulong) hashed_bpage->offset,
                (const void*) bpage);
        }

#if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG
        mutex_exit(buf_page_get_mutex(bpage));
        buf_pool_mutex_exit(buf_pool);
        buf_print();
        buf_LRU_print();
        buf_validate();
        buf_LRU_validate();
#endif /* UNIV_DEBUG || UNIV_BUF_DEBUG */
        ut_error;
    }

    ut_ad(!bpage->in_zip_hash);
    ut_ad(bpage->in_page_hash);
    ut_d(bpage->in_page_hash = FALSE);
    HASH_DELETE(buf_page_t, hash, buf_pool->page_hash, fold, bpage); //这里    switch (buf_page_get_state(bpage)) {
    case BUF_BLOCK_ZIP_PAGE:
        ut_ad(!bpage->in_free_list);
        ut_ad(!bpage->in_flush_list);
        ut_ad(!bpage->in_LRU_list);
        ut_a(bpage->zip.data);
        ut_a(buf_page_get_zip_size(bpage));

#if defined UNIV_DEBUG || defined UNIV_BUF_DEBUG
        UT_LIST_REMOVE(list, buf_pool->zip_clean, bpage);
#endif /* UNIV_DEBUG || UNIV_BUF_DEBUG */

        mutex_exit(&buf_pool->zip_mutex);
        buf_pool_mutex_exit_forbid(buf_pool);

        buf_buddy_free(
            buf_pool, bpage->zip.data,
            page_zip_get_size(&bpage->zip));

        buf_pool_mutex_exit_allow(buf_pool);
        buf_page_free_descriptor(bpage);
        return(BUF_BLOCK_ZIP_FREE);

    case BUF_BLOCK_FILE_PAGE:
        memset(((buf_block_t*) bpage)->frame
               + FIL_PAGE_OFFSET, );
        memset(((buf_block_t*) bpage)->frame
               + FIL_PAGE_ARCH_LOG_NO_OR_SPACE_ID, );
        UNIV_MEM_INVALID(((buf_block_t*) bpage)->frame,
                 UNIV_PAGE_SIZE);
        buf_page_set_state(bpage, BUF_BLOCK_REMOVE_HASH);

        if (zip && bpage->zip.data) {
            /* Free the compressed page. */
            void*    data = bpage->zip.data;
            bpage->zip.data = NULL;

            ut_ad(!bpage->in_free_list);
            ut_ad(!bpage->in_flush_list);
            ut_ad(!bpage->in_LRU_list);
            mutex_exit(&((buf_block_t*) bpage)->mutex);
            buf_pool_mutex_exit_forbid(buf_pool);

            buf_buddy_free(
                buf_pool, data,
                page_zip_get_size(&bpage->zip));

            buf_pool_mutex_exit_allow(buf_pool);
            mutex_enter(&((buf_block_t*) bpage)->mutex);
            page_zip_set_size(&bpage->zip, );
        }

        return(BUF_BLOCK_REMOVE_HASH);

    case BUF_BLOCK_ZIP_FREE:
    case BUF_BLOCK_ZIP_DIRTY:
    case BUF_BLOCK_NOT_USED:
    case BUF_BLOCK_READY_FOR_USE:
    case BUF_BLOCK_MEMORY:
    case BUF_BLOCK_REMOVE_HASH:
        break;
    }

    ut_error;
    return(BUF_BLOCK_ZIP_FREE);
}

函数buf_LRU_block_remove_hashed_page的更多相关文章

  1. Python 小而美的函数

    python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况   any any(iterable) ...

  2. 探究javascript对象和数组的异同,及函数变量缓存技巧

    javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...

  3. JavaScript权威指南 - 函数

    函数本身就是一段JavaScript代码,定义一次但可能被调用任意次.如果函数挂载在一个对象上,作为对象的一个属性,通常这种函数被称作对象的方法.用于初始化一个新创建的对象的函数被称作构造函数. 相对 ...

  4. C++对C的函数拓展

    一,内联函数 1.内联函数的概念 C++中的const常量可以用来代替宏常数的定义,例如:用const int a = 10来替换# define a 10.那么C++中是否有什么解决方案来替代宏代码 ...

  5. 菜鸟Python学习笔记第一天:关于一些函数库的使用

    2017年1月3日 星期二 大一学习一门新的计算机语言真的很难,有时候连函数拼写出错查错都能查半天,没办法,谁让我英语太渣. 关于计算机语言的学习我想还是从C语言学习开始为好,Python有很多语言的 ...

  6. javascript中的this与函数讲解

    前言 javascript中没有块级作用域(es6以前),javascript中作用域分为函数作用域和全局作用域.并且,大家可以认为全局作用域其实就是Window函数的函数作用域,我们编写的js代码, ...

  7. 复杂的 Hash 函数组合有意义吗?

    很久以前看到一篇文章,讲某个大网站储存用户口令时,会经过十分复杂的处理.怎么个复杂记不得了,大概就是先 Hash,结果加上一些特殊字符再 Hash,结果再加上些字符.再倒序.再怎么怎么的.再 Hash ...

  8. JS核心系列:浅谈函数的作用域

    一.作用域(scope) 所谓作用域就是:变量在声明它们的函数体以及这个函数体嵌套的任意函数体内都是有定义的. function scope(){ var foo = "global&quo ...

  9. C++中的时间函数

    C++获取时间函数众多,何时该用什么函数,拿到的是什么时间?该怎么用?很多人都会混淆. 本文是本人经历了几款游戏客户端和服务器开发后,对游戏中时间获取的一点总结. 最早学习游戏客户端时,为了获取最精确 ...

随机推荐

  1. CorelDRAW 插件的安装和使用

    CorelDRAW 是一款在中国非常受欢迎的图形软件,开放的界面和编程技术,能够对它进行二次开发制作插件,插件大抵有三种gms.cpg.exe格式,下面介绍一下这三种插件的安装和使用方法. 一.gms ...

  2. Kakfa揭秘 Day7 Producer源码解密

    Kakfa揭秘 Day7 Producer源码解密 今天我们来研究下Producer.Producer的主要作用就是向Kafka的brokers发送数据.从思考角度,为了简化思考过程,可以简化为一个单 ...

  3. Linux进程间通信IPC学习笔记之同步二(SVR4 信号量)

    Linux进程间通信IPC学习笔记之同步二(SVR4 信号量)

  4. InnoDB外键使用小结

    USE `wfc_database`; # 主表(也可以称作:被参照表.referenced table.outTable) ALTER TABLE `app` ENGINE=INNODB; # 从表 ...

  5. 【IOS】分享下近一年IOS开发的经验总结

    从上个暑假末到现在,自己做IOS开发也快一年了.从一开始的什么都不知道,到现在大多事都能搭上一两手,期间经历了很多事情.下面来和大家分享一下心得和感触. 1.现在移动领域的知识更新的很快,无论是IOS ...

  6. 汽车之家, 比亚迪等成为开源数据库SSDB的用户

    开源的 NoSQL 数据库 SSDB 已经一岁多了! 在这一年中, SSDB 不断被应用在众多业界知名互联网企业, 创业团队的产品中. 最近, 比亚迪汽车也成为 SSDB 的用户, 其将 SSDB 作 ...

  7. easy ui datagrid 设置冻结列

    为了冻结列,您需要定义 frozenColumns 属性.frozenColumn 属性和 columns 属性一样. $('#tt').datagrid({ title:'Frozen Column ...

  8. Xcode 合并分支报错

    原理和操作步骤见如下转载的两篇文章, 我所使用的 svn 客户端软件是 Mac 下面的 Versions.app v1.06 这个版本包含一个多人开发的bug bug 的解决方案见我之前转载的两篇文章 ...

  9. 自己开发开源jquery插件--给jquery.treeview加上checkbox

    很多时候需要把树状的数据显示除来,比如分类,中国省份.城市信息,等,因此这方面的javascript插件也有很多.比如性能优异的jquery.treeview和国人开发的功能强大的zTree. 我最近 ...

  10. 1195: [HNOI2006]最短母串 - BZOJ

    Description 给定n个字符串(S1,S2,„,Sn),要求找到一个最短的字符串T,使得这n个字符串(S1,S2,„,Sn)都是T的子串.Input 第一行是一个正整数n(n<=12), ...