Back to home page

OSCL-LXR

 
 

    


0001 /* SPDX-License-Identifier: GPL-2.0-only */
0002 /*
0003  * Copyright (C) 2015 Atmel
0004  *
0005  * Boris Brezillon <boris.brezillon@free-electrons.com
0006  */
0007 
0008 #ifndef __AT91_SOC_H
0009 #define __AT91_SOC_H
0010 
0011 #include <linux/sys_soc.h>
0012 
0013 struct at91_soc {
0014     u32 cidr_match;
0015     u32 cidr_mask;
0016     u32 version_mask;
0017     u32 exid_match;
0018     const char *name;
0019     const char *family;
0020 };
0021 
0022 #define AT91_SOC(__cidr, __cidr_mask, __version_mask, __exid,   \
0023          __name, __family)              \
0024     {                           \
0025         .cidr_match = (__cidr),             \
0026         .cidr_mask = (__cidr_mask),         \
0027         .version_mask = (__version_mask),       \
0028         .exid_match = (__exid),             \
0029         .name = (__name),               \
0030         .family = (__family),               \
0031     }
0032 
0033 struct soc_device * __init
0034 at91_soc_init(const struct at91_soc *socs);
0035 
0036 #define AT91RM9200_CIDR_MATCH       0x09290780
0037 
0038 #define AT91SAM9260_CIDR_MATCH      0x019803a0
0039 #define AT91SAM9261_CIDR_MATCH      0x019703a0
0040 #define AT91SAM9263_CIDR_MATCH      0x019607a0
0041 #define AT91SAM9G20_CIDR_MATCH      0x019905a0
0042 #define AT91SAM9RL64_CIDR_MATCH     0x019b03a0
0043 #define AT91SAM9G45_CIDR_MATCH      0x019b05a0
0044 #define AT91SAM9X5_CIDR_MATCH       0x019a05a0
0045 #define AT91SAM9N12_CIDR_MATCH      0x019a07a0
0046 #define SAM9X60_CIDR_MATCH      0x019b35a0
0047 #define SAMA7G5_CIDR_MATCH      0x00162100
0048 
0049 #define AT91SAM9M11_EXID_MATCH      0x00000001
0050 #define AT91SAM9M10_EXID_MATCH      0x00000002
0051 #define AT91SAM9G46_EXID_MATCH      0x00000003
0052 #define AT91SAM9G45_EXID_MATCH      0x00000004
0053 
0054 #define AT91SAM9G15_EXID_MATCH      0x00000000
0055 #define AT91SAM9G35_EXID_MATCH      0x00000001
0056 #define AT91SAM9X35_EXID_MATCH      0x00000002
0057 #define AT91SAM9G25_EXID_MATCH      0x00000003
0058 #define AT91SAM9X25_EXID_MATCH      0x00000004
0059 
0060 #define AT91SAM9CN12_EXID_MATCH     0x00000005
0061 #define AT91SAM9N12_EXID_MATCH      0x00000006
0062 #define AT91SAM9CN11_EXID_MATCH     0x00000009
0063 
0064 #define SAM9X60_EXID_MATCH      0x00000000
0065 #define SAM9X60_D5M_EXID_MATCH      0x00000001
0066 #define SAM9X60_D1G_EXID_MATCH      0x00000010
0067 #define SAM9X60_D6K_EXID_MATCH      0x00000011
0068 
0069 #define SAMA7G51_EXID_MATCH     0x3
0070 #define SAMA7G52_EXID_MATCH     0x2
0071 #define SAMA7G53_EXID_MATCH     0x1
0072 #define SAMA7G54_EXID_MATCH     0x0
0073 
0074 #define AT91SAM9XE128_CIDR_MATCH    0x329973a0
0075 #define AT91SAM9XE256_CIDR_MATCH    0x329a93a0
0076 #define AT91SAM9XE512_CIDR_MATCH    0x329aa3a0
0077 
0078 #define SAMA5D2_CIDR_MATCH      0x0a5c08c0
0079 #define SAMA5D21CU_EXID_MATCH       0x0000005a
0080 #define SAMA5D225C_D1M_EXID_MATCH   0x00000053
0081 #define SAMA5D22CU_EXID_MATCH       0x00000059
0082 #define SAMA5D22CN_EXID_MATCH       0x00000069
0083 #define SAMA5D23CU_EXID_MATCH       0x00000058
0084 #define SAMA5D24CX_EXID_MATCH       0x00000004
0085 #define SAMA5D24CU_EXID_MATCH       0x00000014
0086 #define SAMA5D26CU_EXID_MATCH       0x00000012
0087 #define SAMA5D27C_D1G_EXID_MATCH    0x00000033
0088 #define SAMA5D27C_D5M_EXID_MATCH    0x00000032
0089 #define SAMA5D27C_LD1G_EXID_MATCH   0x00000061
0090 #define SAMA5D27C_LD2G_EXID_MATCH   0x00000062
0091 #define SAMA5D27CU_EXID_MATCH       0x00000011
0092 #define SAMA5D27CN_EXID_MATCH       0x00000021
0093 #define SAMA5D28C_D1G_EXID_MATCH    0x00000013
0094 #define SAMA5D28C_LD1G_EXID_MATCH   0x00000071
0095 #define SAMA5D28C_LD2G_EXID_MATCH   0x00000072
0096 #define SAMA5D28CU_EXID_MATCH       0x00000010
0097 #define SAMA5D28CN_EXID_MATCH       0x00000020
0098 #define SAMA5D29CN_EXID_MATCH       0x00000023
0099 
0100 #define SAMA5D3_CIDR_MATCH      0x0a5c07c0
0101 #define SAMA5D31_EXID_MATCH     0x00444300
0102 #define SAMA5D33_EXID_MATCH     0x00414300
0103 #define SAMA5D34_EXID_MATCH     0x00414301
0104 #define SAMA5D35_EXID_MATCH     0x00584300
0105 #define SAMA5D36_EXID_MATCH     0x00004301
0106 
0107 #define SAMA5D4_CIDR_MATCH      0x0a5c07c0
0108 #define SAMA5D41_EXID_MATCH     0x00000001
0109 #define SAMA5D42_EXID_MATCH     0x00000002
0110 #define SAMA5D43_EXID_MATCH     0x00000003
0111 #define SAMA5D44_EXID_MATCH     0x00000004
0112 
0113 #define SAME70Q21_CIDR_MATCH        0x21020e00
0114 #define SAME70Q21_EXID_MATCH        0x00000002
0115 #define SAME70Q20_CIDR_MATCH        0x21020c00
0116 #define SAME70Q20_EXID_MATCH        0x00000002
0117 #define SAME70Q19_CIDR_MATCH        0x210d0a00
0118 #define SAME70Q19_EXID_MATCH        0x00000002
0119 
0120 #define SAMS70Q21_CIDR_MATCH        0x21120e00
0121 #define SAMS70Q21_EXID_MATCH        0x00000002
0122 #define SAMS70Q20_CIDR_MATCH        0x21120c00
0123 #define SAMS70Q20_EXID_MATCH        0x00000002
0124 #define SAMS70Q19_CIDR_MATCH        0x211d0a00
0125 #define SAMS70Q19_EXID_MATCH        0x00000002
0126 
0127 #define SAMV71Q21_CIDR_MATCH        0x21220e00
0128 #define SAMV71Q21_EXID_MATCH        0x00000002
0129 #define SAMV71Q20_CIDR_MATCH        0x21220c00
0130 #define SAMV71Q20_EXID_MATCH        0x00000002
0131 #define SAMV71Q19_CIDR_MATCH        0x212d0a00
0132 #define SAMV71Q19_EXID_MATCH        0x00000002
0133 
0134 #define SAMV70Q20_CIDR_MATCH        0x21320c00
0135 #define SAMV70Q20_EXID_MATCH        0x00000002
0136 #define SAMV70Q19_CIDR_MATCH        0x213d0a00
0137 #define SAMV70Q19_EXID_MATCH        0x00000002
0138 
0139 #endif /* __AT91_SOC_H */