2006-04-12 01:59:08 +02:00
|
|
|
/**
|
|
|
|
* =========================================================================
|
|
|
|
* File : file_stats.h
|
|
|
|
* Project : 0 A.D.
|
|
|
|
* Description : gathers statistics from all file modules.
|
|
|
|
*
|
|
|
|
* @author Jan.Wassenberg@stud.uni-karlsruhe.de
|
|
|
|
* =========================================================================
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2005-2006 Jan Wassenberg
|
|
|
|
*
|
|
|
|
* Redistribution and/or modification are also permitted under the
|
|
|
|
* terms of the GNU General Public License as published by the
|
|
|
|
* Free Software Foundation (version 2 or later, at your option).
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2006-01-25 08:21:45 +01:00
|
|
|
#ifndef FILE_STATS_H__
|
|
|
|
#define FILE_STATS_H__
|
|
|
|
|
|
|
|
#define FILE_STATS_ENABLED 1
|
|
|
|
|
|
|
|
|
|
|
|
enum FileIOImplentation { FI_LOWIO, FI_AIO, FI_BCACHE, FI_MAX_IDX };
|
|
|
|
enum FileOp { FO_READ, FO_WRITE };
|
|
|
|
enum CacheRet { CR_HIT, CR_MISS };
|
|
|
|
|
|
|
|
|
|
|
|
#if FILE_STATS_ENABLED
|
|
|
|
|
|
|
|
// vfs
|
|
|
|
extern void stats_vfs_file_add(size_t file_size);
|
|
|
|
extern void stats_vfs_file_remove(size_t file_size);
|
|
|
|
extern void stats_vfs_init_start();
|
|
|
|
extern void stats_vfs_init_finish();
|
|
|
|
|
|
|
|
// file
|
|
|
|
extern void stats_unique_name(size_t name_len);
|
|
|
|
extern void stats_open(const char* atom_fn, size_t file_size);
|
|
|
|
extern void stats_close();
|
|
|
|
|
|
|
|
// file_buf
|
|
|
|
extern void stats_buf_alloc(size_t user_size, size_t padded_size);
|
|
|
|
extern void stats_buf_free();
|
2006-02-05 00:32:01 +01:00
|
|
|
extern void stats_buf_ref();
|
2006-01-25 08:21:45 +01:00
|
|
|
|
|
|
|
// file_io
|
2006-03-24 22:56:00 +01:00
|
|
|
extern void stats_io_user_request(size_t user_size);
|
|
|
|
extern void stats_io_sync_start(double* start_time_storage);
|
|
|
|
extern void stats_io_sync_finish(FileIOImplentation fi, FileOp fo, ssize_t user_size, double* start_time_storage);
|
|
|
|
extern void stats_io_check_seek(BlockId disk_pos);
|
2006-01-28 23:19:42 +01:00
|
|
|
extern void stats_cb_start();
|
|
|
|
extern void stats_cb_finish();
|
2006-01-25 08:21:45 +01:00
|
|
|
|
|
|
|
// file_cache
|
|
|
|
extern void stats_cache(CacheRet cr, size_t size, const char* atom_fn);
|
|
|
|
extern void stats_block_cache(CacheRet cr);
|
|
|
|
|
2006-03-24 22:56:00 +01:00
|
|
|
// archive builder
|
|
|
|
extern void stats_ab_connection(bool already_exists);
|
|
|
|
|
2006-01-25 08:21:45 +01:00
|
|
|
extern void stats_dump();
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
#define stats_vfs_file_add(file_size)
|
|
|
|
#define stats_vfs_file_remove(file_size)
|
|
|
|
#define stats_vfs_init_start()
|
|
|
|
#define stats_vfs_init_finish()
|
|
|
|
#define stats_unique_name(name_len)
|
|
|
|
#define stats_open(atom_fn, file_size)
|
|
|
|
#define stats_close()
|
|
|
|
#define stats_buf_alloc(user_size, padded_size)
|
|
|
|
#define stats_buf_free()
|
2006-02-05 00:32:01 +01:00
|
|
|
#define stats_buf_ref()
|
2006-03-24 22:56:00 +01:00
|
|
|
#define stats_io_user_request(user_size)
|
|
|
|
#define stats_io_sync_start(disk_pos, start_time_storage)
|
|
|
|
#define stats_io_sync_finish(fi, fo, user_size, start_time_storage)
|
|
|
|
#define stats_io_check_seek(disk_pos)
|
2006-01-28 23:19:42 +01:00
|
|
|
#define stats_cb_start()
|
|
|
|
#define stats_cb_finish()
|
2006-01-25 08:21:45 +01:00
|
|
|
#define stats_cache(cr, size, atom_fn)
|
|
|
|
#define stats_block_cache(cr)
|
2006-03-24 22:56:00 +01:00
|
|
|
#define stats_ab_connection(already_exists)
|
2006-01-25 08:21:45 +01:00
|
|
|
#define stats_dump()
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif // #ifndef FILE_STATS_H__
|