You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
159 lines
3.7 KiB
159 lines
3.7 KiB
/*
|
|
* Copyright (C) 2016 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#ifdef IOSHARK_MAIN
|
|
const char *IO_op[] = {
|
|
"LSEEK",
|
|
"LLSEEK",
|
|
"PREAD64",
|
|
"PWRITE64",
|
|
"READ",
|
|
"WRITE",
|
|
"MMAP",
|
|
"MMAP2",
|
|
"OPEN",
|
|
"FSYNC",
|
|
"FDATASYNC",
|
|
"CLOSE",
|
|
"MAPPED_PREAD",
|
|
"MAPPED_PWRITE",
|
|
"MAX_FILE_OP"
|
|
};
|
|
#endif
|
|
|
|
#define MAX(A, B) ((A) > (B) ? (A) : (B))
|
|
#define MIN(A, B) ((A) < (B) ? (A) : (B))
|
|
|
|
#define MINBUFLEN (16*1024)
|
|
|
|
#define FILE_DB_HASHSIZE 8192
|
|
|
|
struct files_db_s {
|
|
char *filename;
|
|
int fileno;
|
|
size_t size;
|
|
int fd;
|
|
int readonly;
|
|
int debug_open_flags;
|
|
struct files_db_s *next;
|
|
};
|
|
|
|
struct files_db_handle {
|
|
struct files_db_s *files_db_buckets[FILE_DB_HASHSIZE];
|
|
};
|
|
|
|
struct IO_operation_s {
|
|
char *IO_op;
|
|
};
|
|
|
|
struct rw_bytes_s {
|
|
u_int64_t bytes_read;
|
|
u_int64_t bytes_written;
|
|
};
|
|
|
|
static inline void
|
|
files_db_update_size(void *node, u_int64_t new_size)
|
|
{
|
|
struct files_db_s *db_node = (struct files_db_s *)node;
|
|
|
|
if (db_node->size < new_size)
|
|
db_node->size = new_size;
|
|
}
|
|
|
|
static inline void
|
|
files_db_update_filename(void *node, char *filename)
|
|
{
|
|
((struct files_db_s *)node)->filename = strdup(filename);
|
|
}
|
|
|
|
static inline int
|
|
files_db_get_fileno(void *node)
|
|
{
|
|
return (((struct files_db_s *)node)->fileno);
|
|
}
|
|
|
|
static inline int
|
|
files_db_get_fd(void *node)
|
|
{
|
|
return (((struct files_db_s *)node)->fd);
|
|
}
|
|
|
|
static inline char *
|
|
files_db_get_filename(void *node)
|
|
{
|
|
return (((struct files_db_s *)node)->filename);
|
|
}
|
|
|
|
static inline int
|
|
files_db_readonly(void *node)
|
|
{
|
|
return (((struct files_db_s *)node)->readonly);
|
|
}
|
|
|
|
static inline u_int64_t
|
|
get_msecs(struct timeval *tv)
|
|
{
|
|
return ((tv->tv_sec * 1000) + (tv->tv_usec / 1000));
|
|
}
|
|
|
|
static inline u_int64_t
|
|
get_usecs(struct timeval *tv)
|
|
{
|
|
return (tv->tv_usec % 1000);
|
|
}
|
|
|
|
static inline void
|
|
update_delta_time(struct timeval *start,
|
|
struct timeval *destination)
|
|
{
|
|
struct timeval res, finish;
|
|
|
|
(void)gettimeofday(&finish, (struct timezone *)NULL);
|
|
timersub(&finish, start, &res);
|
|
timeradd(destination, &res, &finish);
|
|
*destination = finish;
|
|
}
|
|
|
|
void *files_db_create_handle(void);
|
|
void *files_db_lookup_byfileno(void *handle, int fileno);
|
|
void *files_db_add_byfileno(void *handle, int fileno, int readonly);
|
|
void files_db_update_fd(void *node, int fd);
|
|
void files_db_unlink_files(void *db_handle);
|
|
void files_db_close_files(void *handle);
|
|
void files_db_close_fd(void *node);
|
|
void files_db_free_memory(void *handle);
|
|
void create_file(char *path, size_t size,
|
|
struct rw_bytes_s *rw_bytes);
|
|
char *get_buf(char **buf, int *buflen, int len, int do_fill);
|
|
void files_db_fsync_discard_files(void *handle);
|
|
void print_op_stats(u_int64_t *op_counts);
|
|
void print_bytes(char *desc, struct rw_bytes_s *rw_bytes);
|
|
void ioshark_handle_mmap(void *db_node,
|
|
struct ioshark_file_operation *file_op,
|
|
char **bufp, int *buflen, u_int64_t *op_counts,
|
|
struct rw_bytes_s *rw_bytes);
|
|
void capture_util_state_before(void);
|
|
void report_cpu_disk_util(void);
|
|
|
|
char *get_ro_filename(int ix);
|
|
void init_filename_cache(void);
|
|
void free_filename_cache(void);
|
|
int is_readonly_mount(char *filename, size_t size);
|
|
|
|
int ioshark_read_header(FILE *fp, struct ioshark_header *header);
|
|
int ioshark_read_file_state(FILE *fp, struct ioshark_file_state *state);
|
|
int ioshark_read_file_op(FILE *fp, struct ioshark_file_operation *file_op);
|