mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-01-12 15:04:59 +08:00
565 lines
23 KiB
C
565 lines
23 KiB
C
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
* Copyright by The HDF Group. *
|
|
* All rights reserved. *
|
|
* *
|
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
* terms governing use, modification, and redistribution, is contained in *
|
|
* the COPYING file, which can be found at the root of the source code *
|
|
* distribution tree, or in https://www.hdfgroup.org/licenses. *
|
|
* If you do not have access to either file, you may request a copy from *
|
|
* help@hdfgroup.org. *
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
/*
|
|
* Purpose: The public header file for the native VOL connector.
|
|
*/
|
|
|
|
#ifndef H5VLnative_H
|
|
#define H5VLnative_H
|
|
|
|
/* Public headers needed by this file */
|
|
#include "H5Apublic.h" /* Attributes */
|
|
#include "H5VLpublic.h" /* Virtual Object Layer */
|
|
|
|
/*****************/
|
|
/* Public Macros */
|
|
/*****************/
|
|
|
|
/* Identifier for the native VOL connector */
|
|
#define H5VL_NATIVE (H5VL_native_register())
|
|
|
|
/* Characteristics of the native VOL connector */
|
|
#define H5VL_NATIVE_NAME "native"
|
|
#define H5VL_NATIVE_VALUE H5_VOL_NATIVE /* enum value */
|
|
#define H5VL_NATIVE_VERSION 0
|
|
|
|
/* Values for VOL connector attribute optional VOL operations */
|
|
/* NOTE: If new values are added here, the H5VL__native_introspect_opt_query
|
|
* routine must be updated.
|
|
*/
|
|
#ifndef H5_NO_DEPRECATED_SYMBOLS
|
|
#define H5VL_NATIVE_ATTR_ITERATE_OLD 0 /* H5Aiterate (deprecated routine) */
|
|
#endif /* H5_NO_DEPRECATED_SYMBOLS */
|
|
/* NOTE: If values over 1023 are added, the H5VL_RESERVED_NATIVE_OPTIONAL macro
|
|
* must be updated.
|
|
*/
|
|
|
|
#ifndef H5_NO_DEPRECATED_SYMBOLS
|
|
/* Parameters for attribute 'iterate old' operation */
|
|
typedef struct H5VL_native_attr_iterate_old_t {
|
|
hid_t loc_id;
|
|
unsigned *attr_num;
|
|
H5A_operator1_t op;
|
|
void *op_data;
|
|
} H5VL_native_attr_iterate_old_t;
|
|
|
|
/* Parameters for native connector's attribute 'optional' operations */
|
|
typedef union H5VL_native_attr_optional_args_t {
|
|
/* H5VL_NATIVE_ATTR_ITERATE_OLD */
|
|
H5VL_native_attr_iterate_old_t iterate_old;
|
|
} H5VL_native_attr_optional_args_t;
|
|
#endif /* H5_NO_DEPRECATED_SYMBOLS */
|
|
|
|
/* Values for native VOL connector dataset optional VOL operations */
|
|
/* NOTE: If new values are added here, the H5VL__native_introspect_opt_query
|
|
* routine must be updated.
|
|
*/
|
|
#define H5VL_NATIVE_DATASET_FORMAT_CONVERT 0 /* H5Dformat_convert (internal) */
|
|
#define H5VL_NATIVE_DATASET_GET_CHUNK_INDEX_TYPE 1 /* H5Dget_chunk_index_type */
|
|
#define H5VL_NATIVE_DATASET_GET_CHUNK_STORAGE_SIZE 2 /* H5Dget_chunk_storage_size */
|
|
#define H5VL_NATIVE_DATASET_GET_NUM_CHUNKS 3 /* H5Dget_num_chunks */
|
|
#define H5VL_NATIVE_DATASET_GET_CHUNK_INFO_BY_IDX 4 /* H5Dget_chunk_info */
|
|
#define H5VL_NATIVE_DATASET_GET_CHUNK_INFO_BY_COORD 5 /* H5Dget_chunk_info_by_coord */
|
|
#define H5VL_NATIVE_DATASET_CHUNK_READ 6 /* H5Dchunk_read */
|
|
#define H5VL_NATIVE_DATASET_CHUNK_WRITE 7 /* H5Dchunk_write */
|
|
#define H5VL_NATIVE_DATASET_GET_VLEN_BUF_SIZE 8 /* H5Dvlen_get_buf_size */
|
|
#define H5VL_NATIVE_DATASET_GET_OFFSET 9 /* H5Dget_offset */
|
|
#define H5VL_NATIVE_DATASET_CHUNK_ITER 10 /* H5Dchunk_iter */
|
|
/* NOTE: If values over 1023 are added, the H5VL_RESERVED_NATIVE_OPTIONAL macro
|
|
* must be updated.
|
|
*/
|
|
|
|
/* Parameters for native connector's dataset 'chunk read' operation */
|
|
typedef struct H5VL_native_dataset_chunk_read_t {
|
|
const hsize_t *offset;
|
|
uint32_t filters;
|
|
void *buf;
|
|
} H5VL_native_dataset_chunk_read_t;
|
|
|
|
/* Parameters for native connector's dataset 'chunk write' operation */
|
|
typedef struct H5VL_native_dataset_chunk_write_t {
|
|
const hsize_t *offset;
|
|
uint32_t filters;
|
|
uint32_t size;
|
|
const void *buf;
|
|
} H5VL_native_dataset_chunk_write_t;
|
|
|
|
/* Parameters for native connector's dataset 'get vlen buf size' operation */
|
|
typedef struct H5VL_native_dataset_get_vlen_buf_size_t {
|
|
hid_t type_id;
|
|
hid_t space_id;
|
|
hsize_t *size; /* Size of variable-length data buffer (OUT) */
|
|
} H5VL_native_dataset_get_vlen_buf_size_t;
|
|
|
|
/* Parameters for native connector's dataset 'get chunk storage size' operation */
|
|
typedef struct H5VL_native_dataset_get_chunk_storage_size_t {
|
|
const hsize_t *offset; /* Offset of chunk */
|
|
hsize_t *size; /* Size of chunk (OUT) */
|
|
} H5VL_native_dataset_get_chunk_storage_size_t;
|
|
|
|
/* Parameters for native connector's dataset 'get num chunks' operation */
|
|
typedef struct H5VL_native_dataset_get_num_chunks_t {
|
|
hid_t space_id; /* Space selection */
|
|
hsize_t *nchunks; /* # of chunk for space selection (OUT) */
|
|
} H5VL_native_dataset_get_num_chunks_t;
|
|
|
|
/* Parameters for native connector's dataset 'get chunk info by idx' operation */
|
|
typedef struct H5VL_native_dataset_get_chunk_info_by_idx_t {
|
|
hid_t space_id; /* Space selection */
|
|
hsize_t chk_index; /* Chunk index within space */
|
|
hsize_t *offset; /* Chunk coordinates (OUT) */
|
|
unsigned *filter_mask; /* Filter mask for chunk (OUT) */
|
|
haddr_t *addr; /* Address of chunk in file (OUT) */
|
|
hsize_t *size; /* Size of chunk in file (OUT) */
|
|
} H5VL_native_dataset_get_chunk_info_by_idx_t;
|
|
|
|
/* Parameters for native connector's dataset 'get chunk info by coord' operation */
|
|
typedef struct H5VL_native_dataset_get_chunk_info_by_coord_t {
|
|
const hsize_t *offset; /* Chunk coordinates */
|
|
unsigned *filter_mask; /* Filter mask for chunk (OUT) */
|
|
haddr_t *addr; /* Address of chunk in file (OUT) */
|
|
hsize_t *size; /* Size of chunk in file (OUT) */
|
|
} H5VL_native_dataset_get_chunk_info_by_coord_t;
|
|
|
|
/* Parameters for native connector's dataset 'optional' operations */
|
|
typedef union H5VL_native_dataset_optional_args_t {
|
|
/* H5VL_NATIVE_DATASET_FORMAT_CONVERT */
|
|
/* No args */
|
|
|
|
/* H5VL_NATIVE_DATASET_GET_CHUNK_INDEX_TYPE */
|
|
struct {
|
|
H5D_chunk_index_t *idx_type; /* Type of chunk index (OUT) */
|
|
} get_chunk_idx_type;
|
|
|
|
/* H5VL_NATIVE_DATASET_GET_CHUNK_STORAGE_SIZE */
|
|
H5VL_native_dataset_get_chunk_storage_size_t get_chunk_storage_size;
|
|
|
|
/* H5VL_NATIVE_DATASET_GET_NUM_CHUNKS */
|
|
H5VL_native_dataset_get_num_chunks_t get_num_chunks;
|
|
|
|
/* H5VL_NATIVE_DATASET_GET_CHUNK_INFO_BY_IDX */
|
|
H5VL_native_dataset_get_chunk_info_by_idx_t get_chunk_info_by_idx;
|
|
|
|
/* H5VL_NATIVE_DATASET_GET_CHUNK_INFO_BY_COORD */
|
|
H5VL_native_dataset_get_chunk_info_by_coord_t get_chunk_info_by_coord;
|
|
|
|
/* H5VL_NATIVE_DATASET_CHUNK_READ */
|
|
H5VL_native_dataset_chunk_read_t chunk_read;
|
|
|
|
/* H5VL_NATIVE_DATASET_CHUNK_WRITE */
|
|
H5VL_native_dataset_chunk_write_t chunk_write;
|
|
|
|
/* H5VL_NATIVE_DATASET_GET_VLEN_BUF_SIZE */
|
|
H5VL_native_dataset_get_vlen_buf_size_t get_vlen_buf_size;
|
|
|
|
/* H5VL_NATIVE_DATASET_GET_OFFSET */
|
|
struct {
|
|
haddr_t *offset; /* Contiguous dataset's offset in the file (OUT) */
|
|
} get_offset;
|
|
|
|
/* H5VL_NATIVE_DATASET_CHUNK_ITER */
|
|
struct {
|
|
H5D_chunk_iter_op_t op; /* Chunk iteration callback */
|
|
void *op_data; /* Context to pass to iteration callback */
|
|
} chunk_iter;
|
|
|
|
} H5VL_native_dataset_optional_args_t;
|
|
|
|
/* Values for native VOL connector file optional VOL operations */
|
|
/* NOTE: If new values are added here, the H5VL__native_introspect_opt_query
|
|
* routine must be updated.
|
|
*/
|
|
#define H5VL_NATIVE_FILE_CLEAR_ELINK_CACHE 0 /* H5Fclear_elink_file_cache */
|
|
#define H5VL_NATIVE_FILE_GET_FILE_IMAGE 1 /* H5Fget_file_image */
|
|
#define H5VL_NATIVE_FILE_GET_FREE_SECTIONS 2 /* H5Fget_free_sections */
|
|
#define H5VL_NATIVE_FILE_GET_FREE_SPACE 3 /* H5Fget_freespace */
|
|
#define H5VL_NATIVE_FILE_GET_INFO 4 /* H5Fget_info1/2 */
|
|
#define H5VL_NATIVE_FILE_GET_MDC_CONF 5 /* H5Fget_mdc_config */
|
|
#define H5VL_NATIVE_FILE_GET_MDC_HR 6 /* H5Fget_mdc_hit_rate */
|
|
#define H5VL_NATIVE_FILE_GET_MDC_SIZE 7 /* H5Fget_mdc_size */
|
|
#define H5VL_NATIVE_FILE_GET_SIZE 8 /* H5Fget_filesize */
|
|
#define H5VL_NATIVE_FILE_GET_VFD_HANDLE 9 /* H5Fget_vfd_handle */
|
|
#define H5VL_NATIVE_FILE_RESET_MDC_HIT_RATE 10 /* H5Freset_mdc_hit_rate_stats */
|
|
#define H5VL_NATIVE_FILE_SET_MDC_CONFIG 11 /* H5Fset_mdc_config */
|
|
#define H5VL_NATIVE_FILE_GET_METADATA_READ_RETRY_INFO 12 /* H5Fget_metadata_read_retry_info */
|
|
#define H5VL_NATIVE_FILE_START_SWMR_WRITE 13 /* H5Fstart_swmr_write */
|
|
#define H5VL_NATIVE_FILE_START_MDC_LOGGING 14 /* H5Fstart_mdc_logging */
|
|
#define H5VL_NATIVE_FILE_STOP_MDC_LOGGING 15 /* H5Fstop_mdc_logging */
|
|
#define H5VL_NATIVE_FILE_GET_MDC_LOGGING_STATUS 16 /* H5Fget_mdc_logging_status */
|
|
#define H5VL_NATIVE_FILE_FORMAT_CONVERT 17 /* H5Fformat_convert */
|
|
#define H5VL_NATIVE_FILE_RESET_PAGE_BUFFERING_STATS 18 /* H5Freset_page_buffering_stats */
|
|
#define H5VL_NATIVE_FILE_GET_PAGE_BUFFERING_STATS 19 /* H5Fget_page_buffering_stats */
|
|
#define H5VL_NATIVE_FILE_GET_MDC_IMAGE_INFO 20 /* H5Fget_mdc_image_info */
|
|
#define H5VL_NATIVE_FILE_GET_EOA 21 /* H5Fget_eoa */
|
|
#define H5VL_NATIVE_FILE_INCR_FILESIZE 22 /* H5Fincrement_filesize */
|
|
#define H5VL_NATIVE_FILE_SET_LIBVER_BOUNDS 23 /* H5Fset_latest_format/libver_bounds */
|
|
#define H5VL_NATIVE_FILE_GET_MIN_DSET_OHDR_FLAG 24 /* H5Fget_dset_no_attrs_hint */
|
|
#define H5VL_NATIVE_FILE_SET_MIN_DSET_OHDR_FLAG 25 /* H5Fset_dset_no_attrs_hint */
|
|
#ifdef H5_HAVE_PARALLEL
|
|
#define H5VL_NATIVE_FILE_GET_MPI_ATOMICITY 26 /* H5Fget_mpi_atomicity */
|
|
#define H5VL_NATIVE_FILE_SET_MPI_ATOMICITY 27 /* H5Fset_mpi_atomicity */
|
|
#endif
|
|
#define H5VL_NATIVE_FILE_POST_OPEN 28 /* Adjust file after open, with wrapping context */
|
|
/* NOTE: If values over 1023 are added, the H5VL_RESERVED_NATIVE_OPTIONAL macro
|
|
* must be updated.
|
|
*/
|
|
|
|
/* Parameters for native connector's file 'get file image' operation */
|
|
typedef struct H5VL_native_file_get_file_image_t {
|
|
size_t buf_size; /* Size of file image buffer */
|
|
void *buf; /* Buffer for file image (OUT) */
|
|
size_t *image_len; /* Size of file image (OUT) */
|
|
} H5VL_native_file_get_file_image_t;
|
|
|
|
/* Parameters for native connector's file 'get free sections' operation */
|
|
typedef struct H5VL_native_file_get_free_sections_t {
|
|
H5F_mem_t type; /* Type of file memory to query */
|
|
H5F_sect_info_t *sect_info; /* Array of sections (OUT) */
|
|
size_t nsects; /* Size of section array */
|
|
size_t *sect_count; /* Actual # of sections of type (OUT) */
|
|
} H5VL_native_file_get_free_sections_t;
|
|
|
|
/* Parameters for native connector's file 'get freespace' operation */
|
|
typedef struct H5VL_native_file_get_freespace_t {
|
|
hsize_t *size; /* Size of free space (OUT) */
|
|
} H5VL_native_file_get_freespace_t;
|
|
|
|
/* Parameters for native connector's file 'get info' operation */
|
|
typedef struct H5VL_native_file_get_info_t {
|
|
H5I_type_t type; /* Type of object */
|
|
H5F_info2_t *finfo; /* Pointer to file info (OUT) */
|
|
} H5VL_native_file_get_info_t;
|
|
|
|
/* Parameters for native connector's file 'get metadata cache size' operation */
|
|
typedef struct H5VL_native_file_get_mdc_size_t {
|
|
size_t *max_size; /* Maximum amount of cached data (OUT) */
|
|
size_t *min_clean_size; /* Minimum amount of cached data to keep clean (OUT) */
|
|
size_t *cur_size; /* Current amount of cached data (OUT) */
|
|
uint32_t *cur_num_entries; /* Current # of cached entries (OUT) */
|
|
} H5VL_native_file_get_mdc_size_t;
|
|
|
|
/* Parameters for native connector's file 'get VFD handle' operation */
|
|
typedef struct H5VL_native_file_get_vfd_handle_t {
|
|
hid_t fapl_id;
|
|
void **file_handle; /* File handle from VFD (OUT) */
|
|
} H5VL_native_file_get_vfd_handle_t;
|
|
|
|
/* Parameters for native connector's file 'get MDC logging status' operation */
|
|
typedef struct H5VL_native_file_get_mdc_logging_status_t {
|
|
hbool_t *is_enabled; /* Whether logging is enabled (OUT) */
|
|
hbool_t *is_currently_logging; /* Whether currently logging (OUT) */
|
|
} H5VL_native_file_get_mdc_logging_status_t;
|
|
|
|
/* Parameters for native connector's file 'get page buffering stats' operation */
|
|
typedef struct H5VL_native_file_get_page_buffering_stats_t {
|
|
unsigned *accesses; /* Metadata/raw data page access counts (OUT) */
|
|
unsigned *hits; /* Metadata/raw data page hit counts (OUT) */
|
|
unsigned *misses; /* Metadata/raw data page miss counts (OUT) */
|
|
unsigned *evictions; /* Metadata/raw data page eviction counts (OUT) */
|
|
unsigned *bypasses; /* Metadata/raw data page bypass counts (OUT) */
|
|
} H5VL_native_file_get_page_buffering_stats_t;
|
|
|
|
/* Parameters for native connector's file 'get MDC image info' operation */
|
|
typedef struct H5VL_native_file_get_mdc_image_info_t {
|
|
haddr_t *addr; /* Address of image (OUT) */
|
|
hsize_t *len; /* Length of image (OUT) */
|
|
} H5VL_native_file_get_mdc_image_info_t;
|
|
|
|
/* Parameters for native connector's file 'set libver bounds' operation */
|
|
typedef struct H5VL_native_file_set_libver_bounds_t {
|
|
H5F_libver_t low; /* Lowest version possible */
|
|
H5F_libver_t high; /* Highest version possible */
|
|
} H5VL_native_file_set_libver_bounds_t;
|
|
|
|
/* Parameters for native connector's file 'optional' operations */
|
|
typedef union H5VL_native_file_optional_args_t {
|
|
/* H5VL_NATIVE_FILE_CLEAR_ELINK_CACHE */
|
|
/* No args */
|
|
|
|
/* H5VL_NATIVE_FILE_GET_FILE_IMAGE */
|
|
H5VL_native_file_get_file_image_t get_file_image;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_FREE_SECTIONS */
|
|
H5VL_native_file_get_free_sections_t get_free_sections;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_FREE_SPACE */
|
|
H5VL_native_file_get_freespace_t get_freespace;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_INFO */
|
|
H5VL_native_file_get_info_t get_info;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_MDC_CONF */
|
|
struct {
|
|
H5AC_cache_config_t *config; /* Pointer to MDC config (OUT) */
|
|
} get_mdc_config;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_MDC_HR */
|
|
struct {
|
|
double *hit_rate; /* Metadata cache hit rate (OUT) */
|
|
} get_mdc_hit_rate;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_MDC_SIZE */
|
|
H5VL_native_file_get_mdc_size_t get_mdc_size;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_SIZE */
|
|
struct {
|
|
hsize_t *size; /* Size of file (OUT) */
|
|
} get_size;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_VFD_HANDLE */
|
|
H5VL_native_file_get_vfd_handle_t get_vfd_handle;
|
|
|
|
/* H5VL_NATIVE_FILE_RESET_MDC_HIT_RATE */
|
|
/* No args */
|
|
|
|
/* H5VL_NATIVE_FILE_SET_MDC_CONFIG */
|
|
struct {
|
|
const H5AC_cache_config_t *config; /* Pointer to new MDC config */
|
|
} set_mdc_config;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_METADATA_READ_RETRY_INFO */
|
|
struct {
|
|
H5F_retry_info_t *info; /* Pointer to metadata read retry info (OUT) */
|
|
} get_metadata_read_retry_info;
|
|
|
|
/* H5VL_NATIVE_FILE_START_SWMR_WRITE */
|
|
/* No args */
|
|
|
|
/* H5VL_NATIVE_FILE_START_MDC_LOGGING */
|
|
/* No args */
|
|
|
|
/* H5VL_NATIVE_FILE_STOP_MDC_LOGGING */
|
|
/* No args */
|
|
|
|
/* H5VL_NATIVE_FILE_GET_MDC_LOGGING_STATUS */
|
|
H5VL_native_file_get_mdc_logging_status_t get_mdc_logging_status;
|
|
|
|
/* H5VL_NATIVE_FILE_FORMAT_CONVERT */
|
|
/* No args */
|
|
|
|
/* H5VL_NATIVE_FILE_RESET_PAGE_BUFFERING_STATS */
|
|
/* No args */
|
|
|
|
/* H5VL_NATIVE_FILE_GET_PAGE_BUFFERING_STATS */
|
|
H5VL_native_file_get_page_buffering_stats_t get_page_buffering_stats;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_MDC_IMAGE_INFO */
|
|
H5VL_native_file_get_mdc_image_info_t get_mdc_image_info;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_EOA */
|
|
struct {
|
|
haddr_t *eoa; /* End of allocated file address space (OUT) */
|
|
} get_eoa;
|
|
|
|
/* H5VL_NATIVE_FILE_INCR_FILESIZE */
|
|
struct {
|
|
hsize_t increment; /* Amount to increment file size */
|
|
} increment_filesize;
|
|
|
|
/* H5VL_NATIVE_FILE_SET_LIBVER_BOUNDS */
|
|
H5VL_native_file_set_libver_bounds_t set_libver_bounds;
|
|
|
|
/* H5VL_NATIVE_FILE_GET_MIN_DSET_OHDR_FLAG */
|
|
struct {
|
|
hbool_t *minimize; /* Flag whether dataset object headers are minimal (OUT) */
|
|
} get_min_dset_ohdr_flag;
|
|
|
|
/* H5VL_NATIVE_FILE_SET_MIN_DSET_OHDR_FLAG */
|
|
struct {
|
|
hbool_t minimize; /* Flag whether dataset object headers should be minimal */
|
|
} set_min_dset_ohdr_flag;
|
|
|
|
#ifdef H5_HAVE_PARALLEL
|
|
/* H5VL_NATIVE_FILE_GET_MPI_ATOMICITY */
|
|
struct {
|
|
hbool_t *flag; /* Flag whether MPI atomicity is set for files (OUT) */
|
|
} get_mpi_atomicity;
|
|
|
|
/* H5VL_NATIVE_FILE_SET_MPI_ATOMICITY */
|
|
struct {
|
|
hbool_t flag; /* Flag whether to set MPI atomicity for files */
|
|
} set_mpi_atomicity;
|
|
#endif /* H5_HAVE_PARALLEL */
|
|
|
|
/* H5VL_NATIVE_FILE_POST_OPEN */
|
|
/* No args */
|
|
} H5VL_native_file_optional_args_t;
|
|
|
|
/* Values for native VOL connector group optional VOL operations */
|
|
/* NOTE: If new values are added here, the H5VL__native_introspect_opt_query
|
|
* routine must be updated.
|
|
*/
|
|
#ifndef H5_NO_DEPRECATED_SYMBOLS
|
|
#define H5VL_NATIVE_GROUP_ITERATE_OLD 0 /* HG5Giterate (deprecated routine) */
|
|
#define H5VL_NATIVE_GROUP_GET_OBJINFO 1 /* HG5Gget_objinfo (deprecated routine) */
|
|
#endif /* H5_NO_DEPRECATED_SYMBOLS */
|
|
/* NOTE: If values over 1023 are added, the H5VL_RESERVED_NATIVE_OPTIONAL macro
|
|
* must be updated.
|
|
*/
|
|
|
|
#ifndef H5_NO_DEPRECATED_SYMBOLS
|
|
/* Parameters for group 'iterate old' operation */
|
|
typedef struct H5VL_native_group_iterate_old_t {
|
|
H5VL_loc_params_t loc_params; /* Location parameters for iteration */
|
|
hsize_t idx; /* Index of link to begin iteration at */
|
|
hsize_t *last_obj; /* Index of last link looked at (OUT) */
|
|
H5G_iterate_t op; /* Group (link) operator callback */
|
|
void *op_data; /* Context to pass to iterator callback */
|
|
} H5VL_native_group_iterate_old_t;
|
|
|
|
/* Parameters for group 'get objinfo' operation */
|
|
typedef struct H5VL_native_group_get_objinfo_t {
|
|
H5VL_loc_params_t loc_params; /* Location parameters for iteration */
|
|
hbool_t follow_link; /* Whether to follow links for query */
|
|
H5G_stat_t *statbuf; /* Pointer to object info struct (OUT) */
|
|
} H5VL_native_group_get_objinfo_t;
|
|
|
|
/* Parameters for native connector's group 'optional' operations */
|
|
typedef union H5VL_native_group_optional_args_t {
|
|
/* H5VL_NATIVE_GROUP_ITERATE_OLD */
|
|
H5VL_native_group_iterate_old_t iterate_old;
|
|
|
|
/* H5VL_NATIVE_GROUP_GET_OBJINFO */
|
|
H5VL_native_group_get_objinfo_t get_objinfo;
|
|
} H5VL_native_group_optional_args_t;
|
|
#endif /* H5_NO_DEPRECATED_SYMBOLS */
|
|
|
|
/* Values for native VOL connector object optional VOL operations */
|
|
/* NOTE: If new values are added here, the H5VL__native_introspect_opt_query
|
|
* routine must be updated.
|
|
*/
|
|
#define H5VL_NATIVE_OBJECT_GET_COMMENT 0 /* H5G|H5Oget_comment, H5Oget_comment_by_name */
|
|
#define H5VL_NATIVE_OBJECT_SET_COMMENT 1 /* H5G|H5Oset_comment, H5Oset_comment_by_name */
|
|
#define H5VL_NATIVE_OBJECT_DISABLE_MDC_FLUSHES 2 /* H5Odisable_mdc_flushes */
|
|
#define H5VL_NATIVE_OBJECT_ENABLE_MDC_FLUSHES 3 /* H5Oenable_mdc_flushes */
|
|
#define H5VL_NATIVE_OBJECT_ARE_MDC_FLUSHES_DISABLED 4 /* H5Oare_mdc_flushes_disabled */
|
|
#define H5VL_NATIVE_OBJECT_GET_NATIVE_INFO 5 /* H5Oget_native_info(_by_idx, _by_name) */
|
|
/* NOTE: If values over 1023 are added, the H5VL_RESERVED_NATIVE_OPTIONAL macro
|
|
* must be updated.
|
|
*/
|
|
|
|
/* Parameters for native connector's object 'get comment' operation */
|
|
typedef struct H5VL_native_object_get_comment_t {
|
|
size_t buf_size; /* Size of comment buffer */
|
|
void *buf; /* Buffer for comment (OUT) */
|
|
size_t *comment_len; /* Actual size of comment (OUT) */
|
|
} H5VL_native_object_get_comment_t;
|
|
|
|
/* Parameters for object 'get native info' operation */
|
|
typedef struct H5VL_native_object_get_native_info_t {
|
|
unsigned fields; /* Fields to retrieve */
|
|
H5O_native_info_t *ninfo; /* Native info (OUT) */
|
|
} H5VL_native_object_get_native_info_t;
|
|
|
|
/* Parameters for native connector's object 'optional' operations */
|
|
typedef union H5VL_native_object_optional_args_t {
|
|
/* H5VL_NATIVE_OBJECT_GET_COMMENT */
|
|
H5VL_native_object_get_comment_t get_comment;
|
|
|
|
/* H5VL_NATIVE_OBJECT_SET_COMMENT */
|
|
struct {
|
|
const char *comment; /* Comment string to set for the object (IN) */
|
|
} set_comment;
|
|
|
|
/* H5VL_NATIVE_OBJECT_DISABLE_MDC_FLUSHES */
|
|
/* No args */
|
|
|
|
/* H5VL_NATIVE_OBJECT_ENABLE_MDC_FLUSHES */
|
|
/* No args */
|
|
|
|
/* H5VL_NATIVE_OBJECT_ARE_MDC_FLUSHES_DISABLED */
|
|
struct {
|
|
hbool_t *flag; /* Flag whether metadata cache flushes are disabled for this object (OUT) */
|
|
} are_mdc_flushes_disabled;
|
|
|
|
/* H5VL_NATIVE_OBJECT_GET_NATIVE_INFO */
|
|
H5VL_native_object_get_native_info_t get_native_info;
|
|
} H5VL_native_object_optional_args_t;
|
|
|
|
/*******************/
|
|
/* Public Typedefs */
|
|
/*******************/
|
|
|
|
/********************/
|
|
/* Public Variables */
|
|
/********************/
|
|
|
|
/*********************/
|
|
/* Public Prototypes */
|
|
/*********************/
|
|
|
|
/*******************/
|
|
/* Public Typedefs */
|
|
/*******************/
|
|
|
|
/********************/
|
|
/* Public Variables */
|
|
/********************/
|
|
|
|
/*********************/
|
|
/* Public Prototypes */
|
|
/*********************/
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/* Token <--> address converters */
|
|
|
|
/**
|
|
* \ingroup H5VLNAT
|
|
*
|
|
* \brief Convert a haddr_t address to a native VOL connector token
|
|
*
|
|
* \fgdta_loc_obj_id{loc_id}
|
|
* \param[in] addr Object address
|
|
* \param[out] token Object token
|
|
*
|
|
* \return \herr_t
|
|
*
|
|
* \details This API call maps pre-VOL haddr_t native file format addresses
|
|
* to the more generic H5O_token_t tokens used by the VOL.
|
|
*
|
|
* \since 1.12.0
|
|
*/
|
|
H5_DLL herr_t H5VLnative_addr_to_token(hid_t loc_id, haddr_t addr, H5O_token_t *token);
|
|
/**
|
|
* \ingroup H5VLNAT
|
|
*
|
|
* \brief Convert a native VOL connector token to a haddr_t address
|
|
*
|
|
* \fgdta_loc_obj_id{loc_id}
|
|
* \param[in] token Object token
|
|
* \param[out] addr Object address
|
|
*
|
|
* \return \herr_t
|
|
*
|
|
* \details This API call maps generic H5O_token_t tokens used by the VOL to
|
|
* pre-VOL haddr_t native file format addresses.
|
|
*
|
|
* \since 1.12.0
|
|
*/
|
|
H5_DLL herr_t H5VLnative_token_to_addr(hid_t loc_id, H5O_token_t token, haddr_t *addr);
|
|
|
|
/** @private
|
|
*
|
|
* \brief Register the native VOL connector and retrieve an ID for it
|
|
*/
|
|
H5_DLL hid_t H5VL_native_register(void);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* H5VLnative_H */
|