/** * Copyright (C) 2008 Happy Fish / YuQing * * FastDFS may be copied only under the terms of the GNU General * Public License V3, which may be found in the FastDFS source kit. * Please visit the FastDFS Home Page http://www.fastken.com/ for more detail. **/ //storage_dio.h #ifndef _STORAGE_DIO_H #define _STORAGE_DIO_H #include #include #include #include #include "tracker_types.h" #include "fastcommon/fast_task_queue.h" #include "fastcommon/fast_blocked_queue.h" struct storage_dio_context { int path_index; int thread_index; const char *rw; struct fast_blocked_queue queue; }; struct storage_dio_thread_data { /* for mixed read / write */ struct storage_dio_context *contexts; int count; //context count /* for separated read / write */ struct storage_dio_context *reader; struct storage_dio_context *writer; }; #ifdef __cplusplus extern "C" { #endif extern volatile int g_dio_thread_count; int storage_dio_init(); void storage_dio_terminate(); int storage_dio_get_thread_index(struct fast_task_info *pTask, \ const int store_path_index, const char file_op); int storage_dio_queue_push(struct fast_task_info *pTask); int dio_read_file(struct fast_task_info *pTask); int dio_write_file(struct fast_task_info *pTask); int dio_truncate_file(struct fast_task_info *pTask); int dio_delete_normal_file(struct fast_task_info *pTask); int dio_delete_trunk_file(struct fast_task_info *pTask); int dio_discard_file(struct fast_task_info *pTask); void dio_read_finish_clean_up(struct fast_task_info *pTask); void dio_write_finish_clean_up(struct fast_task_info *pTask); void dio_append_finish_clean_up(struct fast_task_info *pTask); void dio_trunk_write_finish_clean_up(struct fast_task_info *pTask); void dio_modify_finish_clean_up(struct fast_task_info *pTask); #define dio_truncate_finish_clean_up dio_read_finish_clean_up int dio_check_trunk_file_ex(int fd, const char *filename, const int64_t offset); int dio_check_trunk_file_when_upload(struct fast_task_info *pTask); int dio_check_trunk_file_when_sync(struct fast_task_info *pTask); int dio_write_chunk_header(struct fast_task_info *pTask); #ifdef __cplusplus } #endif #endif