source: rtems/cpukit/include/rtems/rtems-rfs-format.h

Last change on this file was fb5f575, checked in by Joel Sherrill <joel@…>, on 03/25/22 at 16:14:25

cpukit/include/rtems: Change license to BSD-2

Updates #3053.

  • Property mode set to 100644
File size: 2.7 KB
Line 
1/* SPDX-License-Identifier: BSD-2-Clause */
2
3/**
4 * @file
5 *
6 * @ingroup rtems_rfs
7 *
8 * @brief RTEMS File System Format
9 *
10 * This function lets you format a disk in the RFS format.
11 */
12
13/*
14 *  COPYRIGHT (c) 2010 Chris Johns <chrisj@rtems.org>
15 *
16 * Redistribution and use in source and binary forms, with or without
17 * modification, are permitted provided that the following conditions
18 * are met:
19 * 1. Redistributions of source code must retain the above copyright
20 *    notice, this list of conditions and the following disclaimer.
21 * 2. Redistributions in binary form must reproduce the above copyright
22 *    notice, this list of conditions and the following disclaimer in the
23 *    documentation and/or other materials provided with the distribution.
24 *
25 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
26 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
28 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
29 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35 * POSSIBILITY OF SUCH DAMAGE.
36 */
37
38#if !defined (_RTEMS_RFS_FORMAT_H_)
39#define _RTEMS_RFS_FORMAT_H_
40
41#include <stddef.h>
42#include <stdbool.h>
43#include <stdint.h>
44
45#ifdef __cplusplus
46extern "C" {
47#endif
48
49#include <rtems/rfs/rtems-rfs-trace.h>
50
51/**
52 * RFS File System Configuration data used to format the file system. For
53 * default values leave the field set to 0.
54 */
55typedef struct _rtems_rfs_format_config
56{
57  /**
58   * The size of a block.
59   */
60  size_t block_size;
61
62  /**
63   * The number of blocks in a group.
64   */
65  size_t group_blocks;
66
67  /**
68   * The number of inodes in a group.
69   */
70  size_t group_inodes;
71
72  /**
73   * The percentage overhead allocated to inodes.
74   */
75  int inode_overhead;
76
77  /**
78   * The maximum length of a name.
79   */
80  size_t max_name_length;
81
82  /**
83   * Initialise the inode tables to all ones.
84   */
85  bool initialise_inodes;
86
87  /**
88   * Is the format verbose.
89   */
90  bool verbose;
91
92} rtems_rfs_format_config;
93
94/**
95 * RFS Format command.
96 *
97 * @param[in] name is the device name to format.
98 * @param[in] config is a pointer to the configuration table.
99 *
100 * @retval -1 Error. See errno.
101 * @retval 0 No error. Format successful.
102 */
103int rtems_rfs_format (const char* name, const rtems_rfs_format_config* config);
104
105#ifdef __cplusplus
106}
107#endif
108
109#endif
Note: See TracBrowser for help on using the repository browser.