~ [ 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 (Version linux-6.12-rc7) and /include/linux/mtd/partitions.h (Version linux-4.15.18)


  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 << 
 41  *                                                 40  *
 42  * Note: writeable partitions require their si     41  * Note: writeable partitions require their size and offset be
 43  * erasesize aligned (e.g. use MTDPART_OFS_NEX     42  * erasesize aligned (e.g. use MTDPART_OFS_NEXTBLK).
 44  */                                                43  */
 45                                                    44 
 46 struct mtd_partition {                             45 struct mtd_partition {
 47         const char *name;               /* ide     46         const char *name;               /* identifier string */
 48         const char *const *types;       /* nam     47         const char *const *types;       /* names of parsers to use if any */
 49         uint64_t size;                  /* par     48         uint64_t size;                  /* partition size */
 50         uint64_t offset;                /* off     49         uint64_t offset;                /* offset within the master MTD space */
 51         uint32_t mask_flags;            /* mas     50         uint32_t mask_flags;            /* master MTD flags to mask out for this partition */
 52         uint32_t add_flags;             /* fla << 
 53         struct device_node *of_node;               51         struct device_node *of_node;
 54 };                                                 52 };
 55                                                    53 
 56 #define MTDPART_OFS_RETAIN      (-3)               54 #define MTDPART_OFS_RETAIN      (-3)
 57 #define MTDPART_OFS_NXTBLK      (-2)               55 #define MTDPART_OFS_NXTBLK      (-2)
 58 #define MTDPART_OFS_APPEND      (-1)               56 #define MTDPART_OFS_APPEND      (-1)
 59 #define MTDPART_SIZ_FULL        (0)                57 #define MTDPART_SIZ_FULL        (0)
 60                                                    58 
 61                                                    59 
 62 struct mtd_info;                                   60 struct mtd_info;
 63 struct device_node;                                61 struct device_node;
 64                                                    62 
 65 /**                                                63 /**
 66  * struct mtd_part_parser_data - used to pass      64  * struct mtd_part_parser_data - used to pass data to MTD partition parsers.
 67  * @origin: for RedBoot, start address of MTD      65  * @origin: for RedBoot, start address of MTD device
 68  */                                                66  */
 69 struct mtd_part_parser_data {                      67 struct mtd_part_parser_data {
 70         unsigned long origin;                      68         unsigned long origin;
 71 };                                                 69 };
 72                                                    70 
 73                                                    71 
 74 /*                                                 72 /*
 75  * Functions dealing with the various ways of      73  * Functions dealing with the various ways of partitioning the space
 76  */                                                74  */
 77                                                    75 
 78 struct mtd_part_parser {                           76 struct mtd_part_parser {
 79         struct list_head list;                     77         struct list_head list;
 80         struct module *owner;                      78         struct module *owner;
 81         const char *name;                          79         const char *name;
 82         const struct of_device_id *of_match_ta << 
 83         int (*parse_fn)(struct mtd_info *, con     80         int (*parse_fn)(struct mtd_info *, const struct mtd_partition **,
 84                         struct mtd_part_parser     81                         struct mtd_part_parser_data *);
 85         void (*cleanup)(const struct mtd_parti     82         void (*cleanup)(const struct mtd_partition *pparts, int nr_parts);
 86 };                                                 83 };
 87                                                    84 
 88 /* Container for passing around a set of parse     85 /* Container for passing around a set of parsed partitions */
 89 struct mtd_partitions {                            86 struct mtd_partitions {
 90         const struct mtd_partition *parts;         87         const struct mtd_partition *parts;
 91         int nr_parts;                              88         int nr_parts;
 92         const struct mtd_part_parser *parser;      89         const struct mtd_part_parser *parser;
 93 };                                                 90 };
 94                                                    91 
 95 extern int __register_mtd_parser(struct mtd_pa     92 extern int __register_mtd_parser(struct mtd_part_parser *parser,
 96                                  struct module     93                                  struct module *owner);
 97 #define register_mtd_parser(parser) __register     94 #define register_mtd_parser(parser) __register_mtd_parser(parser, THIS_MODULE)
 98                                                    95 
 99 extern void deregister_mtd_parser(struct mtd_p     96 extern void deregister_mtd_parser(struct mtd_part_parser *parser);
100                                                    97 
101 /*                                                 98 /*
102  * module_mtd_part_parser() - Helper macro for     99  * module_mtd_part_parser() - Helper macro for MTD partition parsers that don't
103  * do anything special in module init/exit. Ea    100  * do anything special in module init/exit. Each driver may only use this macro
104  * once, and calling it replaces module_init()    101  * once, and calling it replaces module_init() and module_exit().
105  */                                               102  */
106 #define module_mtd_part_parser(__mtd_part_pars    103 #define module_mtd_part_parser(__mtd_part_parser) \
107         module_driver(__mtd_part_parser, regis    104         module_driver(__mtd_part_parser, register_mtd_parser, \
108                       deregister_mtd_parser)      105                       deregister_mtd_parser)
109                                                   106 
                                                   >> 107 int mtd_is_partition(const struct mtd_info *mtd);
110 int mtd_add_partition(struct mtd_info *master,    108 int mtd_add_partition(struct mtd_info *master, const char *name,
111                       long long offset, long l    109                       long long offset, long long length);
112 int mtd_del_partition(struct mtd_info *master,    110 int mtd_del_partition(struct mtd_info *master, int partno);
113 uint64_t mtd_get_device_size(const struct mtd_    111 uint64_t mtd_get_device_size(const struct mtd_info *mtd);
114                                                   112 
115 #endif                                            113 #endif
116                                                   114 

~ [ 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