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
0036
0037
0038
0039 #ifdef HAVE_CONFIG_H
0040 #include "config.h"
0041 #endif
0042
0043 #include "rtems-rfs-rtems.h"
0044
0045 #include <rtems/deviceio.h>
0046
0047 static void
0048 rtems_rfs_rtems_device_get_major_and_minor ( const rtems_libio_t *iop,
0049 rtems_device_major_number *major,
0050 rtems_device_minor_number *minor)
0051 {
0052 *major = iop->data0;
0053 *minor = (rtems_device_minor_number) (uintptr_t) iop->data1;
0054 }
0055
0056
0057
0058
0059
0060
0061
0062
0063
0064
0065 static int
0066 rtems_rfs_rtems_device_open ( rtems_libio_t *iop,
0067 const char *pathname,
0068 int oflag,
0069 mode_t mode)
0070 {
0071 rtems_rfs_file_system* fs = rtems_rfs_rtems_pathloc_dev (&iop->pathinfo);
0072 rtems_rfs_ino ino = rtems_rfs_rtems_get_iop_ino (iop);
0073 rtems_rfs_inode_handle inode;
0074 rtems_device_major_number major;
0075 rtems_device_minor_number minor;
0076 int rc;
0077
0078 rtems_rfs_rtems_lock (fs);
0079
0080 rc = rtems_rfs_inode_open (fs, ino, &inode, true);
0081 if (rc > 0)
0082 {
0083 rtems_rfs_rtems_unlock (fs);
0084 return rtems_rfs_rtems_error ("device_open: opening inode", rc);
0085 }
0086
0087 major = rtems_rfs_inode_get_block (&inode, 0);
0088 minor = rtems_rfs_inode_get_block (&inode, 1);
0089
0090 rc = rtems_rfs_inode_close (fs, &inode);
0091 if (rc > 0)
0092 {
0093 rtems_rfs_rtems_unlock (fs);
0094 return rtems_rfs_rtems_error ("device_open: closing inode", rc);
0095 }
0096
0097 rtems_rfs_rtems_unlock (fs);
0098
0099 iop->data0 = major;
0100 iop->data1 = (void *) (uintptr_t) minor;
0101
0102 return rtems_deviceio_open (iop, pathname, oflag, mode, minor, major);
0103 }
0104
0105
0106
0107
0108
0109
0110
0111
0112 static int
0113 rtems_rfs_rtems_device_close (rtems_libio_t* iop)
0114 {
0115 rtems_device_major_number major;
0116 rtems_device_minor_number minor;
0117
0118 rtems_rfs_rtems_device_get_major_and_minor (iop, &major, &minor);
0119
0120 return rtems_deviceio_close (iop, major, minor);
0121 }
0122
0123
0124
0125
0126
0127
0128
0129
0130
0131
0132 static ssize_t
0133 rtems_rfs_rtems_device_read (rtems_libio_t* iop, void* buffer, size_t count)
0134 {
0135 rtems_device_major_number major;
0136 rtems_device_minor_number minor;
0137
0138 rtems_rfs_rtems_device_get_major_and_minor (iop, &major, &minor);
0139
0140 return rtems_deviceio_read (iop, buffer, count, major, minor);
0141 }
0142
0143
0144
0145
0146
0147
0148
0149
0150
0151
0152 static ssize_t
0153 rtems_rfs_rtems_device_write (rtems_libio_t* iop,
0154 const void* buffer,
0155 size_t count)
0156 {
0157 rtems_device_major_number major;
0158 rtems_device_minor_number minor;
0159
0160 rtems_rfs_rtems_device_get_major_and_minor (iop, &major, &minor);
0161
0162 return rtems_deviceio_write (iop, buffer, count, major, minor);
0163 }
0164
0165
0166
0167
0168
0169
0170
0171
0172
0173
0174 static int
0175 rtems_rfs_rtems_device_ioctl (rtems_libio_t* iop,
0176 ioctl_command_t command,
0177 void* buffer)
0178 {
0179 rtems_device_major_number major;
0180 rtems_device_minor_number minor;
0181
0182 rtems_rfs_rtems_device_get_major_and_minor (iop, &major, &minor);
0183
0184 return rtems_deviceio_control (iop, command, buffer, major, minor);
0185 }
0186
0187
0188
0189
0190
0191
0192
0193
0194
0195 static int
0196 rtems_rfs_rtems_device_ftruncate (rtems_libio_t* iop, off_t length)
0197 {
0198 return 0;
0199 }
0200
0201
0202
0203
0204
0205 const rtems_filesystem_file_handlers_r rtems_rfs_rtems_device_handlers = {
0206 .open_h = rtems_rfs_rtems_device_open,
0207 .close_h = rtems_rfs_rtems_device_close,
0208 .read_h = rtems_rfs_rtems_device_read,
0209 .write_h = rtems_rfs_rtems_device_write,
0210 .ioctl_h = rtems_rfs_rtems_device_ioctl,
0211 .lseek_h = rtems_filesystem_default_lseek_file,
0212 .fstat_h = rtems_rfs_rtems_fstat,
0213 .ftruncate_h = rtems_rfs_rtems_device_ftruncate,
0214 .fsync_h = rtems_filesystem_default_fsync_or_fdatasync,
0215 .fdatasync_h = rtems_filesystem_default_fsync_or_fdatasync,
0216 .fcntl_h = rtems_filesystem_default_fcntl,
0217 .kqfilter_h = rtems_filesystem_default_kqfilter,
0218 .mmap_h = rtems_filesystem_default_mmap,
0219 .poll_h = rtems_filesystem_default_poll,
0220 .readv_h = rtems_filesystem_default_readv,
0221 .writev_h = rtems_filesystem_default_writev
0222 };