Page Menu
Home
FreeBSD
Search
Configure Global Search
Log In
Files
F137164598
D6269.id16067.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Flag For Later
Award Token
Size
3 KB
Referenced Files
None
Subscribers
None
D6269.id16067.diff
View Options
Index: sys/arm/allwinner/allwinner_machdep.c
===================================================================
--- sys/arm/allwinner/allwinner_machdep.c
+++ sys/arm/allwinner/allwinner_machdep.c
@@ -167,7 +167,7 @@
PLATFORMMETHOD(platform_devmap_init, allwinner_devmap_init),
#ifdef SMP
- PLATFORMMETHOD(platform_mp_start_ap, a20_mp_start_ap),
+ PLATFORMMETHOD(platform_mp_start_ap, aw_mp_start_ap),
PLATFORMMETHOD(platform_mp_setmaxid, aw_mp_setmaxid),
#endif
PLATFORMMETHOD_END,
@@ -182,7 +182,7 @@
PLATFORMMETHOD(platform_devmap_init, allwinner_devmap_init),
#ifdef SMP
- PLATFORMMETHOD(platform_mp_start_ap, a31_mp_start_ap),
+ PLATFORMMETHOD(platform_mp_start_ap, aw_mp_start_ap),
PLATFORMMETHOD(platform_mp_setmaxid, aw_mp_setmaxid),
#endif
PLATFORMMETHOD_END,
@@ -197,7 +197,7 @@
PLATFORMMETHOD(platform_devmap_init, allwinner_devmap_init),
#ifdef SMP
- PLATFORMMETHOD(platform_mp_start_ap, a31_mp_start_ap),
+ PLATFORMMETHOD(platform_mp_start_ap, aw_mp_start_ap),
PLATFORMMETHOD(platform_mp_setmaxid, aw_mp_setmaxid),
#endif
PLATFORMMETHOD_END,
Index: sys/arm/allwinner/aw_mp.h
===================================================================
--- sys/arm/allwinner/aw_mp.h
+++ sys/arm/allwinner/aw_mp.h
@@ -29,8 +29,7 @@
#define _AW_MP_H_
void aw_mp_setmaxid(platform_t plat);
-void a20_mp_start_ap(platform_t plat);
-void a31_mp_start_ap(platform_t plat);
+void aw_mp_start_ap(platform_t plat);
void a83t_mp_start_ap(platform_t plat);
#endif /* _AW_MP_H_ */
Index: sys/arm/allwinner/aw_mp.c
===================================================================
--- sys/arm/allwinner/aw_mp.c
+++ sys/arm/allwinner/aw_mp.c
@@ -107,12 +107,29 @@
mp_maxid = ncpu - 1;
}
-static void
-aw_common_mp_start_ap(bus_space_handle_t cpucfg, bus_space_handle_t prcm)
+void
+aw_mp_start_ap(platform_t plat)
{
- int i, j;
+ bus_space_handle_t cpucfg;
+ bus_space_handle_t prcm;
+ int i, j, soc_family;
uint32_t val;
+ soc_family = allwinner_soc_family();
+ if (soc_family == ALLWINNERSOC_SUN7I) {
+ if (bus_space_map(fdtbus_bs_tag, A20_CPUCFG_BASE, CPUCFG_SIZE,
+ 0, &cpucfg) != 0)
+ panic("Couldn't map the CPUCFG\n");
+ }
+ else {
+ if (bus_space_map(fdtbus_bs_tag, CPUCFG_BASE, CPUCFG_SIZE,
+ 0, &cpucfg) != 0)
+ panic("Couldn't map the CPUCFG\n");
+ if (bus_space_map(fdtbus_bs_tag, PRCM_BASE, PRCM_SIZE, 0,
+ &prcm) != 0)
+ panic("Couldn't map the PRCM\n");
+ }
+
dcache_wbinv_poc_all();
bus_space_write_4(fdtbus_bs_tag, cpucfg, CPUCFG_P_REG0,
@@ -141,7 +158,7 @@
/* Release power clamp */
for (i = 1; i < mp_ncpus; i++)
for (j = 0; j <= CPU_PWR_CLAMP_STEPS; j++) {
- if (prcm) {
+ if (soc_family != ALLWINNERSOC_SUN7I) {
bus_space_write_4(fdtbus_bs_tag, prcm,
CPU_PWR_CLAMP(i), 0xff >> j);
} else {
@@ -152,7 +169,7 @@
DELAY(10000);
/* Clear power-off gating */
- if (prcm) {
+ if (soc_family != ALLWINNERSOC_SUN7I) {
val = bus_space_read_4(fdtbus_bs_tag, prcm, CPU_PWROFF);
for (i = 0; i < mp_ncpus; i++)
val &= ~(1 << i);
@@ -179,39 +196,8 @@
armv7_sev();
bus_space_unmap(fdtbus_bs_tag, cpucfg, CPUCFG_SIZE);
-}
-
-void
-a20_mp_start_ap(platform_t plat)
-{
- bus_space_handle_t cpucfg;
-
- if (bus_space_map(fdtbus_bs_tag, A20_CPUCFG_BASE, CPUCFG_SIZE,
- 0, &cpucfg) != 0)
- panic("Couldn't map the CPUCFG\n");
-
- aw_common_mp_start_ap(cpucfg, 0);
- armv7_sev();
- bus_space_unmap(fdtbus_bs_tag, cpucfg, CPUCFG_SIZE);
-}
-
-void
-a31_mp_start_ap(platform_t plat)
-{
- bus_space_handle_t cpucfg;
- bus_space_handle_t prcm;
-
- if (bus_space_map(fdtbus_bs_tag, CPUCFG_BASE, CPUCFG_SIZE,
- 0, &cpucfg) != 0)
- panic("Couldn't map the CPUCFG\n");
- if (bus_space_map(fdtbus_bs_tag, PRCM_BASE, PRCM_SIZE, 0,
- &prcm) != 0)
- panic("Couldn't map the PRCM\n");
-
- aw_common_mp_start_ap(cpucfg, prcm);
- armv7_sev();
- bus_space_unmap(fdtbus_bs_tag, cpucfg, CPUCFG_SIZE);
- bus_space_unmap(fdtbus_bs_tag, prcm, PRCM_SIZE);
+ if (soc_family != ALLWINNERSOC_SUN7I)
+ bus_space_unmap(fdtbus_bs_tag, prcm, PRCM_SIZE);
}
static void
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Sat, Nov 22, 8:13 AM (19 h, 5 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
25939275
Default Alt Text
D6269.id16067.diff (3 KB)
Attached To
Mode
D6269: Allwinner MP merge a20_mp_start_ap and a31_mp_start_ap
Attached
Detach File
Event Timeline
Log In to Comment