On Mon, 2013-04-22 at 13:35 -0500, Nathan Fontenot wrote:
> As part of handling handling PRRN events we will need to check the
> vector 5 portion of the architecture bits reported in the device tree
> to ensure that PRRN event handling is enabled. In order to do this
> firmware_has_feature is updated (in a subsequent patch) to
> make this check.  To avoid having to re-define bits in the architecture
> vector the bits are moved to prom.h.
> 
> This patch is the first step in updating firmware_has_feature
> by simply moving the bit definitions from prom_init.c to asm/prom.h.
> There are no functional changes.
> 
> Signed-off-by: Nathan Fontenot <nf...@linux.vnet.ibm.com>
> 
> ---
>  arch/powerpc/include/asm/prom.h |   73 ++++++++++++++++++++++++++++++++++++++
>  arch/powerpc/kernel/prom_init.c |   75 
> +++-------------------------------------
>  2 files changed, 79 insertions(+), 69 deletions(-)
> 
> Index: powerpc/arch/powerpc/include/asm/prom.h
> ===================================================================
> --- powerpc.orig/arch/powerpc/include/asm/prom.h      2013-04-16 
> 21:25:16.000000000 -0500
> +++ powerpc/arch/powerpc/include/asm/prom.h   2013-04-17 13:43:13.000000000 
> -0500
> @@ -74,6 +74,79 @@
>  #define DRCONF_MEM_AI_INVALID        0x00000040
>  #define DRCONF_MEM_RESERVED  0x00000080
>  
> +#if defined(CONFIG_PPC_PSERIES) || defined(CONFIG_PPC_POWERNV)
> +/

The ifdef is unnecessary

> + * There are two methods for telling firmware what our capabilities are.
> + * Newer machines have an "ibm,client-architecture-support" method on the
> + * root node.  For older machines, we have to call the "process-elf-header"
> + * method in the /packages/elf-loader node, passing it a fake 32-bit
> + * ELF header containing a couple of PT_NOTE sections that contain
> + * structures that contain various information.
> + */
> +
> +/* New method - extensible architecture description vector. */
> +
> +/* Option vector bits - generic bits in byte 1 */
> +#define OV_IGNORE            0x80    /* ignore this vector */
> +#define OV_CESSATION_POLICY  0x40    /* halt if unsupported option present*/
> +
> +/* Option vector 1: processor architectures supported */
> +#define OV1_PPC_2_00         0x80    /* set if we support PowerPC 2.00 */
> +#define OV1_PPC_2_01         0x40    /* set if we support PowerPC 2.01 */
> +#define OV1_PPC_2_02         0x20    /* set if we support PowerPC 2.02 */
> +#define OV1_PPC_2_03         0x10    /* set if we support PowerPC 2.03 */
> +#define OV1_PPC_2_04         0x08    /* set if we support PowerPC 2.04 */
> +#define OV1_PPC_2_05         0x04    /* set if we support PowerPC 2.05 */
> +#define OV1_PPC_2_06         0x02    /* set if we support PowerPC 2.06 */
> +#define OV1_PPC_2_07         0x01    /* set if we support PowerPC 2.07 */
> +
> +/* Option vector 2: Open Firmware options supported */
> +#define OV2_REAL_MODE                0x20    /* set if we want OF in real 
> mode */
> +
> +/* Option vector 3: processor options supported */
> +#define OV3_FP                       0x80    /* floating point */
> +#define OV3_VMX                      0x40    /* VMX/Altivec */
> +#define OV3_DFP                      0x20    /* decimal FP */
> +
> +/* Option vector 4: IBM PAPR implementation */
> +#define OV4_MIN_ENT_CAP              0x01    /* minimum VP entitled capacity 
> */
> +
> +/* Option vector 5: PAPR/OF options supported */
> +#define OV5_LPAR             0x80    /* logical partitioning supported */
> +#define OV5_SPLPAR           0x40    /* shared-processor LPAR supported */
> +/* ibm,dynamic-reconfiguration-memory property supported */
> +#define OV5_DRCONF_MEMORY    0x20
> +#define OV5_LARGE_PAGES              0x10    /* large pages supported */
> +#define OV5_DONATE_DEDICATE_CPU      0x02    /* donate dedicated CPU support 
> */
> +/* PCIe/MSI support.  Without MSI full PCIe is not supported */
> +#ifdef CONFIG_PCI_MSI
> +#define OV5_MSI                      0x01    /* PCIe/MSI support */
> +#else
> +#define OV5_MSI                      0x00
> +#endif /* CONFIG_PCI_MSI */
> +#ifdef CONFIG_PPC_SMLPAR
> +#define OV5_CMO                      0x80    /* Cooperative Memory 
> Overcommitment */
> +#define OV5_XCMO             0x40    /* Page Coalescing */
> +#else
> +#define OV5_CMO                      0x00
> +#define OV5_XCMO             0x00
> +#endif
> +#define OV5_TYPE1_AFFINITY   0x80    /* Type 1 NUMA affinity */
> +#define OV5_PFO_HW_RNG               0x80    /* PFO Random Number Generator 
> */
> +#define OV5_PFO_HW_842               0x40    /* PFO Compression Accelerator 
> */
> +#define OV5_PFO_HW_ENCR              0x20    /* PFO Encryption Accelerator */
> +#define OV5_SUB_PROCESSORS   0x01    /* 1,2,or 4 Sub-Processors supported */
> +
> +/* Option Vector 6: IBM PAPR hints */
> +#define OV6_LINUX            0x02    /* Linux is our OS */
> +
> +/*
> + * The architecture vector has an array of PVR mask/value pairs,
> + * followed by # option vectors - 1, followed by the option vectors.
> + */
> +extern unsigned char ibm_architecture_vec[];
> +#endif
> +
>  /* These includes are put at the bottom because they may contain things
>   * that are overridden by this file.  Ideally they shouldn't be included
>   * by this file, but there are a bunch of .c files that currently depend
> Index: powerpc/arch/powerpc/kernel/prom_init.c
> ===================================================================
> --- powerpc.orig/arch/powerpc/kernel/prom_init.c      2013-04-16 
> 21:25:16.000000000 -0500
> +++ powerpc/arch/powerpc/kernel/prom_init.c   2013-04-17 13:43:13.000000000 
> -0500
> @@ -627,16 +627,11 @@
>  
>  #if defined(CONFIG_PPC_PSERIES) || defined(CONFIG_PPC_POWERNV)
>  /*
> - * There are two methods for telling firmware what our capabilities are.
> - * Newer machines have an "ibm,client-architecture-support" method on the
> - * root node.  For older machines, we have to call the "process-elf-header"
> - * method in the /packages/elf-loader node, passing it a fake 32-bit
> - * ELF header containing a couple of PT_NOTE sections that contain
> - * structures that contain various information.
> - */
> -
> -/*
> - * New method - extensible architecture description vector.
> + * The architecture vector has an array of PVR mask/value pairs,
> + * followed by # option vectors - 1, followed by the option vectors.
> + *
> + * See prom.h for the definition of the bits specified in the
> + * achitecture vector.
>   *
>   * Because the description vector contains a mix of byte and word
>   * values, we declare it as an unsigned char array, and use this
> @@ -645,65 +640,7 @@
>  #define W(x) ((x) >> 24) & 0xff, ((x) >> 16) & 0xff, \
>               ((x) >> 8) & 0xff, (x) & 0xff
>  
> -/* Option vector bits - generic bits in byte 1 */
> -#define OV_IGNORE            0x80    /* ignore this vector */
> -#define OV_CESSATION_POLICY  0x40    /* halt if unsupported option present*/
> -
> -/* Option vector 1: processor architectures supported */
> -#define OV1_PPC_2_00         0x80    /* set if we support PowerPC 2.00 */
> -#define OV1_PPC_2_01         0x40    /* set if we support PowerPC 2.01 */
> -#define OV1_PPC_2_02         0x20    /* set if we support PowerPC 2.02 */
> -#define OV1_PPC_2_03         0x10    /* set if we support PowerPC 2.03 */
> -#define OV1_PPC_2_04         0x08    /* set if we support PowerPC 2.04 */
> -#define OV1_PPC_2_05         0x04    /* set if we support PowerPC 2.05 */
> -#define OV1_PPC_2_06         0x02    /* set if we support PowerPC 2.06 */
> -#define OV1_PPC_2_07         0x01    /* set if we support PowerPC 2.07 */
> -
> -/* Option vector 2: Open Firmware options supported */
> -#define OV2_REAL_MODE                0x20    /* set if we want OF in real 
> mode */
> -
> -/* Option vector 3: processor options supported */
> -#define OV3_FP                       0x80    /* floating point */
> -#define OV3_VMX                      0x40    /* VMX/Altivec */
> -#define OV3_DFP                      0x20    /* decimal FP */
> -
> -/* Option vector 4: IBM PAPR implementation */
> -#define OV4_MIN_ENT_CAP              0x01    /* minimum VP entitled capacity 
> */
> -
> -/* Option vector 5: PAPR/OF options supported */
> -#define OV5_LPAR             0x80    /* logical partitioning supported */
> -#define OV5_SPLPAR           0x40    /* shared-processor LPAR supported */
> -/* ibm,dynamic-reconfiguration-memory property supported */
> -#define OV5_DRCONF_MEMORY    0x20
> -#define OV5_LARGE_PAGES              0x10    /* large pages supported */
> -#define OV5_DONATE_DEDICATE_CPU 0x02 /* donate dedicated CPU support */
> -/* PCIe/MSI support.  Without MSI full PCIe is not supported */
> -#ifdef CONFIG_PCI_MSI
> -#define OV5_MSI                      0x01    /* PCIe/MSI support */
> -#else
> -#define OV5_MSI                      0x00
> -#endif /* CONFIG_PCI_MSI */
> -#ifdef CONFIG_PPC_SMLPAR
> -#define OV5_CMO                      0x80    /* Cooperative Memory 
> Overcommitment */
> -#define OV5_XCMO                     0x40    /* Page Coalescing */
> -#else
> -#define OV5_CMO                      0x00
> -#define OV5_XCMO                     0x00
> -#endif
> -#define OV5_TYPE1_AFFINITY   0x80    /* Type 1 NUMA affinity */
> -#define OV5_PFO_HW_RNG               0x80    /* PFO Random Number Generator 
> */
> -#define OV5_PFO_HW_842               0x40    /* PFO Compression Accelerator 
> */
> -#define OV5_PFO_HW_ENCR              0x20    /* PFO Encryption Accelerator */
> -#define OV5_SUB_PROCESSORS   0x01    /* 1,2,or 4 Sub-Processors supported */
> -
> -/* Option Vector 6: IBM PAPR hints */
> -#define OV6_LINUX            0x02    /* Linux is our OS */
> -
> -/*
> - * The architecture vector has an array of PVR mask/value pairs,
> - * followed by # option vectors - 1, followed by the option vectors.
> - */
> -static unsigned char ibm_architecture_vec[] = {
> +unsigned char ibm_architecture_vec[] = {
>       W(0xfffe0000), W(0x003a0000),   /* POWER5/POWER5+ */
>       W(0xffff0000), W(0x003e0000),   /* POWER6 */
>       W(0xffff0000), W(0x003f0000),   /* POWER7 */
> 
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev@lists.ozlabs.org
> https://lists.ozlabs.org/listinfo/linuxppc-dev


_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to