On Fri, Oct 01, 2010 at 05:06:02PM +1000, Ian Munsie wrote:
> From: Ian Munsie <imun...@au1.ibm.com>
> 
> On PowerPC the device tree is always big endian, but the CPU could be
> either, so add be32_to_cpu where appropriate and change the types of
> device tree data to __be32 etc to allow sparse to locate endian issues.
> 
> Signed-off-by: Ian Munsie <imun...@au1.ibm.com>

Acked-by: Grant Likely <grant.lik...@secretlab.ca>

But I won't merge this through my tree unless Ben asks me to.

g.

> ---
>  arch/powerpc/kernel/prom.c |   60 
> ++++++++++++++++++++++----------------------
>  1 files changed, 30 insertions(+), 30 deletions(-)
> 
> diff --git a/arch/powerpc/kernel/prom.c b/arch/powerpc/kernel/prom.c
> index fed9bf6..9b9ebb2 100644
> --- a/arch/powerpc/kernel/prom.c
> +++ b/arch/powerpc/kernel/prom.c
> @@ -188,16 +188,16 @@ static void __init check_cpu_pa_features(unsigned long 
> node)
>  #ifdef CONFIG_PPC_STD_MMU_64
>  static void __init check_cpu_slb_size(unsigned long node)
>  {
> -     u32 *slb_size_ptr;
> +     __be32 *slb_size_ptr;
>  
>       slb_size_ptr = of_get_flat_dt_prop(node, "slb-size", NULL);
>       if (slb_size_ptr != NULL) {
> -             mmu_slb_size = *slb_size_ptr;
> +             mmu_slb_size = be32_to_cpup(slb_size_ptr);
>               return;
>       }
>       slb_size_ptr = of_get_flat_dt_prop(node, "ibm,slb-size", NULL);
>       if (slb_size_ptr != NULL) {
> -             mmu_slb_size = *slb_size_ptr;
> +             mmu_slb_size = be32_to_cpup(slb_size_ptr);
>       }
>  }
>  #else
> @@ -252,11 +252,11 @@ static void __init 
> check_cpu_feature_properties(unsigned long node)
>  {
>       unsigned long i;
>       struct feature_property *fp = feature_properties;
> -     const u32 *prop;
> +     const __be32 *prop;
>  
>       for (i = 0; i < ARRAY_SIZE(feature_properties); ++i, ++fp) {
>               prop = of_get_flat_dt_prop(node, fp->name, NULL);
> -             if (prop && *prop >= fp->min_value) {
> +             if (prop && be32_to_cpup(prop) >= fp->min_value) {
>                       cur_cpu_spec->cpu_features |= fp->cpu_feature;
>                       cur_cpu_spec->cpu_user_features |= fp->cpu_user_ftr;
>               }
> @@ -269,8 +269,8 @@ static int __init early_init_dt_scan_cpus(unsigned long 
> node,
>  {
>       static int logical_cpuid = 0;
>       char *type = of_get_flat_dt_prop(node, "device_type", NULL);
> -     const u32 *prop;
> -     const u32 *intserv;
> +     const __be32 *prop;
> +     const __be32 *intserv;
>       int i, nthreads;
>       unsigned long len;
>       int found = 0;
> @@ -297,9 +297,9 @@ static int __init early_init_dt_scan_cpus(unsigned long 
> node,
>                * version 2 of the kexec param format adds the phys cpuid of
>                * booted proc.
>                */
> -             if (initial_boot_params && initial_boot_params->version >= 2) {
> -                     if (intserv[i] ==
> -                                     initial_boot_params->boot_cpuid_phys) {
> +             if (initial_boot_params && 
> be32_to_cpu(initial_boot_params->version) >= 2) {
> +                     if (be32_to_cpu(intserv[i]) ==
> +                                     
> be32_to_cpu(initial_boot_params->boot_cpuid_phys)) {
>                               found = 1;
>                               break;
>                       }
> @@ -324,9 +324,9 @@ static int __init early_init_dt_scan_cpus(unsigned long 
> node,
>  
>       if (found) {
>               DBG("boot cpu: logical %d physical %d\n", logical_cpuid,
> -                     intserv[i]);
> +                     be32_to_cpu(intserv[i]));
>               boot_cpuid = logical_cpuid;
> -             set_hard_smp_processor_id(boot_cpuid, intserv[i]);
> +             set_hard_smp_processor_id(boot_cpuid, be32_to_cpu(intserv[i]));
>  
>               /*
>                * PAPR defines "logical" PVR values for cpus that
> @@ -343,8 +343,8 @@ static int __init early_init_dt_scan_cpus(unsigned long 
> node,
>                * it uses 0x0f000001.
>                */
>               prop = of_get_flat_dt_prop(node, "cpu-version", NULL);
> -             if (prop && (*prop & 0xff000000) == 0x0f000000)
> -                     identify_cpu(0, *prop);
> +             if (prop && (be32_to_cpup(prop) & 0xff000000) == 0x0f000000)
> +                     identify_cpu(0, be32_to_cpup(prop));
>  
>               identical_pvr_fixup(node);
>       }
> @@ -365,7 +365,7 @@ static int __init early_init_dt_scan_cpus(unsigned long 
> node,
>  
>  void __init early_init_dt_scan_chosen_arch(unsigned long node)
>  {
> -     unsigned long *lprop;
> +     unsigned long *lprop; /* All these set by kernel, so no need to convert 
> endian */
>  
>  #ifdef CONFIG_PPC64
>       /* check if iommu is forced on or off */
> @@ -524,16 +524,16 @@ void __init early_init_dt_setup_initrd_arch(unsigned 
> long start,
>  static void __init early_reserve_mem(void)
>  {
>       u64 base, size;
> -     u64 *reserve_map;
> +     __be64 *reserve_map;
>       unsigned long self_base;
>       unsigned long self_size;
>  
> -     reserve_map = (u64 *)(((unsigned long)initial_boot_params) +
> -                                     initial_boot_params->off_mem_rsvmap);
> +     reserve_map = (__be64 *)(((unsigned long)initial_boot_params) +
> +                     be32_to_cpu(initial_boot_params->off_mem_rsvmap));
>  
>       /* before we do anything, lets reserve the dt blob */
>       self_base = __pa((unsigned long)initial_boot_params);
> -     self_size = initial_boot_params->totalsize;
> +     self_size = be32_to_cpu(initial_boot_params->totalsize);
>       memblock_reserve(self_base, self_size);
>  
>  #ifdef CONFIG_BLK_DEV_INITRD
> @@ -547,13 +547,13 @@ static void __init early_reserve_mem(void)
>        * Handle the case where we might be booting from an old kexec
>        * image that setup the mem_rsvmap as pairs of 32-bit values
>        */
> -     if (*reserve_map > 0xffffffffull) {
> +     if (be64_to_cpup(reserve_map) > 0xffffffffull) {
>               u32 base_32, size_32;
> -             u32 *reserve_map_32 = (u32 *)reserve_map;
> +             __be32 *reserve_map_32 = (__be32 *)reserve_map;
>  
>               while (1) {
> -                     base_32 = *(reserve_map_32++);
> -                     size_32 = *(reserve_map_32++);
> +                     base_32 = be32_to_cpup(reserve_map_32++);
> +                     size_32 = be32_to_cpup(reserve_map_32++);
>                       if (size_32 == 0)
>                               break;
>                       /* skip if the reservation is for the blob */
> @@ -566,8 +566,8 @@ static void __init early_reserve_mem(void)
>       }
>  #endif
>       while (1) {
> -             base = *(reserve_map++);
> -             size = *(reserve_map++);
> +             base = be64_to_cpup(reserve_map++);
> +             size = be64_to_cpup(reserve_map++);
>               if (size == 0)
>                       break;
>               DBG("reserving: %llx -> %llx\n", base, size);
> @@ -860,7 +860,7 @@ struct device_node *of_get_cpu_node(int cpu, unsigned int 
> *thread)
>       hardid = get_hard_smp_processor_id(cpu);
>  
>       for_each_node_by_type(np, "cpu") {
> -             const u32 *intserv;
> +             const __be32 *intserv;
>               unsigned int plen, t;
>  
>               /* Check for ibm,ppc-interrupt-server#s. If it doesn't exist
> @@ -869,10 +869,10 @@ struct device_node *of_get_cpu_node(int cpu, unsigned 
> int *thread)
>               intserv = of_get_property(np, "ibm,ppc-interrupt-server#s",
>                               &plen);
>               if (intserv == NULL) {
> -                     const u32 *reg = of_get_property(np, "reg", NULL);
> +                     const __be32 *reg = of_get_property(np, "reg", NULL);
>                       if (reg == NULL)
>                               continue;
> -                     if (*reg == hardid) {
> +                     if (be32_to_cpup(reg) == hardid) {
>                               if (thread)
>                                       *thread = 0;
>                               return np;
> @@ -880,7 +880,7 @@ struct device_node *of_get_cpu_node(int cpu, unsigned int 
> *thread)
>               } else {
>                       plen /= sizeof(u32);
>                       for (t = 0; t < plen; t++) {
> -                             if (hardid == intserv[t]) {
> +                             if (hardid == be32_to_cpu(intserv[t])) {
>                                       if (thread)
>                                               *thread = t;
>                                       return np;
> @@ -900,7 +900,7 @@ static int __init export_flat_device_tree(void)
>       struct dentry *d;
>  
>       flat_dt_blob.data = initial_boot_params;
> -     flat_dt_blob.size = initial_boot_params->totalsize;
> +     flat_dt_blob.size = be32_to_cpu(initial_boot_params->totalsize);
>  
>       d = debugfs_create_blob("flat-device-tree", S_IFREG | S_IRUSR,
>                               powerpc_debugfs_root, &flat_dt_blob);
> -- 
> 1.7.1
> 
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to