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