2014-02-03 10:08:15 +02:00
|
|
|
/*****************************************************************************
|
|
|
|
|
2016-04-29 12:32:35 +03:00
|
|
|
Copyright (C) 2013, 2016 MariaDB Corporation. All Rights Reserved.
|
2014-02-03 10:08:15 +02:00
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify it under
|
|
|
|
the terms of the GNU General Public License as published by the Free Software
|
|
|
|
Foundation; version 2 of the License.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License along with
|
|
|
|
this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
#ifndef fil0pagecompress_h
|
|
|
|
#define fil0pagecompress_h
|
|
|
|
|
|
|
|
#include "fsp0fsp.h"
|
|
|
|
#include "fsp0pagecompress.h"
|
|
|
|
|
|
|
|
/******************************************************************//**
|
|
|
|
@file include/fil0pagecompress.h
|
|
|
|
Helper functions for extracting/storing page compression and
|
|
|
|
atomic writes information to table space.
|
|
|
|
|
|
|
|
Created 11/12/2013 Jan Lindström jan.lindstrom@skysql.com
|
|
|
|
***********************************************************************/
|
|
|
|
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns the page compression level flag of the space, or 0 if the space
|
|
|
|
is not compressed. The tablespace must be cached in the memory cache.
|
|
|
|
@return page compression level if page compressed, ULINT_UNDEFINED if space not found */
|
2016-11-25 06:09:00 +02:00
|
|
|
UNIV_INLINE
|
2014-02-03 10:08:15 +02:00
|
|
|
ulint
|
|
|
|
fil_space_get_page_compression_level(
|
|
|
|
/*=================================*/
|
|
|
|
ulint id); /*!< in: space id */
|
|
|
|
/*******************************************************************//**
|
|
|
|
Returns the page compression flag of the space, or false if the space
|
|
|
|
is not compressed. The tablespace must be cached in the memory cache.
|
|
|
|
@return true if page compressed, false if not or space not found */
|
2016-11-25 06:09:00 +02:00
|
|
|
UNIV_INLINE
|
2014-02-03 10:08:15 +02:00
|
|
|
ibool
|
|
|
|
fil_space_is_page_compressed(
|
|
|
|
/*=========================*/
|
2015-06-03 13:10:18 +03:00
|
|
|
ulint id); /*!< in: space id */
|
2014-02-03 10:08:15 +02:00
|
|
|
/*******************************************************************//**
|
2014-07-25 14:37:10 +03:00
|
|
|
Returns the page compression flag of the space, or false if the space
|
|
|
|
is not compressed. The tablespace must be cached in the memory cache.
|
|
|
|
@return true if page compressed, false if not or space not found */
|
2015-06-03 13:10:18 +03:00
|
|
|
UNIV_INTERN
|
2014-07-25 14:37:10 +03:00
|
|
|
ibool
|
|
|
|
fil_space_get_page_compressed(
|
|
|
|
/*=========================*/
|
|
|
|
fil_space_t* space); /*!< in: space id */
|
|
|
|
/*******************************************************************//**
|
2014-02-03 10:08:15 +02:00
|
|
|
Returns the atomic writes flag of the space, or false if the space
|
|
|
|
is not using atomic writes. The tablespace must be cached in the memory cache.
|
|
|
|
@return atomic write table option value */
|
2016-11-25 06:09:00 +02:00
|
|
|
UNIV_INLINE
|
2014-02-03 10:08:15 +02:00
|
|
|
atomic_writes_t
|
|
|
|
fil_space_get_atomic_writes(
|
|
|
|
/*=========================*/
|
2015-06-03 13:10:18 +03:00
|
|
|
ulint id); /*!< in: space id */
|
2014-02-03 10:08:15 +02:00
|
|
|
/*******************************************************************//**
|
|
|
|
Find out wheather the page is index page or not
|
|
|
|
@return true if page type index page, false if not */
|
2016-11-25 06:09:00 +02:00
|
|
|
UNIV_INLINE
|
2014-02-03 10:08:15 +02:00
|
|
|
ibool
|
|
|
|
fil_page_is_index_page(
|
|
|
|
/*===================*/
|
2015-06-03 13:10:18 +03:00
|
|
|
byte *buf); /*!< in: page */
|
2014-02-03 10:08:15 +02:00
|
|
|
|
|
|
|
/****************************************************************//**
|
|
|
|
Get the name of the compression algorithm used for page
|
|
|
|
compression.
|
|
|
|
@return compression algorithm name or "UNKNOWN" if not known*/
|
2016-11-25 06:09:00 +02:00
|
|
|
UNIV_INLINE
|
2014-02-03 10:08:15 +02:00
|
|
|
const char*
|
|
|
|
fil_get_compression_alg_name(
|
|
|
|
/*=========================*/
|
2015-06-03 13:10:18 +03:00
|
|
|
ulint comp_alg); /*!<in: compression algorithm number */
|
2014-02-03 10:08:15 +02:00
|
|
|
|
|
|
|
/****************************************************************//**
|
|
|
|
For page compressed pages compress the page before actual write
|
|
|
|
operation.
|
|
|
|
@return compressed page to be written*/
|
2015-06-03 13:10:18 +03:00
|
|
|
UNIV_INTERN
|
2014-02-03 10:08:15 +02:00
|
|
|
byte*
|
|
|
|
fil_compress_page(
|
|
|
|
/*==============*/
|
2015-06-03 13:10:18 +03:00
|
|
|
ulint space_id, /*!< in: tablespace id of the
|
|
|
|
table. */
|
|
|
|
byte* buf, /*!< in: buffer from which to write; in aio
|
|
|
|
this must be appropriately aligned */
|
|
|
|
byte* out_buf, /*!< out: compressed buffer */
|
|
|
|
ulint len, /*!< in: length of input buffer.*/
|
|
|
|
ulint level, /* in: compression level */
|
|
|
|
ulint block_size, /*!< in: block size */
|
|
|
|
bool encrypted, /*!< in: is page also encrypted */
|
|
|
|
ulint* out_len, /*!< out: actual length of compressed
|
|
|
|
page */
|
|
|
|
byte* lzo_mem); /*!< in: temporal memory used by LZO */
|
2014-02-03 10:08:15 +02:00
|
|
|
|
|
|
|
/****************************************************************//**
|
|
|
|
For page compressed pages decompress the page after actual read
|
2015-06-03 13:10:18 +03:00
|
|
|
operation. */
|
|
|
|
UNIV_INTERN
|
2014-02-03 10:08:15 +02:00
|
|
|
void
|
|
|
|
fil_decompress_page(
|
|
|
|
/*================*/
|
2015-06-03 13:10:18 +03:00
|
|
|
byte* page_buf, /*!< in: preallocated buffer or NULL */
|
|
|
|
byte* buf, /*!< out: buffer from which to read; in aio
|
|
|
|
this must be appropriately aligned */
|
|
|
|
ulong len, /*!< in: length of output buffer.*/
|
2016-04-29 12:32:35 +03:00
|
|
|
ulint* write_size, /*!< in/out: Actual payload size of
|
2015-06-03 13:10:18 +03:00
|
|
|
the compressed data. */
|
2016-04-29 12:32:35 +03:00
|
|
|
bool return_error=false);
|
|
|
|
/*!< in: true if only an error should
|
|
|
|
be produced when decompression fails.
|
|
|
|
By default this parameter is false. */
|
2014-02-03 10:08:15 +02:00
|
|
|
|
|
|
|
/****************************************************************//**
|
|
|
|
Get space id from fil node
|
|
|
|
@return space id*/
|
2015-06-03 13:10:18 +03:00
|
|
|
UNIV_INTERN
|
2014-02-03 10:08:15 +02:00
|
|
|
ulint
|
|
|
|
fil_node_get_space_id(
|
|
|
|
/*==================*/
|
2015-06-03 13:10:18 +03:00
|
|
|
fil_node_t* node); /*!< in: Node where to get space id*/
|
2014-02-03 10:08:15 +02:00
|
|
|
|
2014-10-28 14:49:31 +04:00
|
|
|
/****************************************************************//**
|
|
|
|
Get block size from fil node
|
|
|
|
@return block size*/
|
2016-11-25 06:09:00 +02:00
|
|
|
UNIV_INLINE
|
2014-10-28 14:49:31 +04:00
|
|
|
ulint
|
|
|
|
fil_node_get_block_size(
|
2015-06-03 13:10:18 +03:00
|
|
|
fil_node_t* node); /*!< in: Node where to get block
|
|
|
|
size */
|
2014-02-03 10:08:15 +02:00
|
|
|
/*******************************************************************//**
|
|
|
|
Find out wheather the page is page compressed
|
|
|
|
@return true if page is page compressed*/
|
2016-11-25 06:09:00 +02:00
|
|
|
UNIV_INLINE
|
2014-02-03 10:08:15 +02:00
|
|
|
ibool
|
|
|
|
fil_page_is_compressed(
|
|
|
|
/*===================*/
|
2015-06-03 13:10:18 +03:00
|
|
|
byte* buf); /*!< in: page */
|
|
|
|
|
|
|
|
/*******************************************************************//**
|
|
|
|
Find out wheather the page is page compressed
|
|
|
|
@return true if page is page compressed*/
|
2016-11-25 06:09:00 +02:00
|
|
|
UNIV_INLINE
|
2015-06-03 13:10:18 +03:00
|
|
|
ibool
|
|
|
|
fil_page_is_compressed_encrypted(
|
|
|
|
/*=============================*/
|
|
|
|
byte* buf); /*!< in: page */
|
2014-02-03 10:08:15 +02:00
|
|
|
|
2014-12-03 10:41:52 +02:00
|
|
|
/*******************************************************************//**
|
|
|
|
Find out wheather the page is page compressed with lzo method
|
|
|
|
@return true if page is page compressed with lzo method*/
|
2016-11-25 06:09:00 +02:00
|
|
|
UNIV_INLINE
|
2014-12-03 10:41:52 +02:00
|
|
|
ibool
|
|
|
|
fil_page_is_lzo_compressed(
|
|
|
|
/*=======================*/
|
2015-06-03 13:10:18 +03:00
|
|
|
byte* buf); /*!< in: page */
|
2014-02-03 10:08:15 +02:00
|
|
|
#endif
|