~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/powerpc/kernel/cpu_specs_book3s_64.h

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0-or-later */
  2 /*
  3  *  Copyright (C) 2001 Ben. Herrenschmidt (benh@kernel.crashing.org)
  4  *
  5  *  Modifications for ppc64:
  6  *      Copyright (C) 2003 Dave Engebretsen <engebret@us.ibm.com>
  7  */
  8 
  9 /* NOTE:
 10  * Unlike ppc32, ppc64 will only call cpu_setup() for the boot CPU, it's
 11  * the responsibility of the appropriate CPU save/restore functions to
 12  * eventually copy these settings over. Those save/restore aren't yet
 13  * part of the cputable though. That has to be fixed for both ppc32
 14  * and ppc64
 15  */
 16 #define COMMON_USER_PPC64       (PPC_FEATURE_32 | PPC_FEATURE_HAS_FPU | \
 17                                  PPC_FEATURE_HAS_MMU | PPC_FEATURE_64)
 18 #define COMMON_USER_POWER4      (COMMON_USER_PPC64 | PPC_FEATURE_POWER4)
 19 #define COMMON_USER_POWER5      (COMMON_USER_PPC64 | PPC_FEATURE_POWER5 |\
 20                                  PPC_FEATURE_SMT | PPC_FEATURE_ICACHE_SNOOP)
 21 #define COMMON_USER_POWER5_PLUS (COMMON_USER_PPC64 | PPC_FEATURE_POWER5_PLUS|\
 22                                  PPC_FEATURE_SMT | PPC_FEATURE_ICACHE_SNOOP)
 23 #define COMMON_USER_POWER6      (COMMON_USER_PPC64 | PPC_FEATURE_ARCH_2_05 |\
 24                                  PPC_FEATURE_SMT | PPC_FEATURE_ICACHE_SNOOP | \
 25                                  PPC_FEATURE_TRUE_LE | \
 26                                  PPC_FEATURE_PSERIES_PERFMON_COMPAT)
 27 #define COMMON_USER_POWER7      (COMMON_USER_PPC64 | PPC_FEATURE_ARCH_2_06 |\
 28                                  PPC_FEATURE_SMT | PPC_FEATURE_ICACHE_SNOOP | \
 29                                  PPC_FEATURE_TRUE_LE | \
 30                                  PPC_FEATURE_PSERIES_PERFMON_COMPAT)
 31 #define COMMON_USER2_POWER7     (PPC_FEATURE2_DSCR)
 32 #define COMMON_USER_POWER8      (COMMON_USER_PPC64 | PPC_FEATURE_ARCH_2_06 |\
 33                                  PPC_FEATURE_SMT | PPC_FEATURE_ICACHE_SNOOP | \
 34                                  PPC_FEATURE_TRUE_LE | \
 35                                  PPC_FEATURE_PSERIES_PERFMON_COMPAT)
 36 #define COMMON_USER2_POWER8     (PPC_FEATURE2_ARCH_2_07 | \
 37                                  PPC_FEATURE2_HTM_COMP | \
 38                                  PPC_FEATURE2_HTM_NOSC_COMP | \
 39                                  PPC_FEATURE2_DSCR | \
 40                                  PPC_FEATURE2_ISEL | PPC_FEATURE2_TAR | \
 41                                  PPC_FEATURE2_VEC_CRYPTO)
 42 #define COMMON_USER_PA6T        (COMMON_USER_PPC64 | PPC_FEATURE_PA6T |\
 43                                  PPC_FEATURE_TRUE_LE | \
 44                                  PPC_FEATURE_HAS_ALTIVEC_COMP)
 45 #define COMMON_USER_POWER9      COMMON_USER_POWER8
 46 #define COMMON_USER2_POWER9     (COMMON_USER2_POWER8 | \
 47                                  PPC_FEATURE2_ARCH_3_00 | \
 48                                  PPC_FEATURE2_HAS_IEEE128 | \
 49                                  PPC_FEATURE2_DARN | \
 50                                  PPC_FEATURE2_SCV)
 51 #define COMMON_USER_POWER10     COMMON_USER_POWER9
 52 #define COMMON_USER2_POWER10    (PPC_FEATURE2_ARCH_3_1 | \
 53                                  PPC_FEATURE2_MMA | \
 54                                  PPC_FEATURE2_ARCH_3_00 | \
 55                                  PPC_FEATURE2_HAS_IEEE128 | \
 56                                  PPC_FEATURE2_DARN | \
 57                                  PPC_FEATURE2_SCV | \
 58                                  PPC_FEATURE2_ARCH_2_07 | \
 59                                  PPC_FEATURE2_DSCR | \
 60                                  PPC_FEATURE2_ISEL | PPC_FEATURE2_TAR | \
 61                                  PPC_FEATURE2_VEC_CRYPTO)
 62 
 63 #define COMMON_USER_POWER11     COMMON_USER_POWER10
 64 #define COMMON_USER2_POWER11    COMMON_USER2_POWER10
 65 
 66 static struct cpu_spec cpu_specs[] __initdata = {
 67         {       /* PPC970 */
 68                 .pvr_mask               = 0xffff0000,
 69                 .pvr_value              = 0x00390000,
 70                 .cpu_name               = "PPC970",
 71                 .cpu_features           = CPU_FTRS_PPC970,
 72                 .cpu_user_features      = COMMON_USER_POWER4 | PPC_FEATURE_HAS_ALTIVEC_COMP,
 73                 .mmu_features           = MMU_FTRS_PPC970,
 74                 .icache_bsize           = 128,
 75                 .dcache_bsize           = 128,
 76                 .num_pmcs               = 8,
 77                 .pmc_type               = PPC_PMC_IBM,
 78                 .cpu_setup              = __setup_cpu_ppc970,
 79                 .cpu_restore            = __restore_cpu_ppc970,
 80                 .platform               = "ppc970",
 81         },
 82         {       /* PPC970FX */
 83                 .pvr_mask               = 0xffff0000,
 84                 .pvr_value              = 0x003c0000,
 85                 .cpu_name               = "PPC970FX",
 86                 .cpu_features           = CPU_FTRS_PPC970,
 87                 .cpu_user_features      = COMMON_USER_POWER4 | PPC_FEATURE_HAS_ALTIVEC_COMP,
 88                 .mmu_features           = MMU_FTRS_PPC970,
 89                 .icache_bsize           = 128,
 90                 .dcache_bsize           = 128,
 91                 .num_pmcs               = 8,
 92                 .pmc_type               = PPC_PMC_IBM,
 93                 .cpu_setup              = __setup_cpu_ppc970,
 94                 .cpu_restore            = __restore_cpu_ppc970,
 95                 .platform               = "ppc970",
 96         },
 97         {       /* PPC970MP DD1.0 - no DEEPNAP, use regular 970 init */
 98                 .pvr_mask               = 0xffffffff,
 99                 .pvr_value              = 0x00440100,
100                 .cpu_name               = "PPC970MP",
101                 .cpu_features           = CPU_FTRS_PPC970,
102                 .cpu_user_features      = COMMON_USER_POWER4 | PPC_FEATURE_HAS_ALTIVEC_COMP,
103                 .mmu_features           = MMU_FTRS_PPC970,
104                 .icache_bsize           = 128,
105                 .dcache_bsize           = 128,
106                 .num_pmcs               = 8,
107                 .pmc_type               = PPC_PMC_IBM,
108                 .cpu_setup              = __setup_cpu_ppc970,
109                 .cpu_restore            = __restore_cpu_ppc970,
110                 .platform               = "ppc970",
111         },
112         {       /* PPC970MP */
113                 .pvr_mask               = 0xffff0000,
114                 .pvr_value              = 0x00440000,
115                 .cpu_name               = "PPC970MP",
116                 .cpu_features           = CPU_FTRS_PPC970,
117                 .cpu_user_features      = COMMON_USER_POWER4 | PPC_FEATURE_HAS_ALTIVEC_COMP,
118                 .mmu_features           = MMU_FTRS_PPC970,
119                 .icache_bsize           = 128,
120                 .dcache_bsize           = 128,
121                 .num_pmcs               = 8,
122                 .pmc_type               = PPC_PMC_IBM,
123                 .cpu_setup              = __setup_cpu_ppc970MP,
124                 .cpu_restore            = __restore_cpu_ppc970,
125                 .platform               = "ppc970",
126         },
127         {       /* PPC970GX */
128                 .pvr_mask               = 0xffff0000,
129                 .pvr_value              = 0x00450000,
130                 .cpu_name               = "PPC970GX",
131                 .cpu_features           = CPU_FTRS_PPC970,
132                 .cpu_user_features      = COMMON_USER_POWER4 | PPC_FEATURE_HAS_ALTIVEC_COMP,
133                 .mmu_features           = MMU_FTRS_PPC970,
134                 .icache_bsize           = 128,
135                 .dcache_bsize           = 128,
136                 .num_pmcs               = 8,
137                 .pmc_type               = PPC_PMC_IBM,
138                 .cpu_setup              = __setup_cpu_ppc970,
139                 .platform               = "ppc970",
140         },
141         {       /* Power5 GR */
142                 .pvr_mask               = 0xffff0000,
143                 .pvr_value              = 0x003a0000,
144                 .cpu_name               = "POWER5 (gr)",
145                 .cpu_features           = CPU_FTRS_POWER5,
146                 .cpu_user_features      = COMMON_USER_POWER5,
147                 .mmu_features           = MMU_FTRS_POWER5,
148                 .icache_bsize           = 128,
149                 .dcache_bsize           = 128,
150                 .num_pmcs               = 6,
151                 .pmc_type               = PPC_PMC_IBM,
152                 .platform               = "power5",
153         },
154         {       /* Power5++ */
155                 .pvr_mask               = 0xffffff00,
156                 .pvr_value              = 0x003b0300,
157                 .cpu_name               = "POWER5+ (gs)",
158                 .cpu_features           = CPU_FTRS_POWER5,
159                 .cpu_user_features      = COMMON_USER_POWER5_PLUS,
160                 .mmu_features           = MMU_FTRS_POWER5,
161                 .icache_bsize           = 128,
162                 .dcache_bsize           = 128,
163                 .num_pmcs               = 6,
164                 .platform               = "power5+",
165         },
166         {       /* Power5 GS */
167                 .pvr_mask               = 0xffff0000,
168                 .pvr_value              = 0x003b0000,
169                 .cpu_name               = "POWER5+ (gs)",
170                 .cpu_features           = CPU_FTRS_POWER5,
171                 .cpu_user_features      = COMMON_USER_POWER5_PLUS,
172                 .mmu_features           = MMU_FTRS_POWER5,
173                 .icache_bsize           = 128,
174                 .dcache_bsize           = 128,
175                 .num_pmcs               = 6,
176                 .pmc_type               = PPC_PMC_IBM,
177                 .platform               = "power5+",
178         },
179         {       /* POWER6 in P5+ mode; 2.04-compliant processor */
180                 .pvr_mask               = 0xffffffff,
181                 .pvr_value              = 0x0f000001,
182                 .cpu_name               = "POWER5+",
183                 .cpu_features           = CPU_FTRS_POWER5,
184                 .cpu_user_features      = COMMON_USER_POWER5_PLUS,
185                 .mmu_features           = MMU_FTRS_POWER5,
186                 .icache_bsize           = 128,
187                 .dcache_bsize           = 128,
188                 .platform               = "power5+",
189         },
190         {       /* Power6 */
191                 .pvr_mask               = 0xffff0000,
192                 .pvr_value              = 0x003e0000,
193                 .cpu_name               = "POWER6 (raw)",
194                 .cpu_features           = CPU_FTRS_POWER6,
195                 .cpu_user_features      = COMMON_USER_POWER6 | PPC_FEATURE_POWER6_EXT,
196                 .mmu_features           = MMU_FTRS_POWER6,
197                 .icache_bsize           = 128,
198                 .dcache_bsize           = 128,
199                 .num_pmcs               = 6,
200                 .pmc_type               = PPC_PMC_IBM,
201                 .platform               = "power6x",
202         },
203         {       /* 2.05-compliant processor, i.e. Power6 "architected" mode */
204                 .pvr_mask               = 0xffffffff,
205                 .pvr_value              = 0x0f000002,
206                 .cpu_name               = "POWER6 (architected)",
207                 .cpu_features           = CPU_FTRS_POWER6,
208                 .cpu_user_features      = COMMON_USER_POWER6,
209                 .mmu_features           = MMU_FTRS_POWER6,
210                 .icache_bsize           = 128,
211                 .dcache_bsize           = 128,
212                 .platform               = "power6",
213         },
214         {       /* 2.06-compliant processor, i.e. Power7 "architected" mode */
215                 .pvr_mask               = 0xffffffff,
216                 .pvr_value              = 0x0f000003,
217                 .cpu_name               = "POWER7 (architected)",
218                 .cpu_features           = CPU_FTRS_POWER7,
219                 .cpu_user_features      = COMMON_USER_POWER7,
220                 .cpu_user_features2     = COMMON_USER2_POWER7,
221                 .mmu_features           = MMU_FTRS_POWER7,
222                 .icache_bsize           = 128,
223                 .dcache_bsize           = 128,
224                 .cpu_setup              = __setup_cpu_power7,
225                 .cpu_restore            = __restore_cpu_power7,
226                 .machine_check_early    = __machine_check_early_realmode_p7,
227                 .platform               = "power7",
228         },
229         {       /* 2.07-compliant processor, i.e. Power8 "architected" mode */
230                 .pvr_mask               = 0xffffffff,
231                 .pvr_value              = 0x0f000004,
232                 .cpu_name               = "POWER8 (architected)",
233                 .cpu_features           = CPU_FTRS_POWER8,
234                 .cpu_user_features      = COMMON_USER_POWER8,
235                 .cpu_user_features2     = COMMON_USER2_POWER8,
236                 .mmu_features           = MMU_FTRS_POWER8,
237                 .icache_bsize           = 128,
238                 .dcache_bsize           = 128,
239                 .cpu_setup              = __setup_cpu_power8,
240                 .cpu_restore            = __restore_cpu_power8,
241                 .machine_check_early    = __machine_check_early_realmode_p8,
242                 .platform               = "power8",
243         },
244         {       /* 2.07-compliant processor, HeXin C2000 processor */
245                 .pvr_mask               = 0xffff0000,
246                 .pvr_value              = 0x00660000,
247                 .cpu_name               = "HX-C2000",
248                 .cpu_features           = CPU_FTRS_POWER8,
249                 .cpu_user_features      = COMMON_USER_POWER8,
250                 .cpu_user_features2     = COMMON_USER2_POWER8,
251                 .mmu_features           = MMU_FTRS_POWER8,
252                 .icache_bsize           = 128,
253                 .dcache_bsize           = 128,
254                 .cpu_setup              = __setup_cpu_power8,
255                 .cpu_restore            = __restore_cpu_power8,
256                 .machine_check_early    = __machine_check_early_realmode_p8,
257                 .platform               = "power8",
258         },
259         {       /* 3.00-compliant processor, i.e. Power9 "architected" mode */
260                 .pvr_mask               = 0xffffffff,
261                 .pvr_value              = 0x0f000005,
262                 .cpu_name               = "POWER9 (architected)",
263                 .cpu_features           = CPU_FTRS_POWER9,
264                 .cpu_user_features      = COMMON_USER_POWER9,
265                 .cpu_user_features2     = COMMON_USER2_POWER9,
266                 .mmu_features           = MMU_FTRS_POWER9,
267                 .icache_bsize           = 128,
268                 .dcache_bsize           = 128,
269                 .cpu_setup              = __setup_cpu_power9,
270                 .cpu_restore            = __restore_cpu_power9,
271                 .platform               = "power9",
272         },
273         {       /* 3.1-compliant processor, i.e. Power10 "architected" mode */
274                 .pvr_mask               = 0xffffffff,
275                 .pvr_value              = 0x0f000006,
276                 .cpu_name               = "POWER10 (architected)",
277                 .cpu_features           = CPU_FTRS_POWER10,
278                 .cpu_user_features      = COMMON_USER_POWER10,
279                 .cpu_user_features2     = COMMON_USER2_POWER10,
280                 .mmu_features           = MMU_FTRS_POWER10,
281                 .icache_bsize           = 128,
282                 .dcache_bsize           = 128,
283                 .cpu_setup              = __setup_cpu_power10,
284                 .cpu_restore            = __restore_cpu_power10,
285                 .platform               = "power10",
286         },
287         {       /* 3.1-compliant processor, i.e. Power11 "architected" mode */
288                 .pvr_mask               = 0xffffffff,
289                 .pvr_value              = 0x0f000007,
290                 .cpu_name               = "Power11 (architected)",
291                 .cpu_features           = CPU_FTRS_POWER11,
292                 .cpu_user_features      = COMMON_USER_POWER11,
293                 .cpu_user_features2     = COMMON_USER2_POWER11,
294                 .mmu_features           = MMU_FTRS_POWER11,
295                 .icache_bsize           = 128,
296                 .dcache_bsize           = 128,
297                 .cpu_setup              = __setup_cpu_power10,
298                 .cpu_restore            = __restore_cpu_power10,
299                 .platform               = "power11",
300         },
301         {       /* Power7 */
302                 .pvr_mask               = 0xffff0000,
303                 .pvr_value              = 0x003f0000,
304                 .cpu_name               = "POWER7 (raw)",
305                 .cpu_features           = CPU_FTRS_POWER7,
306                 .cpu_user_features      = COMMON_USER_POWER7,
307                 .cpu_user_features2     = COMMON_USER2_POWER7,
308                 .mmu_features           = MMU_FTRS_POWER7,
309                 .icache_bsize           = 128,
310                 .dcache_bsize           = 128,
311                 .num_pmcs               = 6,
312                 .pmc_type               = PPC_PMC_IBM,
313                 .cpu_setup              = __setup_cpu_power7,
314                 .cpu_restore            = __restore_cpu_power7,
315                 .machine_check_early    = __machine_check_early_realmode_p7,
316                 .platform               = "power7",
317         },
318         {       /* Power7+ */
319                 .pvr_mask               = 0xffff0000,
320                 .pvr_value              = 0x004A0000,
321                 .cpu_name               = "POWER7+ (raw)",
322                 .cpu_features           = CPU_FTRS_POWER7,
323                 .cpu_user_features      = COMMON_USER_POWER7,
324                 .cpu_user_features2     = COMMON_USER2_POWER7,
325                 .mmu_features           = MMU_FTRS_POWER7,
326                 .icache_bsize           = 128,
327                 .dcache_bsize           = 128,
328                 .num_pmcs               = 6,
329                 .pmc_type               = PPC_PMC_IBM,
330                 .cpu_setup              = __setup_cpu_power7,
331                 .cpu_restore            = __restore_cpu_power7,
332                 .machine_check_early    = __machine_check_early_realmode_p7,
333                 .platform               = "power7+",
334         },
335         {       /* Power8E */
336                 .pvr_mask               = 0xffff0000,
337                 .pvr_value              = 0x004b0000,
338                 .cpu_name               = "POWER8E (raw)",
339                 .cpu_features           = CPU_FTRS_POWER8E,
340                 .cpu_user_features      = COMMON_USER_POWER8,
341                 .cpu_user_features2     = COMMON_USER2_POWER8,
342                 .mmu_features           = MMU_FTRS_POWER8,
343                 .icache_bsize           = 128,
344                 .dcache_bsize           = 128,
345                 .num_pmcs               = 6,
346                 .pmc_type               = PPC_PMC_IBM,
347                 .cpu_setup              = __setup_cpu_power8,
348                 .cpu_restore            = __restore_cpu_power8,
349                 .machine_check_early    = __machine_check_early_realmode_p8,
350                 .platform               = "power8",
351         },
352         {       /* Power8NVL */
353                 .pvr_mask               = 0xffff0000,
354                 .pvr_value              = 0x004c0000,
355                 .cpu_name               = "POWER8NVL (raw)",
356                 .cpu_features           = CPU_FTRS_POWER8,
357                 .cpu_user_features      = COMMON_USER_POWER8,
358                 .cpu_user_features2     = COMMON_USER2_POWER8,
359                 .mmu_features           = MMU_FTRS_POWER8,
360                 .icache_bsize           = 128,
361                 .dcache_bsize           = 128,
362                 .num_pmcs               = 6,
363                 .pmc_type               = PPC_PMC_IBM,
364                 .cpu_setup              = __setup_cpu_power8,
365                 .cpu_restore            = __restore_cpu_power8,
366                 .machine_check_early    = __machine_check_early_realmode_p8,
367                 .platform               = "power8",
368         },
369         {       /* Power8 */
370                 .pvr_mask               = 0xffff0000,
371                 .pvr_value              = 0x004d0000,
372                 .cpu_name               = "POWER8 (raw)",
373                 .cpu_features           = CPU_FTRS_POWER8,
374                 .cpu_user_features      = COMMON_USER_POWER8,
375                 .cpu_user_features2     = COMMON_USER2_POWER8,
376                 .mmu_features           = MMU_FTRS_POWER8,
377                 .icache_bsize           = 128,
378                 .dcache_bsize           = 128,
379                 .num_pmcs               = 6,
380                 .pmc_type               = PPC_PMC_IBM,
381                 .cpu_setup              = __setup_cpu_power8,
382                 .cpu_restore            = __restore_cpu_power8,
383                 .machine_check_early    = __machine_check_early_realmode_p8,
384                 .platform               = "power8",
385         },
386         {       /* Power9 DD2.0 */
387                 .pvr_mask               = 0xffffefff,
388                 .pvr_value              = 0x004e0200,
389                 .cpu_name               = "POWER9 (raw)",
390                 .cpu_features           = CPU_FTRS_POWER9_DD2_0,
391                 .cpu_user_features      = COMMON_USER_POWER9,
392                 .cpu_user_features2     = COMMON_USER2_POWER9,
393                 .mmu_features           = MMU_FTRS_POWER9,
394                 .icache_bsize           = 128,
395                 .dcache_bsize           = 128,
396                 .num_pmcs               = 6,
397                 .pmc_type               = PPC_PMC_IBM,
398                 .cpu_setup              = __setup_cpu_power9,
399                 .cpu_restore            = __restore_cpu_power9,
400                 .machine_check_early    = __machine_check_early_realmode_p9,
401                 .platform               = "power9",
402         },
403         {       /* Power9 DD 2.1 */
404                 .pvr_mask               = 0xffffefff,
405                 .pvr_value              = 0x004e0201,
406                 .cpu_name               = "POWER9 (raw)",
407                 .cpu_features           = CPU_FTRS_POWER9_DD2_1,
408                 .cpu_user_features      = COMMON_USER_POWER9,
409                 .cpu_user_features2     = COMMON_USER2_POWER9,
410                 .mmu_features           = MMU_FTRS_POWER9,
411                 .icache_bsize           = 128,
412                 .dcache_bsize           = 128,
413                 .num_pmcs               = 6,
414                 .pmc_type               = PPC_PMC_IBM,
415                 .cpu_setup              = __setup_cpu_power9,
416                 .cpu_restore            = __restore_cpu_power9,
417                 .machine_check_early    = __machine_check_early_realmode_p9,
418                 .platform               = "power9",
419         },
420         {       /* Power9 DD2.2 */
421                 .pvr_mask               = 0xffffefff,
422                 .pvr_value              = 0x004e0202,
423                 .cpu_name               = "POWER9 (raw)",
424                 .cpu_features           = CPU_FTRS_POWER9_DD2_2,
425                 .cpu_user_features      = COMMON_USER_POWER9,
426                 .cpu_user_features2     = COMMON_USER2_POWER9,
427                 .mmu_features           = MMU_FTRS_POWER9,
428                 .icache_bsize           = 128,
429                 .dcache_bsize           = 128,
430                 .num_pmcs               = 6,
431                 .pmc_type               = PPC_PMC_IBM,
432                 .cpu_setup              = __setup_cpu_power9,
433                 .cpu_restore            = __restore_cpu_power9,
434                 .machine_check_early    = __machine_check_early_realmode_p9,
435                 .platform               = "power9",
436         },
437         {       /* Power9 DD2.3 or later */
438                 .pvr_mask               = 0xffff0000,
439                 .pvr_value              = 0x004e0000,
440                 .cpu_name               = "POWER9 (raw)",
441                 .cpu_features           = CPU_FTRS_POWER9_DD2_3,
442                 .cpu_user_features      = COMMON_USER_POWER9,
443                 .cpu_user_features2     = COMMON_USER2_POWER9,
444                 .mmu_features           = MMU_FTRS_POWER9,
445                 .icache_bsize           = 128,
446                 .dcache_bsize           = 128,
447                 .num_pmcs               = 6,
448                 .pmc_type               = PPC_PMC_IBM,
449                 .cpu_setup              = __setup_cpu_power9,
450                 .cpu_restore            = __restore_cpu_power9,
451                 .machine_check_early    = __machine_check_early_realmode_p9,
452                 .platform               = "power9",
453         },
454         {       /* Power10 */
455                 .pvr_mask               = 0xffff0000,
456                 .pvr_value              = 0x00800000,
457                 .cpu_name               = "POWER10 (raw)",
458                 .cpu_features           = CPU_FTRS_POWER10,
459                 .cpu_user_features      = COMMON_USER_POWER10,
460                 .cpu_user_features2     = COMMON_USER2_POWER10,
461                 .mmu_features           = MMU_FTRS_POWER10,
462                 .icache_bsize           = 128,
463                 .dcache_bsize           = 128,
464                 .num_pmcs               = 6,
465                 .pmc_type               = PPC_PMC_IBM,
466                 .cpu_setup              = __setup_cpu_power10,
467                 .cpu_restore            = __restore_cpu_power10,
468                 .machine_check_early    = __machine_check_early_realmode_p10,
469                 .platform               = "power10",
470         },
471         {       /* Power11 */
472                 .pvr_mask               = 0xffff0000,
473                 .pvr_value              = 0x00820000,
474                 .cpu_name               = "Power11 (raw)",
475                 .cpu_features           = CPU_FTRS_POWER11,
476                 .cpu_user_features      = COMMON_USER_POWER11,
477                 .cpu_user_features2     = COMMON_USER2_POWER11,
478                 .mmu_features           = MMU_FTRS_POWER11,
479                 .icache_bsize           = 128,
480                 .dcache_bsize           = 128,
481                 .num_pmcs               = 6,
482                 .pmc_type               = PPC_PMC_IBM,
483                 .cpu_setup              = __setup_cpu_power10,
484                 .cpu_restore            = __restore_cpu_power10,
485                 .machine_check_early    = __machine_check_early_realmode_p10,
486                 .platform               = "power11",
487         },
488         {       /* Cell Broadband Engine */
489                 .pvr_mask               = 0xffff0000,
490                 .pvr_value              = 0x00700000,
491                 .cpu_name               = "Cell Broadband Engine",
492                 .cpu_features           = CPU_FTRS_CELL,
493                 .cpu_user_features      = COMMON_USER_PPC64 | PPC_FEATURE_CELL |
494                                           PPC_FEATURE_HAS_ALTIVEC_COMP | PPC_FEATURE_SMT,
495                 .mmu_features           = MMU_FTRS_CELL,
496                 .icache_bsize           = 128,
497                 .dcache_bsize           = 128,
498                 .num_pmcs               = 4,
499                 .pmc_type               = PPC_PMC_IBM,
500                 .platform               = "ppc-cell-be",
501         },
502         {       /* PA Semi PA6T */
503                 .pvr_mask               = 0x7fff0000,
504                 .pvr_value              = 0x00900000,
505                 .cpu_name               = "PA6T",
506                 .cpu_features           = CPU_FTRS_PA6T,
507                 .cpu_user_features      = COMMON_USER_PA6T,
508                 .mmu_features           = MMU_FTRS_PA6T,
509                 .icache_bsize           = 64,
510                 .dcache_bsize           = 64,
511                 .num_pmcs               = 6,
512                 .pmc_type               = PPC_PMC_PA6T,
513                 .cpu_setup              = __setup_cpu_pa6t,
514                 .cpu_restore            = __restore_cpu_pa6t,
515                 .platform               = "pa6t",
516         },
517         {       /* default match */
518                 .pvr_mask               = 0x00000000,
519                 .pvr_value              = 0x00000000,
520                 .cpu_name               = "POWER5 (compatible)",
521                 .cpu_features           = CPU_FTRS_COMPATIBLE,
522                 .cpu_user_features      = COMMON_USER_PPC64,
523                 .mmu_features           = MMU_FTRS_POWER,
524                 .icache_bsize           = 128,
525                 .dcache_bsize           = 128,
526                 .num_pmcs               = 6,
527                 .pmc_type               = PPC_PMC_IBM,
528                 .platform               = "power5",
529         }
530 };
531 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php