21 #if !defined (_RTEMS_RFS_FILE_H_) 22 #define _RTEMS_RFS_FILE_H_ 26 #include <rtems/rfs/rtems-rfs-block.h> 27 #include <rtems/rfs/rtems-rfs-data.h> 28 #include <rtems/rfs/rtems-rfs-file-system.h> 29 #include <rtems/rfs/rtems-rfs-inode.h> 112 return shared->
mtime;
125 return shared->
ctime;
135 static inline uint32_t
148 static inline uint16_t
172 #define RTEMS_RFS_FILE_NO_ATIME_UPDATE (1 << 0) 175 #define RTEMS_RFS_FILE_NO_MTIME_UPDATE (1 << 1) 178 #define RTEMS_RFS_FILE_NO_LENGTH_UPDATE (1 << 2) 185 typedef struct _rtems_rfs_file_handle 212 #define rtems_rfs_file_data(_f) \ 213 (rtems_rfs_buffer_data (&(_f)->buffer) + (_f)->bpos.boff) 218 #define rtems_rfs_file_fs(_f) ((_f)->shared->fs) 223 #define rtems_rfs_file_inode(_f) (&(_f)->shared->inode) 228 #define rtems_rfs_file_map(_f) (&(_f)->shared->map) 233 #define rtems_rfs_file_bpos(_f) (&(_f)->bpos) 238 #define rtems_rfs_file_block(_f) ((_f)->bpos.bno) 243 #define rtems_rfs_file_block_offset(_f) ((_f)->bpos.boff) 248 #define rtems_rfs_file_set_bpos(_f, _p) \ 249 rtems_rfs_block_get_bpos (rtems_rfs_file_fs (_f), _p, (&(_f)->bpos)) 254 #define rtems_rfs_file_buffer(_f) (&(_f)->buffer) 259 #define rtems_rfs_file_update_atime(_f) \ 260 (((_f)->flags & RTEMS_RFS_FILE_NO_ATIME_UPDATE) == 0) 265 #define rtems_rfs_file_update_mtime(_f) \ 266 (((_f)->flags & RTEMS_RFS_FILE_NO_MTIME_UPDATE) == 0) 271 #define rtems_rfs_file_update_length(_f) \ 272 (((_f)->flags & RTEMS_RFS_FILE_NO_LENGTH_UPDATE) == 0) 277 #define rtems_rfs_file_get_size(_f) \ 278 (&(_f)->shared->size) 283 #define rtems_rfs_file_size(_f) \ 284 rtems_rfs_file_shared_get_size (rtems_rfs_file_fs (_f), (_f)->shared) 289 #define rtems_rfs_file_size_count(_f) \ 290 rtems_rfs_file_shared_get_block_count ((_f)->shared) 295 #define rtems_rfs_file_size_offset(_f) \ 296 rtems_rfs_file_shared_get_block_offset ((_f)->shared) This is used to manage each element (node) which is placed on a chain.
Definition: chain.h:65
ssize_t read(int fd, void *buffer, size_t count)
POSIX 1003.1b 6.4.1 - Read From a File.
Definition: read.c:27
rtems_chain_node link
The shared parts are maintained as a list.
Definition: rtems-rfs-file.h:42
A block size is the number of blocks less one plus the offset where the offset must be less than the ...
Definition: rtems-rfs-block-pos.h:141
rtems_rfs_pos rtems_rfs_block_get_size(rtems_rfs_file_system *fs, rtems_rfs_block_size *size)
Calculate the position given the number of blocks and the offset.
Definition: rtems-rfs-block.c:78
int rtems_rfs_file_io_start(rtems_rfs_file_handle *handle, size_t *available, bool read)
Start I/O on a block of a file.
Definition: rtems-rfs-file.c:220
rtems_rfs_time atime
The access time.
Definition: rtems-rfs-file.h:69
rtems_rfs_file_shared * rtems_rfs_file_get_shared(rtems_rfs_file_system *fs, rtems_rfs_ino ino)
Return the shared file data for an ino.
Definition: rtems-rfs-file.c:619
rtems_rfs_time mtime
The modified time.
Definition: rtems-rfs-file.h:74
RFS File System data.
Definition: rtems-rfs-file-system.h:123
int rtems_rfs_file_set_size(rtems_rfs_file_handle *handle, rtems_rfs_pos size)
Set the size of the file to the new size.
Definition: rtems-rfs-file.c:469
uint64_t rtems_rfs_pos
Absolute position.
Definition: rtems-rfs-file-system.h:90
int rtems_rfs_file_seek(rtems_rfs_file_handle *handle, rtems_rfs_pos pos, rtems_rfs_pos *new_pos)
The file to the position returning the old position.
Definition: rtems-rfs-file.c:405
uint32_t rtems_rfs_ino
The inode number or ino.
Definition: rtems-rfs-inode.h:78
rtems_rfs_block_map map
The block map for the file.
Definition: rtems-rfs-file.h:58
rtems_rfs_block_off offset
The offset into the block.
Definition: rtems-rfs-block-pos.h:153
File data that is shared by various file handles accessing the same file.
Definition: rtems-rfs-file.h:37
int rtems_rfs_file_io_release(rtems_rfs_file_handle *handle)
Release the I/O resources without any changes.
Definition: rtems-rfs-file.c:395
RFS Inode Handle.
Definition: rtems-rfs-inode.h:181
File data used to managed an open file.
Definition: rtems-rfs-file.h:191
rtems_rfs_block_size size
The size of the file as taken from the inode.
Definition: rtems-rfs-file.h:64
A block position is a block number times the block size plus the offset.
Definition: rtems-rfs-block-pos.h:51
rtems_rfs_block_no count
The count of blocks in a map.
Definition: rtems-rfs-block-pos.h:147
A block map manges the block lists that originate from an inode.
Definition: rtems-rfs-block.h:92
rtems_rfs_file_system * fs
Hold a pointer to the file system data so users can take the handle and use it without the needing to...
Definition: rtems-rfs-file.h:85
int rtems_rfs_file_close(rtems_rfs_file_system *fs, rtems_rfs_file_handle *handle)
Close an open file handle.
Definition: rtems-rfs-file.c:143
rtems_rfs_time ctime
The change time.
Definition: rtems-rfs-file.h:79
LibIO Internal Interface.
rtems_rfs_inode_handle inode
The inode for the file.
Definition: rtems-rfs-file.h:52
uint32_t rtems_rfs_time
The time in the file system.
Definition: rtems-rfs-inode.h:83
int rtems_rfs_file_io_end(rtems_rfs_file_handle *handle, size_t size, bool read)
End the I/O.
Definition: rtems-rfs-file.c:308
struct _rtems_rfs_file_shared rtems_rfs_file_shared
File data that is shared by various file handles accessing the same file.
RFS Buffer handle.
Definition: rtems-rfs-buffer.h:91
int references
Reference count the users of this data.
Definition: rtems-rfs-file.h:47
int rtems_rfs_file_open(rtems_rfs_file_system *fs, rtems_rfs_ino ino, int oflag, rtems_rfs_file_handle **handle)
Open a file handle.
Definition: rtems-rfs-file.c:31
struct _rtems_rfs_file_handle rtems_rfs_file_handle
File data used to managed an open file.