xref: /rk3399_rockchip-uboot/include/memblk.h (revision efda1f1db3f4fc77c65c060b5bdb91d223df5d69)
188bfa979SJoseph Chen /* SPDX-License-Identifier:     GPL-2.0+ */
288bfa979SJoseph Chen /*
388bfa979SJoseph Chen  * (C) Copyright 2019 Rockchip Electronics Co., Ltd
488bfa979SJoseph Chen  */
588bfa979SJoseph Chen 
688bfa979SJoseph Chen #ifndef _MEMBLK_H
788bfa979SJoseph Chen #define _MEMBLK_H
888bfa979SJoseph Chen 
988bfa979SJoseph Chen enum memblk_id {
1088bfa979SJoseph Chen 	MEMBLK_ID_UNK,
1188bfa979SJoseph Chen 
1288bfa979SJoseph Chen 	/* Preloader */
1388bfa979SJoseph Chen 	MEMBLK_ID_ATF,
1488bfa979SJoseph Chen 	MEMBLK_ID_OPTEE,
1588bfa979SJoseph Chen 	MEMBLK_ID_SHM,
1688bfa979SJoseph Chen 
1788bfa979SJoseph Chen 	/* U-Boot self */
1888bfa979SJoseph Chen 	MEMBLK_ID_UBOOT,
1988bfa979SJoseph Chen 	MEMBLK_ID_STACK,
2088bfa979SJoseph Chen 	MEMBLK_ID_FASTBOOT,
2188bfa979SJoseph Chen 
2288bfa979SJoseph Chen 	/* Image */
2388bfa979SJoseph Chen 	MEMBLK_ID_RAMDISK,
2488bfa979SJoseph Chen 	MEMBLK_ID_FDT,
2588bfa979SJoseph Chen 	MEMBLK_ID_FDT_DTBO,
2688bfa979SJoseph Chen 	MEMBLK_ID_FDT_AOSP,
2788bfa979SJoseph Chen 	MEMBLK_ID_KERNEL,
2888bfa979SJoseph Chen 	MEMBLK_ID_ANDROID,
2988bfa979SJoseph Chen 
3088bfa979SJoseph Chen 	/* Other */
3188bfa979SJoseph Chen 	MEMBLK_ID_BY_NAME,
3288bfa979SJoseph Chen 	MEMBLK_ID_FDT_RESV,
3388bfa979SJoseph Chen 	MEMBLK_ID_DEMO,
3488bfa979SJoseph Chen 	MEMBLK_ID_MAX,
3588bfa979SJoseph Chen };
3688bfa979SJoseph Chen 
3788bfa979SJoseph Chen struct memblk_attr {
3888bfa979SJoseph Chen 	const char *name;
3988bfa979SJoseph Chen 	const char *alias[2];
4088bfa979SJoseph Chen 	u32 flags;
4188bfa979SJoseph Chen };
4288bfa979SJoseph Chen 
4388bfa979SJoseph Chen struct memblock {
4488bfa979SJoseph Chen 	phys_addr_t base;
4588bfa979SJoseph Chen 	phys_size_t size;
4688bfa979SJoseph Chen 	struct memblk_attr attr;
4788bfa979SJoseph Chen 	struct list_head node;
4888bfa979SJoseph Chen };
4988bfa979SJoseph Chen 
5088bfa979SJoseph Chen extern const struct memblk_attr *mem_attr;
5188bfa979SJoseph Chen 
5288bfa979SJoseph Chen #define SIZE_MB(len)		((len) >> 20)
5388bfa979SJoseph Chen #define SIZE_KB(len)		(((len) % (1 << 20)) >> 10)
5488bfa979SJoseph Chen 
5588bfa979SJoseph Chen #define M_ATTR_NONE		0
5688bfa979SJoseph Chen /* Over-Flow-Check for region tail */
5788bfa979SJoseph Chen #define M_ATTR_OFC		(1 << 0)
5888bfa979SJoseph Chen /* Over-Flow-Check for region Head, only for U-Boot stack */
5988bfa979SJoseph Chen #define M_ATTR_HOFC		(1 << 1)
6088bfa979SJoseph Chen /* Memory can be overlap by fdt reserved memory */
6188bfa979SJoseph Chen #define M_ATTR_OVERLAP		(1 << 2)
62*efda1f1dSJoseph Chen /* Just peek, always return success */
63*efda1f1dSJoseph Chen #define M_ATTR_PEEK		(1 << 3)
6488bfa979SJoseph Chen 
6588bfa979SJoseph Chen #endif /* _MEMBLK_H */
66