2016-07-11 14:51:47 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 Eistec AB
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2017-03-20 11:59:10 +01:00
|
|
|
* @defgroup sys_fs_devfs DevFS device file system
|
|
|
|
* @ingroup sys_fs
|
2016-07-11 14:51:47 +02:00
|
|
|
* @brief Dynamic device file system
|
|
|
|
*
|
|
|
|
* This file system implementation allows devices to register file names for
|
|
|
|
* easier access to device drivers from shell commands etc.
|
|
|
|
*
|
|
|
|
* The idea is similar to the /dev directory on Unix.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
* @file
|
|
|
|
* @brief DevFS public API
|
|
|
|
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef DEVFS_H_
|
|
|
|
#define DEVFS_H_
|
|
|
|
|
|
|
|
#include "clist.h"
|
|
|
|
#include "vfs.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief DevFS node typedef
|
|
|
|
*/
|
|
|
|
typedef struct devfs devfs_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief A device "file" consists of a file name and an opaque pointer to device driver private data
|
|
|
|
*
|
|
|
|
* The file system is implemented as a linked list.
|
|
|
|
*/
|
|
|
|
struct devfs {
|
|
|
|
clist_node_t list_entry; /**< List item entry */
|
|
|
|
const char *path; /**< File system relative path to this node */
|
|
|
|
const vfs_file_ops_t *f_op; /**< Pointer to file operations table for this device */
|
|
|
|
void *private_data; /**< Pointer to device driver specific data */
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief DevFS file system driver
|
|
|
|
*
|
|
|
|
* For use with vfs_mount
|
|
|
|
*/
|
|
|
|
extern const vfs_file_system_t devfs_file_system;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Register a node in DevFS
|
|
|
|
*
|
|
|
|
* The node will immediately become available to @c vfs_open, if DevFS is already
|
|
|
|
* mounted somewhere.
|
|
|
|
*
|
|
|
|
* If DevFS is not mounted, the node will be registered and will become
|
|
|
|
* available to @c vfs_open when DevFS is mounted.
|
|
|
|
*
|
|
|
|
* @param[in] node DevFS node to register
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return <0 on error
|
|
|
|
*/
|
|
|
|
int devfs_register(devfs_t *node);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Remove a registration from DevFS
|
|
|
|
*
|
|
|
|
* The node will no longer be available to @c vfs_open, but any already opened FDs
|
|
|
|
* will remain open.
|
|
|
|
*
|
|
|
|
* @param[in] node DevFS node to unregister
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return <0 on error
|
|
|
|
*/
|
|
|
|
int devfs_unregister(devfs_t *node);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @} */
|