xref: /openbmc/linux/arch/x86/include/asm/imr.h (revision 75bf465f0bc33e9b776a46d6a1b9b990f5fb7c37)
1*b886d83cSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
228a375dfSBryan O'Donoghue /*
328a375dfSBryan O'Donoghue  * imr.h: Isolated Memory Region API
428a375dfSBryan O'Donoghue  *
528a375dfSBryan O'Donoghue  * Copyright(c) 2013 Intel Corporation.
628a375dfSBryan O'Donoghue  * Copyright(c) 2015 Bryan O'Donoghue <pure.logic@nexus-software.ie>
728a375dfSBryan O'Donoghue  */
828a375dfSBryan O'Donoghue #ifndef _IMR_H
928a375dfSBryan O'Donoghue #define _IMR_H
1028a375dfSBryan O'Donoghue 
1128a375dfSBryan O'Donoghue #include <linux/types.h>
1228a375dfSBryan O'Donoghue 
1328a375dfSBryan O'Donoghue /*
1428a375dfSBryan O'Donoghue  * IMR agent access mask bits
1528a375dfSBryan O'Donoghue  * See section 12.7.4.7 from quark-x1000-datasheet.pdf for register
1628a375dfSBryan O'Donoghue  * definitions.
1728a375dfSBryan O'Donoghue  */
1828a375dfSBryan O'Donoghue #define IMR_ESRAM_FLUSH		BIT(31)
1928a375dfSBryan O'Donoghue #define IMR_CPU_SNOOP		BIT(30)		/* Applicable only to write */
2028a375dfSBryan O'Donoghue #define IMR_RMU			BIT(29)
2128a375dfSBryan O'Donoghue #define IMR_VC1_SAI_ID3		BIT(15)
2228a375dfSBryan O'Donoghue #define IMR_VC1_SAI_ID2		BIT(14)
2328a375dfSBryan O'Donoghue #define IMR_VC1_SAI_ID1		BIT(13)
2428a375dfSBryan O'Donoghue #define IMR_VC1_SAI_ID0		BIT(12)
2528a375dfSBryan O'Donoghue #define IMR_VC0_SAI_ID3		BIT(11)
2628a375dfSBryan O'Donoghue #define IMR_VC0_SAI_ID2		BIT(10)
2728a375dfSBryan O'Donoghue #define IMR_VC0_SAI_ID1		BIT(9)
2828a375dfSBryan O'Donoghue #define IMR_VC0_SAI_ID0		BIT(8)
2928a375dfSBryan O'Donoghue #define IMR_CPU_0		BIT(1)		/* SMM mode */
3028a375dfSBryan O'Donoghue #define IMR_CPU			BIT(0)		/* Non SMM mode */
3128a375dfSBryan O'Donoghue #define IMR_ACCESS_NONE		0
3228a375dfSBryan O'Donoghue 
3328a375dfSBryan O'Donoghue /*
3428a375dfSBryan O'Donoghue  * Read/Write access-all bits here include some reserved bits
3528a375dfSBryan O'Donoghue  * These are the values firmware uses and are accepted by hardware.
3628a375dfSBryan O'Donoghue  * The kernel defines read/write access-all in the same way as firmware
3728a375dfSBryan O'Donoghue  * in order to have a consistent and crisp definition across firmware,
3828a375dfSBryan O'Donoghue  * bootloader and kernel.
3928a375dfSBryan O'Donoghue  */
4028a375dfSBryan O'Donoghue #define IMR_READ_ACCESS_ALL	0xBFFFFFFF
4128a375dfSBryan O'Donoghue #define IMR_WRITE_ACCESS_ALL	0xFFFFFFFF
4228a375dfSBryan O'Donoghue 
4328a375dfSBryan O'Donoghue /* Number of IMRs provided by Quark X1000 SoC */
4428a375dfSBryan O'Donoghue #define QUARK_X1000_IMR_MAX	0x08
4528a375dfSBryan O'Donoghue #define QUARK_X1000_IMR_REGBASE 0x40
4628a375dfSBryan O'Donoghue 
4728a375dfSBryan O'Donoghue /* IMR alignment bits - only bits 31:10 are checked for IMR validity */
4828a375dfSBryan O'Donoghue #define IMR_ALIGN		0x400
4928a375dfSBryan O'Donoghue #define IMR_MASK		(IMR_ALIGN - 1)
5028a375dfSBryan O'Donoghue 
5128a375dfSBryan O'Donoghue int imr_add_range(phys_addr_t base, size_t size,
52c637fa52SBryan O'Donoghue 		  unsigned int rmask, unsigned int wmask);
5328a375dfSBryan O'Donoghue 
5428a375dfSBryan O'Donoghue int imr_remove_range(phys_addr_t base, size_t size);
5528a375dfSBryan O'Donoghue 
5628a375dfSBryan O'Donoghue #endif /* _IMR_H */
57