~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/linux/mtd/partitions.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /include/linux/mtd/partitions.h (Architecture sparc64) and /include/linux/mtd/partitions.h (Architecture alpha)


  1 /*                                                  1 /*
  2  * MTD partitioning layer definitions               2  * MTD partitioning layer definitions
  3  *                                                  3  *
  4  * (C) 2000 Nicolas Pitre <nico@fluxnic.net>        4  * (C) 2000 Nicolas Pitre <nico@fluxnic.net>
  5  *                                                  5  *
  6  * This code is GPL                                 6  * This code is GPL
  7  */                                                 7  */
  8                                                     8 
  9 #ifndef MTD_PARTITIONS_H                            9 #ifndef MTD_PARTITIONS_H
 10 #define MTD_PARTITIONS_H                           10 #define MTD_PARTITIONS_H
 11                                                    11 
 12 #include <linux/types.h>                           12 #include <linux/types.h>
 13                                                    13 
 14                                                    14 
 15 /*                                                 15 /*
 16  * Partition definition structure:                 16  * Partition definition structure:
 17  *                                                 17  *
 18  * An array of struct partition is passed alon     18  * An array of struct partition is passed along with a MTD object to
 19  * mtd_device_register() to create them.           19  * mtd_device_register() to create them.
 20  *                                                 20  *
 21  * For each partition, these fields are availa     21  * For each partition, these fields are available:
 22  * name: string that will be used to label the     22  * name: string that will be used to label the partition's MTD device.
 23  * types: some partitions can be containers us     23  * types: some partitions can be containers using specific format to describe
 24  *      embedded subpartitions / volumes. E.g.     24  *      embedded subpartitions / volumes. E.g. many home routers use "firmware"
 25  *      partition that contains at least kerne     25  *      partition that contains at least kernel and rootfs. In such case an
 26  *      extra parser is needed that will detec     26  *      extra parser is needed that will detect these dynamic partitions and
 27  *      report them to the MTD subsystem. If s     27  *      report them to the MTD subsystem. If set this property stores an array
 28  *      of parser names to use when looking fo     28  *      of parser names to use when looking for subpartitions.
 29  * size: the partition size; if defined as MTD     29  * size: the partition size; if defined as MTDPART_SIZ_FULL, the partition
 30  *      will extend to the end of the master M     30  *      will extend to the end of the master MTD device.
 31  * offset: absolute starting position within t     31  * offset: absolute starting position within the master MTD device; if
 32  *      defined as MTDPART_OFS_APPEND, the par     32  *      defined as MTDPART_OFS_APPEND, the partition will start where the
 33  *      previous one ended; if MTDPART_OFS_NXT     33  *      previous one ended; if MTDPART_OFS_NXTBLK, at the next erase block;
 34  *      if MTDPART_OFS_RETAIN, consume as much     34  *      if MTDPART_OFS_RETAIN, consume as much as possible, leaving size
 35  *      after the end of partition.                35  *      after the end of partition.
 36  * mask_flags: contains flags that have to be      36  * mask_flags: contains flags that have to be masked (removed) from the
 37  *      master MTD flag set for the correspond     37  *      master MTD flag set for the corresponding MTD partition.
 38  *      For example, to force a read-only part     38  *      For example, to force a read-only partition, simply adding
 39  *      MTD_WRITEABLE to the mask_flags will d     39  *      MTD_WRITEABLE to the mask_flags will do the trick.
 40  * add_flags: contains flags to add to the par     40  * add_flags: contains flags to add to the parent flags
 41  *                                                 41  *
 42  * Note: writeable partitions require their si     42  * Note: writeable partitions require their size and offset be
 43  * erasesize aligned (e.g. use MTDPART_OFS_NEX     43  * erasesize aligned (e.g. use MTDPART_OFS_NEXTBLK).
 44  */                                                44  */
 45                                                    45 
 46 struct mtd_partition {                             46 struct mtd_partition {
 47         const char *name;               /* ide     47         const char *name;               /* identifier string */
 48         const char *const *types;       /* nam     48         const char *const *types;       /* names of parsers to use if any */
 49         uint64_t size;                  /* par     49         uint64_t size;                  /* partition size */
 50         uint64_t offset;                /* off     50         uint64_t offset;                /* offset within the master MTD space */
 51         uint32_t mask_flags;            /* mas     51         uint32_t mask_flags;            /* master MTD flags to mask out for this partition */
 52         uint32_t add_flags;             /* fla     52         uint32_t add_flags;             /* flags to add to the partition */
 53         struct device_node *of_node;               53         struct device_node *of_node;
 54 };                                                 54 };
 55                                                    55 
 56 #define MTDPART_OFS_RETAIN      (-3)               56 #define MTDPART_OFS_RETAIN      (-3)
 57 #define MTDPART_OFS_NXTBLK      (-2)               57 #define MTDPART_OFS_NXTBLK      (-2)
 58 #define MTDPART_OFS_APPEND      (-1)               58 #define MTDPART_OFS_APPEND      (-1)
 59 #define MTDPART_SIZ_FULL        (0)                59 #define MTDPART_SIZ_FULL        (0)
 60                                                    60 
 61                                                    61 
 62 struct mtd_info;                                   62 struct mtd_info;
 63 struct device_node;                                63 struct device_node;
 64                                                    64 
 65 /**                                                65 /**
 66  * struct mtd_part_parser_data - used to pass      66  * struct mtd_part_parser_data - used to pass data to MTD partition parsers.
 67  * @origin: for RedBoot, start address of MTD      67  * @origin: for RedBoot, start address of MTD device
 68  */                                                68  */
 69 struct mtd_part_parser_data {                      69 struct mtd_part_parser_data {
 70         unsigned long origin;                      70         unsigned long origin;
 71 };                                                 71 };
 72                                                    72 
 73                                                    73 
 74 /*                                                 74 /*
 75  * Functions dealing with the various ways of      75  * Functions dealing with the various ways of partitioning the space
 76  */                                                76  */
 77                                                    77 
 78 struct mtd_part_parser {                           78 struct mtd_part_parser {
 79         struct list_head list;                     79         struct list_head list;
 80         struct module *owner;                      80         struct module *owner;
 81         const char *name;                          81         const char *name;
 82         const struct of_device_id *of_match_ta     82         const struct of_device_id *of_match_table;
 83         int (*parse_fn)(struct mtd_info *, con     83         int (*parse_fn)(struct mtd_info *, const struct mtd_partition **,
 84                         struct mtd_part_parser     84                         struct mtd_part_parser_data *);
 85         void (*cleanup)(const struct mtd_parti     85         void (*cleanup)(const struct mtd_partition *pparts, int nr_parts);
 86 };                                                 86 };
 87                                                    87 
 88 /* Container for passing around a set of parse     88 /* Container for passing around a set of parsed partitions */
 89 struct mtd_partitions {                            89 struct mtd_partitions {
 90         const struct mtd_partition *parts;         90         const struct mtd_partition *parts;
 91         int nr_parts;                              91         int nr_parts;
 92         const struct mtd_part_parser *parser;      92         const struct mtd_part_parser *parser;
 93 };                                                 93 };
 94                                                    94 
 95 extern int __register_mtd_parser(struct mtd_pa     95 extern int __register_mtd_parser(struct mtd_part_parser *parser,
 96                                  struct module     96                                  struct module *owner);
 97 #define register_mtd_parser(parser) __register     97 #define register_mtd_parser(parser) __register_mtd_parser(parser, THIS_MODULE)
 98                                                    98 
 99 extern void deregister_mtd_parser(struct mtd_p     99 extern void deregister_mtd_parser(struct mtd_part_parser *parser);
100                                                   100 
101 /*                                                101 /*
102  * module_mtd_part_parser() - Helper macro for    102  * module_mtd_part_parser() - Helper macro for MTD partition parsers that don't
103  * do anything special in module init/exit. Ea    103  * do anything special in module init/exit. Each driver may only use this macro
104  * once, and calling it replaces module_init()    104  * once, and calling it replaces module_init() and module_exit().
105  */                                               105  */
106 #define module_mtd_part_parser(__mtd_part_pars    106 #define module_mtd_part_parser(__mtd_part_parser) \
107         module_driver(__mtd_part_parser, regis    107         module_driver(__mtd_part_parser, register_mtd_parser, \
108                       deregister_mtd_parser)      108                       deregister_mtd_parser)
109                                                   109 
110 int mtd_add_partition(struct mtd_info *master,    110 int mtd_add_partition(struct mtd_info *master, const char *name,
111                       long long offset, long l    111                       long long offset, long long length);
112 int mtd_del_partition(struct mtd_info *master,    112 int mtd_del_partition(struct mtd_info *master, int partno);
113 uint64_t mtd_get_device_size(const struct mtd_    113 uint64_t mtd_get_device_size(const struct mtd_info *mtd);
114                                                   114 
115 #endif                                            115 #endif
116                                                   116 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php