File indexing completed on 2025-05-11 08:24:18
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030
0031
0032
0033
0034
0035 #ifdef HAVE_CONFIG_H
0036 #include "config.h"
0037 #endif
0038
0039 #include <inttypes.h>
0040
0041 #include <sys/types.h>
0042 #include <sys/stat.h>
0043 #include <fcntl.h>
0044 #include <stdlib.h>
0045 #include <stdio.h>
0046 #include <unistd.h>
0047
0048 #include <rtems/rfs/rtems-rfs-dir.h>
0049 #include <rtems/rfs/rtems-rfs-link.h>
0050 #include "rtems-rfs-rtems.h"
0051
0052
0053
0054
0055
0056
0057 static int
0058 rtems_rfs_rtems_dir_open (rtems_libio_t* iop,
0059 const char* pathname,
0060 int oflag,
0061 mode_t mode)
0062 {
0063 rtems_rfs_file_system* fs = rtems_rfs_rtems_pathloc_dev (&iop->pathinfo);
0064 rtems_rfs_ino ino = rtems_rfs_rtems_get_iop_ino (iop);
0065 rtems_rfs_inode_handle inode;
0066 int rc;
0067
0068 rtems_rfs_rtems_lock (fs);
0069
0070 rc = rtems_rfs_inode_open (fs, ino, &inode, true);
0071 if (rc)
0072 {
0073 rtems_rfs_rtems_unlock (fs);
0074 return rtems_rfs_rtems_error ("dir_open: opening inode", rc);
0075 }
0076
0077 if (!RTEMS_RFS_S_ISDIR (rtems_rfs_inode_get_mode (&inode)))
0078 {
0079 rtems_rfs_inode_close (fs, &inode);
0080 rtems_rfs_rtems_unlock (fs);
0081 return rtems_rfs_rtems_error ("dir_open: not dir", ENOTDIR);
0082 }
0083
0084 iop->offset = 0;
0085
0086 rtems_rfs_inode_close (fs, &inode);
0087 rtems_rfs_rtems_unlock (fs);
0088 return 0;
0089 }
0090
0091
0092
0093
0094
0095
0096
0097
0098 static int
0099 rtems_rfs_rtems_dir_close (rtems_libio_t* iop)
0100 {
0101
0102
0103
0104 return 0;
0105 }
0106
0107
0108
0109
0110
0111
0112
0113
0114
0115
0116
0117
0118
0119 static ssize_t
0120 rtems_rfs_rtems_dir_read (rtems_libio_t* iop,
0121 void* buffer,
0122 size_t count)
0123 {
0124 rtems_rfs_file_system* fs = rtems_rfs_rtems_pathloc_dev (&iop->pathinfo);
0125 rtems_rfs_ino ino = rtems_rfs_rtems_get_iop_ino (iop);
0126 rtems_rfs_inode_handle inode;
0127 struct dirent* dirent;
0128 ssize_t bytes_transferred;
0129 int d;
0130 int rc;
0131
0132 count = count / sizeof (struct dirent);
0133 dirent = buffer;
0134
0135 rtems_rfs_rtems_lock (fs);
0136
0137 rc = rtems_rfs_inode_open (fs, ino, &inode, true);
0138 if (rc)
0139 {
0140 rtems_rfs_rtems_unlock (fs);
0141 return rtems_rfs_rtems_error ("dir_read: read inode", rc);
0142 }
0143
0144 bytes_transferred = 0;
0145
0146 for (d = 0; d < count; d++, dirent++)
0147 {
0148 size_t size;
0149 rc = rtems_rfs_dir_read (fs, &inode, iop->offset, dirent, &size);
0150 if (rc == ENOENT)
0151 {
0152 rc = 0;
0153 break;
0154 }
0155 if (rc > 0)
0156 {
0157 bytes_transferred = rtems_rfs_rtems_error ("dir_read: dir read", rc);
0158 break;
0159 }
0160 iop->offset += size;
0161 bytes_transferred += sizeof (struct dirent);
0162 }
0163
0164 rtems_rfs_inode_close (fs, &inode);
0165 rtems_rfs_rtems_unlock (fs);
0166
0167 return bytes_transferred;
0168 }
0169
0170
0171
0172
0173
0174 const rtems_filesystem_file_handlers_r rtems_rfs_rtems_dir_handlers = {
0175 .open_h = rtems_rfs_rtems_dir_open,
0176 .close_h = rtems_rfs_rtems_dir_close,
0177 .read_h = rtems_rfs_rtems_dir_read,
0178 .write_h = rtems_filesystem_default_write,
0179 .ioctl_h = rtems_filesystem_default_ioctl,
0180 .lseek_h = rtems_filesystem_default_lseek_directory,
0181 .fstat_h = rtems_rfs_rtems_fstat,
0182 .ftruncate_h = rtems_filesystem_default_ftruncate_directory,
0183 .fsync_h = rtems_filesystem_default_fsync_or_fdatasync,
0184 .fdatasync_h = rtems_rfs_rtems_fdatasync,
0185 .fcntl_h = rtems_filesystem_default_fcntl,
0186 .kqfilter_h = rtems_filesystem_default_kqfilter,
0187 .mmap_h = rtems_filesystem_default_mmap,
0188 .poll_h = rtems_filesystem_default_poll,
0189 .readv_h = rtems_filesystem_default_readv,
0190 .writev_h = rtems_filesystem_default_writev
0191 };