17e6ee7adSKyungmin Park /* 27e6ee7adSKyungmin Park * MTD partitioning layer definitions 37e6ee7adSKyungmin Park * 47e6ee7adSKyungmin Park * (C) 2000 Nicolas Pitre <nico@cam.org> 57e6ee7adSKyungmin Park * 67e6ee7adSKyungmin Park * This code is GPL 77e6ee7adSKyungmin Park * 87e6ee7adSKyungmin Park * $Id: partitions.h,v 1.17 2005/11/07 11:14:55 gleixner Exp $ 97e6ee7adSKyungmin Park */ 107e6ee7adSKyungmin Park 117e6ee7adSKyungmin Park #ifndef MTD_PARTITIONS_H 127e6ee7adSKyungmin Park #define MTD_PARTITIONS_H 137e6ee7adSKyungmin Park 147e6ee7adSKyungmin Park #include <linux/types.h> 157e6ee7adSKyungmin Park 167e6ee7adSKyungmin Park 177e6ee7adSKyungmin Park /* 187e6ee7adSKyungmin Park * Partition definition structure: 197e6ee7adSKyungmin Park * 207e6ee7adSKyungmin Park * An array of struct partition is passed along with a MTD object to 217e6ee7adSKyungmin Park * add_mtd_partitions() to create them. 227e6ee7adSKyungmin Park * 237e6ee7adSKyungmin Park * For each partition, these fields are available: 247e6ee7adSKyungmin Park * name: string that will be used to label the partition's MTD device. 257e6ee7adSKyungmin Park * size: the partition size; if defined as MTDPART_SIZ_FULL, the partition 267e6ee7adSKyungmin Park * will extend to the end of the master MTD device. 277e6ee7adSKyungmin Park * offset: absolute starting position within the master MTD device; if 287e6ee7adSKyungmin Park * defined as MTDPART_OFS_APPEND, the partition will start where the 297e6ee7adSKyungmin Park * previous one ended; if MTDPART_OFS_NXTBLK, at the next erase block. 307e6ee7adSKyungmin Park * mask_flags: contains flags that have to be masked (removed) from the 317e6ee7adSKyungmin Park * master MTD flag set for the corresponding MTD partition. 327e6ee7adSKyungmin Park * For example, to force a read-only partition, simply adding 337e6ee7adSKyungmin Park * MTD_WRITEABLE to the mask_flags will do the trick. 347e6ee7adSKyungmin Park * 357e6ee7adSKyungmin Park * Note: writeable partitions require their size and offset be 367e6ee7adSKyungmin Park * erasesize aligned (e.g. use MTDPART_OFS_NEXTBLK). 377e6ee7adSKyungmin Park */ 387e6ee7adSKyungmin Park 397e6ee7adSKyungmin Park struct mtd_partition { 407e6ee7adSKyungmin Park char *name; /* identifier string */ 41*aaa8eec5SSandeep Paulraj uint64_t size; /* partition size */ 42*aaa8eec5SSandeep Paulraj uint64_t offset; /* offset within the master MTD space */ 437e6ee7adSKyungmin Park u_int32_t mask_flags; /* master MTD flags to mask out for this partition */ 447e6ee7adSKyungmin Park struct nand_ecclayout *ecclayout; /* out of band layout for this partition (NAND only)*/ 457e6ee7adSKyungmin Park struct mtd_info **mtdp; /* pointer to store the MTD object */ 467e6ee7adSKyungmin Park }; 477e6ee7adSKyungmin Park 487e6ee7adSKyungmin Park #define MTDPART_OFS_NXTBLK (-2) 497e6ee7adSKyungmin Park #define MTDPART_OFS_APPEND (-1) 507e6ee7adSKyungmin Park #define MTDPART_SIZ_FULL (0) 517e6ee7adSKyungmin Park 527e6ee7adSKyungmin Park 537e6ee7adSKyungmin Park int add_mtd_partitions(struct mtd_info *, const struct mtd_partition *, int); 547e6ee7adSKyungmin Park int del_mtd_partitions(struct mtd_info *); 557e6ee7adSKyungmin Park 567e6ee7adSKyungmin Park #if 0 577e6ee7adSKyungmin Park /* 587e6ee7adSKyungmin Park * Functions dealing with the various ways of partitioning the space 597e6ee7adSKyungmin Park */ 607e6ee7adSKyungmin Park 617e6ee7adSKyungmin Park struct mtd_part_parser { 627e6ee7adSKyungmin Park struct list_head list; 637e6ee7adSKyungmin Park struct module *owner; 647e6ee7adSKyungmin Park const char *name; 657e6ee7adSKyungmin Park int (*parse_fn)(struct mtd_info *, struct mtd_partition **, unsigned long); 667e6ee7adSKyungmin Park }; 677e6ee7adSKyungmin Park 687e6ee7adSKyungmin Park extern int register_mtd_parser(struct mtd_part_parser *parser); 697e6ee7adSKyungmin Park extern int deregister_mtd_parser(struct mtd_part_parser *parser); 707e6ee7adSKyungmin Park extern int parse_mtd_partitions(struct mtd_info *master, const char **types, 717e6ee7adSKyungmin Park struct mtd_partition **pparts, unsigned long origin); 727e6ee7adSKyungmin Park 737e6ee7adSKyungmin Park #define put_partition_parser(p) do { module_put((p)->owner); } while(0) 747e6ee7adSKyungmin Park 757e6ee7adSKyungmin Park struct device; 767e6ee7adSKyungmin Park struct device_node; 777e6ee7adSKyungmin Park 787e6ee7adSKyungmin Park int __devinit of_mtd_parse_partitions(struct device *dev, 797e6ee7adSKyungmin Park struct mtd_info *mtd, 807e6ee7adSKyungmin Park struct device_node *node, 817e6ee7adSKyungmin Park struct mtd_partition **pparts); 827e6ee7adSKyungmin Park #endif 837e6ee7adSKyungmin Park 847e6ee7adSKyungmin Park #endif 85