/* * Device Operations Table for the IMFS * * COPYRIGHT (c) 1989-1999. * On-Line Applications Research Corporation (OAR). * * The license and distribution terms for this file may be * found in the file LICENSE in this distribution or at * http://www.rtems.com/license/LICENSE. * * $Id$ */ #if HAVE_CONFIG_H #include "config.h" #endif #include "imfs.h" static int IMFS_stat_device( const rtems_filesystem_location_info_t *loc, struct stat *buf ) { const IMFS_jnode_t *node = loc->node_access; const IMFS_device_t *io = &node->info.device; buf->st_rdev = rtems_filesystem_make_dev_t( io->major, io->minor ); return IMFS_stat( loc, buf ); } static const rtems_filesystem_file_handlers_r IMFS_device_handlers = { device_open, device_close, device_read, device_write, device_ioctl, rtems_filesystem_default_lseek_file, IMFS_stat_device, device_ftruncate, rtems_filesystem_default_fsync_or_fdatasync, rtems_filesystem_default_fsync_or_fdatasync, rtems_filesystem_default_fcntl }; static IMFS_jnode_t *IMFS_node_initialize_device( IMFS_jnode_t *node, const IMFS_types_union *info ) { node->info.device.major = info->device.major; node->info.device.minor = info->device.minor; return node; } const IMFS_node_control IMFS_node_control_device = { .imfs_type = IMFS_DEVICE, .handlers = &IMFS_device_handlers, .node_initialize = IMFS_node_initialize_device, .node_remove = IMFS_node_remove_default, .node_destroy = IMFS_node_destroy_default };