xref: /rk3399_rockchip-uboot/include/linux/mtd/partitions.h (revision aaa8eec532876c47acfd31bf9b573a00eaad92ae)
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