summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChen-Yu Tsai <wens@csie.org>2016-06-07 10:54:31 +0800
committerHans de Goede <hdegoede@redhat.com>2016-06-20 22:44:00 +0200
commit20e3d05370b75bc71b74765adc80de35ad2d2ec7 (patch)
tree11e047482599f85f27b2bbac2cd733168721ba38
parent57c2a255725a033407835cc596158a153c255bc1 (diff)
downloadblackbird-obmc-uboot-20e3d05370b75bc71b74765adc80de35ad2d2ec7.tar.gz
blackbird-obmc-uboot-20e3d05370b75bc71b74765adc80de35ad2d2ec7.zip
sunxi: Group cpu core related controls together
Instead of listing individual registers for controls to each processor core, list them as an array of registers. This makes accessing controls by core index easier. Also rename "cpucfg_sun6i.h" (which was unused anyway) to the more generic "cpucfg.h", and add packed attribute to struct sunxi_cpucfg. Signed-off-by: Chen-Yu Tsai <wens@csie.org> Acked-by: Marc Zyngier <marc.zyngier@arm.com> Signed-off-by: Hans de Goede <hdegoede@redhat.com>
-rw-r--r--arch/arm/include/asm/arch-sunxi/cpucfg.h (renamed from arch/arm/include/asm/arch-sunxi/cpucfg_sun6i.h)34
-rw-r--r--arch/arm/include/asm/arch-sunxi/prcm.h6
2 files changed, 16 insertions, 24 deletions
diff --git a/arch/arm/include/asm/arch-sunxi/cpucfg_sun6i.h b/arch/arm/include/asm/arch-sunxi/cpucfg.h
index 6885a972ce..f6d2f21d9d 100644
--- a/arch/arm/include/asm/arch-sunxi/cpucfg_sun6i.h
+++ b/arch/arm/include/asm/arch-sunxi/cpucfg.h
@@ -9,37 +9,31 @@
#ifndef _SUNXI_CPUCFG_H
#define _SUNXI_CPUCFG_H
+#include <linux/compiler.h>
#include <linux/types.h>
#ifndef __ASSEMBLY__
-struct sunxi_cpucfg_reg {
+struct __packed sunxi_cpucfg_cpu {
+ u32 rst; /* base + 0x0 */
+ u32 ctrl; /* base + 0x4 */
+ u32 status; /* base + 0x8 */
+ u8 res[0x34]; /* base + 0xc */
+};
+
+struct __packed sunxi_cpucfg_reg {
u8 res0[0x40]; /* 0x000 */
- u32 cpu0_rst; /* 0x040 */
- u32 cpu0_ctrl; /* 0x044 */
- u32 cpu0_status; /* 0x048 */
- u8 res1[0x34]; /* 0x04c */
- u32 cpu1_rst; /* 0x080 */
- u32 cpu1_ctrl; /* 0x084 */
- u32 cpu1_status; /* 0x088 */
- u8 res2[0x34]; /* 0x08c */
- u32 cpu2_rst; /* 0x0c0 */
- u32 cpu2_ctrl; /* 0x0c4 */
- u32 cpu2_status; /* 0x0c8 */
- u8 res3[0x34]; /* 0x0cc */
- u32 cpu3_rst; /* 0x100 */
- u32 cpu3_ctrl; /* 0x104 */
- u32 cpu3_status; /* 0x108 */
- u8 res4[0x78]; /* 0x10c */
+ struct sunxi_cpucfg_cpu cpu[4]; /* 0x040 */
+ u8 res1[0x44]; /* 0x140 */
u32 gen_ctrl; /* 0x184 */
u32 l2_status; /* 0x188 */
- u8 res5[0x4]; /* 0x18c */
+ u8 res2[0x4]; /* 0x18c */
u32 event_in; /* 0x190 */
- u8 res6[0xc]; /* 0x194 */
+ u8 res3[0xc]; /* 0x194 */
u32 super_standy_flag; /* 0x1a0 */
u32 priv0; /* 0x1a4 */
u32 priv1; /* 0x1a8 */
- u8 res7[0x54]; /* 0x1ac */
+ u8 res4[0x54]; /* 0x1ac */
u32 idle_cnt0_low; /* 0x200 */
u32 idle_cnt0_high; /* 0x204 */
u32 idle_cnt0_ctrl; /* 0x208 */
diff --git a/arch/arm/include/asm/arch-sunxi/prcm.h b/arch/arm/include/asm/arch-sunxi/prcm.h
index 34e01e825d..ae3880b13b 100644
--- a/arch/arm/include/asm/arch-sunxi/prcm.h
+++ b/arch/arm/include/asm/arch-sunxi/prcm.h
@@ -227,10 +227,8 @@ struct __packed sunxi_prcm_reg {
u32 gpu_pwroff; /* 0x118 */
u8 res9[0x4]; /* 0x11c */
u32 vdd_pwr_reset; /* 0x120 */
- u8 res10[0x20]; /* 0x124 */
- u32 cpu1_pwr_clamp; /* 0x144 */
- u32 cpu2_pwr_clamp; /* 0x148 */
- u32 cpu3_pwr_clamp; /* 0x14c */
+ u8 res10[0x1c]; /* 0x124 */
+ u32 cpu_pwr_clamp[4]; /* 0x140 but first one is actually unused */
u8 res11[0x30]; /* 0x150 */
u32 dram_pwr; /* 0x180 */
u8 res12[0xc]; /* 0x184 */
OpenPOWER on IntegriCloud