mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-01-18 15:15:56 +08:00
[svn-r6552] Purpose:
To support szip compression in HDF5 Description: This is where szip filter function is located. Solution: The filter function composes of "encode" and "decode" part, which is similar as deflate filter. One critical difference is: when szip decompresses the data, it needs to know the buffer size to hold the decompressed data in advance. Currently it's hard for HDF5 lib to give the buffer size easily. So to avoid this problem, in each chunk, we add a small header to hold the buffer size of each chunk. The code will use UINT32 ENCODE and UINT32 DECODE to finish this part of work. Platforms tested: Since there are changes of configure.in and configure,I didn't use h5committest. I tested with four platforms. 1) Linux 2.4 (eirene) 2) Solaris 2.7(arabica) 3) windows 2000(VS 6.0) 4) SGI IRIX6.5-64(modi4) For test 1)-3), only basic C tests were done For modi4 test, I tested 64-bit C,parallel and fortran. All tests passed, except a warning message from szip library when checksum is used in some order, which doesn't e any real problems. Misc. update:
This commit is contained in:
parent
f94431ce1f
commit
992eb85944
122
src/H5Zszip.c
Normal file
122
src/H5Zszip.c
Normal file
@ -0,0 +1,122 @@
|
||||
/*
|
||||
* Copyright © 1999-2001 NCSA
|
||||
* All rights reserved.
|
||||
*
|
||||
* Programmer: Robb Matzke <matzke@llnl.gov>
|
||||
* Friday, August 27, 1999
|
||||
*/
|
||||
#include "H5private.h"
|
||||
#include "H5Eprivate.h"
|
||||
#include "H5MMprivate.h"
|
||||
#include "H5Zprivate.h"
|
||||
|
||||
#ifdef H5_HAVE_FILTER_SZIP
|
||||
|
||||
#ifdef H5_HAVE_SZLIB_H
|
||||
# include "szlib.h"
|
||||
#endif
|
||||
|
||||
/* Interface initialization */
|
||||
#define PABLO_MASK H5Z_szip_mask
|
||||
#define INTERFACE_INIT NULL
|
||||
static int interface_initialize_g = 0;
|
||||
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: H5Z_filter_szip
|
||||
*
|
||||
* Purpose: Implement an I/O filter around the 'rice' algorithm in
|
||||
* libsz
|
||||
*
|
||||
* Return: Success:
|
||||
*
|
||||
* Failure:
|
||||
*
|
||||
* Programmer: Robb Matzke
|
||||
* Thursday, April 16, 1998
|
||||
*
|
||||
* Modifications:
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
size_t
|
||||
H5Z_filter_szip (unsigned flags,
|
||||
size_t cd_nelmts,
|
||||
const unsigned cd_values[],
|
||||
size_t nbytes,
|
||||
size_t *buf_size,
|
||||
void **buf)
|
||||
{
|
||||
|
||||
size_t ret_value = 0;
|
||||
size_t size_out = 0;
|
||||
size_t size_in = 0;
|
||||
char *outbuf = NULL;
|
||||
char *newbuf = NULL;
|
||||
int status;
|
||||
SZ_com_t sz_param;
|
||||
|
||||
sz_param.options_mask = cd_values[0];
|
||||
sz_param.bits_per_pixel = cd_values[1];
|
||||
sz_param.pixels_per_block = cd_values[2];
|
||||
sz_param.pixels_per_scanline = cd_values[3];
|
||||
|
||||
FUNC_ENTER_NOAPI(H5Z_filter_szip, 0);
|
||||
|
||||
if (flags & H5Z_FLAG_REVERSE) {
|
||||
/* Input; uncompress */
|
||||
|
||||
size_t nalloc;
|
||||
|
||||
newbuf = *buf;
|
||||
UINT32DECODE(newbuf,nalloc);
|
||||
|
||||
size_out = nalloc;
|
||||
size_in = nbytes;
|
||||
|
||||
if(NULL==(outbuf = H5MM_malloc(nalloc)))
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, 0, "memory allocation failed for szip decompression");
|
||||
|
||||
status = SZ_BufftoBuffDecompress(outbuf, &size_out, newbuf, size_in-4, &sz_param);
|
||||
|
||||
if(status != SZ_OK) {
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, 0, "szip_filter: decompression failed");
|
||||
}
|
||||
|
||||
*buf = newbuf -4;
|
||||
H5MM_xfree(*buf);
|
||||
*buf = outbuf;
|
||||
outbuf = NULL;
|
||||
*buf_size = nalloc;
|
||||
ret_value = size_out;
|
||||
}
|
||||
|
||||
else {
|
||||
|
||||
size_in = nbytes;
|
||||
size_out = nbytes;
|
||||
if(NULL==(outbuf = H5MM_malloc(size_out+4)))
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, 0, "unable to allocate szip destination buffer");
|
||||
|
||||
UINT32ENCODE(outbuf,nbytes);
|
||||
status = SZ_BufftoBuffCompress(outbuf, &size_out, *buf, size_in, &sz_param);
|
||||
if(SZ_OK!=status)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTINIT, 0, "szip_filter: Compression failed");
|
||||
|
||||
if(*buf) H5MM_xfree(*buf);
|
||||
*buf = outbuf-4;
|
||||
outbuf = NULL;
|
||||
*buf_size = size_out+4;
|
||||
ret_value = size_out+4;
|
||||
}
|
||||
|
||||
done:
|
||||
if(outbuf) H5MM_xfree(outbuf);
|
||||
FUNC_LEAVE_NOAPI(ret_value);
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user