X-Git-Url: http://git.sven.stormbind.net/?p=sven%2Fexfat-utils.git;a=blobdiff_plain;f=libexfat%2Fexfat.h;h=bca0d240f5496ee6baffa13e9be1e13100909cbc;hp=de2e1a23746cc4529a46c7a31c442d25d4c574c8;hb=1f5c4d900674e89576886f971ba292ad14f947f7;hpb=8cf24443c2e50411fc4c78730ba8048dff3add26 diff --git a/libexfat/exfat.h b/libexfat/exfat.h index de2e1a2..bca0d24 100644 --- a/libexfat/exfat.h +++ b/libexfat/exfat.h @@ -69,10 +69,12 @@ struct exfat_node le16_t name[EXFAT_NAME_MAX + 1]; }; +struct exfat_dev; + struct exfat { + struct exfat_dev* dev; struct exfat_super_block* sb; - int fd; le16_t* upcase; size_t upcase_chars; struct exfat_node* root; @@ -120,12 +122,19 @@ void exfat_warn(const char* format, ...) void exfat_debug(const char* format, ...) __attribute__((format(printf, 1, 2))); -int exfat_open(const char* spec, int ro); -void exfat_read_raw(void* buffer, size_t size, off_t offset, int fd); -void exfat_write_raw(const void* buffer, size_t size, off_t offset, int fd); -ssize_t exfat_read(const struct exfat* ef, struct exfat_node* node, +struct exfat_dev* exfat_open(const char* spec, int ro); +int exfat_close(struct exfat_dev* dev); +int exfat_fsync(struct exfat_dev* dev); +off_t exfat_seek(struct exfat_dev* dev, off_t offset, int whence); +ssize_t exfat_read(struct exfat_dev* dev, void* buffer, size_t size); +ssize_t exfat_write(struct exfat_dev* dev, const void* buffer, size_t size); +void exfat_pread(struct exfat_dev* dev, void* buffer, size_t size, + off_t offset); +void exfat_pwrite(struct exfat_dev* dev, const void* buffer, size_t size, + off_t offset); +ssize_t exfat_generic_pread(const struct exfat* ef, struct exfat_node* node, void* buffer, size_t size, off_t offset); -ssize_t exfat_write(struct exfat* ef, struct exfat_node* node, +ssize_t exfat_generic_pwrite(struct exfat* ef, struct exfat_node* node, const void* buffer, size_t size, off_t offset); int exfat_opendir(struct exfat* ef, struct exfat_node* dir, @@ -149,9 +158,6 @@ int exfat_find_used_sectors(const struct exfat* ef, off_t* a, off_t* b); void exfat_stat(const struct exfat* ef, const struct exfat_node* node, struct stat* stbuf); -time_t exfat_exfat2unix(le16_t date, le16_t time, uint8_t centisec); -void exfat_unix2exfat(time_t unix_time, le16_t* date, le16_t* time, - uint8_t* centisec); void exfat_get_name(const struct exfat_node* node, char* buffer, size_t n); uint16_t exfat_start_checksum(const struct exfat_entry_meta1* entry); uint16_t exfat_add_checksum(const void* entry, uint16_t sum); @@ -189,4 +195,9 @@ int exfat_set_label(struct exfat* ef, const char* label); int exfat_mount(struct exfat* ef, const char* spec, const char* options); void exfat_unmount(struct exfat* ef); +time_t exfat_exfat2unix(le16_t date, le16_t time, uint8_t centisec); +void exfat_unix2exfat(time_t unix_time, le16_t* date, le16_t* time, + uint8_t* centisec); +void exfat_tzset(void); + #endif /* ifndef EXFAT_H_INCLUDED */