This pull request adds misc fixes for cssi boards and activates
CPM relocation in order to enable the use of SCC4 in
QMC (QUICC Multi-Channel) mode.
This commit is contained in:
Tom Rini 2023-05-07 09:44:27 -04:00
commit 1917a1a8a8
16 changed files with 254 additions and 86 deletions

View file

@ -30,6 +30,51 @@ config MPC885
endchoice endchoice
choice
prompt "Microcode patch selection"
default NO_UCODE_PATCH
help
This allows loading of CPM microcode.
Only one microcode can be loaded at a time.
config NO_UCODE_PATCH
bool "None"
config USB_SOF_UCODE_PATCH
bool "USB SOF patch"
depends on MPC885
help
This microcode fixes CPM15 errata:
When the USB controller is configured in Host mode, and the
SOF generation (SFTE=1 in USMOD register) is being used,
there may be false CRC error indication in other SCCs.
Although the data is received correctly, the CRC result
will be corrupted.
config SMC_UCODE_PATCH
bool "SMC relocation patch"
help
This microcode relocates SMC1 and SMC2 parameter RAMs to allow
extended parameter RAM for SCC3 and SCC4 (ex: for QMC mode)
config SMC1_RPBASE
hex "SMC1 relocation offset"
depends on SMC_UCODE_PATCH
default 0x1e80
help
Offset of SMC1 parameter RAM to be written to RPBASE register.
config SMC2_RPBASE
hex "SMC2 relocation offset"
depends on SMC_UCODE_PATCH
default 0x1f80
help
Offset of SMC2 parameter RAM to be written to RPBASE register.
endchoice
comment "Specific commands" comment "Specific commands"
config CMD_IMMAP config CMD_IMMAP

View file

@ -12,3 +12,5 @@ obj-$(CONFIG_CMD_IMMAP) += immap.o
obj-y += interrupts.o obj-y += interrupts.o
obj-y += speed.o obj-y += speed.o
obj-y += cache.o obj-y += cache.o
obj-$(CONFIG_USB_SOF_UCODE_PATCH) += micropatch_usb_sof.o
obj-$(CONFIG_SMC_UCODE_PATCH) += micropatch_smc.o

View file

@ -127,7 +127,7 @@ static int check_CPU(long clock, uint pvr, uint immr)
return -1; return -1;
k = (immr << 16) | k = (immr << 16) |
in_be16(&immap->im_cpm.cp_dparam16[PROFF_REVNUM / sizeof(u16)]); in_be16((u16 __iomem *)&immap->im_cpm.cp_dpmem[PROFF_REVNUM]);
/* /*
* Some boards use sockets so different CPUs can be used. * Some boards use sockets so different CPUs can be used.

View file

@ -0,0 +1,105 @@
// SPDX-License-Identifier: GPL-2.0
/*
* Microcode patches for the CPM as supplied by Motorola.
*/
#include <linux/string.h>
#include <linux/io.h>
#include <asm/immap_8xx.h>
#include <asm/cpm_8xx.h>
static uint patch_2000[] = {
0x3fff0000, 0x3ffd0000, 0x3ffb0000, 0x3ff90000,
0x5fefeff8, 0x5f91eff8, 0x3ff30000, 0x3ff10000,
0x3a11e710, 0xedf0ccb9, 0xf318ed66, 0x7f0e5fe2,
0x7fedbb38, 0x3afe7468, 0x7fedf4d8, 0x8ffbb92d,
0xb83b77fd, 0xb0bb5eb9, 0xdfda7fed, 0x90bde74d,
0x6f0dcbd3, 0xe7decfed, 0xcb50cfed, 0xcfeddf6d,
0x914d4f74, 0x5eaedfcb, 0x9ee0e7df, 0xefbb6ffb,
0xe7ef7f0e, 0x9ee57fed, 0xebb7effa, 0xeb30affb,
0x7fea90b3, 0x7e0cf09f, 0xbffff318, 0x5fffdfff,
0xac35efea, 0x7fce1fc1, 0xe2ff5fbd, 0xaffbe2ff,
0x5fbfaffb, 0xf9a87d0f, 0xaef8770f, 0x7d0fb0a2,
0xeffbbfff, 0xcfef5fba, 0x7d0fbfff, 0x5fba4cf8,
0x7fddd09b, 0x49f847fd, 0x7efdf097, 0x7fedfffd,
0x7dfdf093, 0xef7e7e1e, 0x5fba7f0e, 0x3a11e710,
0xedf0cc87, 0xfb18ad0a, 0x1f85bbb8, 0x74283b7e,
0x7375e4bb, 0x2ab64fb8, 0x5c7de4bb, 0x32fdffbf,
0x5f0843f8, 0x7ce3e1bb, 0xe74f7ded, 0x6f0f4fe8,
0xc7ba32be, 0x73f2efeb, 0x600b4f78, 0xe5bb760b,
0x5388aef8, 0x4ef80b6a, 0xcfef9ee5, 0xabf8751f,
0xefef5b88, 0x741f4fe8, 0x751e760d, 0x7fdb70dd,
0x741cafce, 0xefcc7fce, 0x751e7088, 0x741ce7bb,
0x334ecfed, 0xafdbefeb, 0xe5bb760b, 0x53ceaef8,
0xafe8e7eb, 0x4bf8771e, 0x7e007fed, 0x4fcbe2cc,
0x7fbc3085, 0x7b0f7a0f, 0x34b177fd, 0xb0e75e93,
0xdf313e3b, 0xaf78741f, 0x741f30cc, 0xcfef5f08,
0x741f3e88, 0xafb8771e, 0x5f437fed, 0x0bafe2cc,
0x741ccfec, 0xe5ca53a9, 0x6fcb4f74, 0x5e89df27,
0x2a923d14, 0x4b8fdf0c, 0x751f741c, 0x6c1eeffa,
0xefea7fce, 0x6ffc309a, 0xefec3fca, 0x308fdf0a,
0xadf85e7a, 0xaf7daefd, 0x5e7adf0a, 0x5e7aafdd,
0x761f1088, 0x1e7c7efd, 0x3089fffe, 0x4908fb18,
0x5fffdfff, 0xafbbf0f7, 0x4ef85f43, 0xadf81489,
0x7a0f7089, 0xcfef5089, 0x7a0fdf0c, 0x5e7cafed,
0xbc6e780f, 0xefef780f, 0xefef790f, 0xa7f85eeb,
0xffef790f, 0xefef790f, 0x1489df0a, 0x5e7aadfd,
0x5f09fffb, 0xe79aded9, 0xeff96079, 0x607ae79a,
0xded8eff9, 0x60795edb, 0x607acfef, 0xefefefdf,
0xefbfef7f, 0xeeffedff, 0xebffe7ff, 0xafefafdf,
0xafbfaf7f, 0xaeffadff, 0xabffa7ff, 0x6fef6fdf,
0x6fbf6f7f, 0x6eff6dff, 0x6bff67ff, 0x2fef2fdf,
0x2fbf2f7f, 0x2eff2dff, 0x2bff27ff, 0x4e08fd1f,
0xe5ff6e0f, 0xaff87eef, 0x7e0ffdef, 0xf11f6079,
0xabf8f51e, 0x7e0af11c, 0x37cfae16, 0x7fec909a,
0xadf8efdc, 0xcfeae52f, 0x7d0fe12b, 0xf11c6079,
0x7e0a4df8, 0xcfea5ea0, 0x7d0befec, 0xcfea5ea2,
0xe522efdc, 0x5ea2cfda, 0x4e08fd1f, 0x6e0faff8,
0x7c1f761f, 0xfdeff91f, 0x6079abf8, 0x761cee00,
0xf91f2bfb, 0xefefcfec, 0xf91f6079, 0x761c27fb,
0xefdf5e83, 0xcfdc7fdd, 0x50f84bf8, 0x47fd7c1f,
0x761ccfcf, 0x7eef7fed, 0x7dfd70ef, 0xef7e7f1e,
0x771efb18, 0x6079e722, 0xe6bbe5bb, 0x2e66e5bb,
0x600b2ee1, 0xe2bbe2bb, 0xe2bbe2bb, 0x2f5ee2bb,
0xe2bb2ff9, 0x6079e2bb,
};
static uint patch_2f00[] = {
0x30303030, 0x3e3e3030, 0xaf79b9b3, 0xbaa3b979,
0x9693369f, 0x79f79777, 0x97333fff, 0xfb3b9e9f,
0x79b91d11, 0x9e13f3ff, 0x3f9b6bd9, 0xe173d136,
0x695669d1, 0x697b3daf, 0x79b93a3a, 0x3f979f91,
0x379ff976, 0xf99777fd, 0x9779737d, 0xe9d6bbf9,
0xbfffd9df, 0x97f7fd97, 0x6f7b9bff, 0xf9bd9683,
0x397db973, 0xd97b3b9f, 0xd7f9f733, 0x9993bb9e,
0xe1f9ef93, 0x73773337, 0xb936917d, 0x11f87379,
0xb979d336, 0x8b7ded73, 0x1b7d9337, 0x31f3f22f,
0x3f2327ee, 0xeeeeeeee, 0xeeeeeeee, 0xeeeeeeee,
0xeeeeee4b, 0xf4fbdbd2, 0x58bb1878, 0x577fdfd2,
0xd573b773, 0xf7374b4f, 0xbdbd25b8, 0xb177d2d1,
0x7376856b, 0xbfdd687b, 0xdd2fff8f, 0x78ffff8f,
0xf22f0000,
};
void cpm_load_patch(cpm8xx_t __iomem *cp)
{
smc_uart_t __iomem *smp;
out_be16(&cp->cp_rccr, 0);
memcpy_toio(cp->cp_dpmem, patch_2000, sizeof(patch_2000));
memcpy_toio(cp->cp_dpmem + 0xf00, patch_2f00, sizeof(patch_2f00));
smp = (smc_uart_t __iomem *)&cp->cp_dpmem[PROFF_SMC1];
out_be16(&smp->smc_rpbase, CONFIG_SMC1_RPBASE);
smp = (smc_uart_t __iomem *)&cp->cp_dpmem[PROFF_SMC2];
out_be16(&smp->smc_rpbase, CONFIG_SMC2_RPBASE);
out_be16(&cp->cp_cpmcr1, 0x8080);
out_be16(&cp->cp_cpmcr2, 0x8088);
out_be16(&cp->cp_cpmcr3, 0);
out_be16(&cp->cp_cpmcr4, 0);
out_be16(&cp->cp_rccr, 2);
}

View file

@ -0,0 +1,38 @@
// SPDX-License-Identifier: GPL-2.0
/*
* Microcode patches for the CPM as supplied by Motorola.
*/
#include <linux/string.h>
#include <linux/io.h>
#include <asm/immap_8xx.h>
#include <asm/cpm_8xx.h>
/*
* USB SOF patch arrays.
*/
static uint patch_2000[] = {
0x7fff0000, 0x7ffd0000, 0x7ffb0000, 0x49f7ba5b,
0xba383ffb, 0xf9b8b46d, 0xe5ab4e07, 0xaf77bffe,
0x3f7bbf79, 0xba5bba38, 0xe7676076, 0x60750000
};
static uint patch_2f00[] = {
0x3030304c, 0xcab9e441, 0xa1aaf220
};
void cpm_load_patch(cpm8xx_t __iomem *cp)
{
out_be16(&cp->cp_rccr, 0);
memcpy_toio(cp->cp_dpmem, patch_2000, sizeof(patch_2000));
memcpy_toio(cp->cp_dpmem + 0xf00, patch_2f00, sizeof(patch_2f00));
out_be16(&cp->cp_cpmcr1, 0);
out_be16(&cp->cp_cpmcr2, 0);
out_be16(&cp->cp_cpmcr3, 0);
out_be16(&cp->cp_cpmcr4, 0);
out_be16(&cp->cp_rccr, 9);
}

View file

@ -141,14 +141,16 @@ in_flash:
mtspr DER, r2 mtspr DER, r2
/* set up the stack on top of internal DPRAM */ /* set up the stack on top of internal DPRAM */
lis r3, (CFG_SYS_INIT_RAM_ADDR + CFG_SYS_INIT_RAM_SIZE)@h lis r3, CFG_SYS_INIT_SP@h
ori r3, r3, (CFG_SYS_INIT_RAM_ADDR + CFG_SYS_INIT_RAM_SIZE)@l ori r3, r3, CFG_SYS_INIT_SP@l
stw r0, -4(r3) stw r0, -4(r3)
stw r0, -8(r3) stw r0, -8(r3)
addi r1, r3, -8 addi r1, r3, -8
lis r3, (CFG_SYS_INIT_RAM_ADDR + CFG_SYS_INIT_RAM_SIZE)@h
ori r3, r3, (CFG_SYS_INIT_RAM_ADDR + CFG_SYS_INIT_RAM_SIZE)@l
bl board_init_f_alloc_reserve bl board_init_f_alloc_reserve
addi r1, r3, -8
/* Zeroise the CPM dpram */ /* Zeroise the CPM dpram */
lis r4, CONFIG_SYS_IMMR@h lis r4, CONFIG_SYS_IMMR@h

View file

@ -51,14 +51,14 @@
/* /*
* DPRAM defines and allocation functions * DPRAM defines and allocation functions
*/ */
#define CPM_SERIAL_BASE 0x1800 #define CPM_SERIAL_BASE 0x0800
#define CPM_I2C_BASE 0x1820 #define CPM_I2C_BASE 0x0820
#define CPM_SPI_BASE 0x1840 #define CPM_SPI_BASE 0x0840
#define CPM_FEC_BASE 0x1860 #define CPM_FEC_BASE 0x0860
#define CPM_SERIAL2_BASE 0x18e0 #define CPM_SERIAL2_BASE 0x08E0
#define CPM_SCC_BASE 0x1900 #define CPM_SCC_BASE 0x0900
#define CPM_POST_BASE 0x1980 #define CPM_POST_BASE 0x0980
#define CPM_WLKBD_BASE 0x1a00 #define CPM_WLKBD_BASE 0x0a00
#define BD_IIC_START ((uint) 0x0400) /* <- please use CPM_I2C_BASE !! */ #define BD_IIC_START ((uint) 0x0400) /* <- please use CPM_I2C_BASE !! */
@ -92,15 +92,15 @@ typedef struct cpm_buf_desc {
/* Parameter RAM offsets. /* Parameter RAM offsets.
*/ */
#define PROFF_SCC1 ((uint)0x0000) #define PROFF_SCC1 ((uint)0x1c00)
#define PROFF_IIC ((uint)0x0080) #define PROFF_IIC ((uint)0x1c80)
#define PROFF_REVNUM ((uint)0x00b0) #define PROFF_REVNUM ((uint)0x1cb0)
#define PROFF_SCC2 ((uint)0x0100) #define PROFF_SCC2 ((uint)0x1d00)
#define PROFF_SPI ((uint)0x0180) #define PROFF_SPI ((uint)0x1d80)
#define PROFF_SCC3 ((uint)0x0200) #define PROFF_SCC3 ((uint)0x1e00)
#define PROFF_SMC1 ((uint)0x0280) #define PROFF_SMC1 ((uint)0x1e80)
#define PROFF_SCC4 ((uint)0x0300) #define PROFF_SCC4 ((uint)0x1f00)
#define PROFF_SMC2 ((uint)0x0380) #define PROFF_SMC2 ((uint)0x1f80)
/* Define enough so I can at least use the serial port as a UART. /* Define enough so I can at least use the serial port as a UART.
*/ */
@ -684,4 +684,11 @@ void irq_install_handler(int vec, void (*handler)(void *), void *dev_id);
#define CICR_HP_MASK ((uint)0x00001f00) /* Hi-pri int. */ #define CICR_HP_MASK ((uint)0x00001f00) /* Hi-pri int. */
#define CICR_IEN ((uint)0x00000080) /* Int. enable */ #define CICR_IEN ((uint)0x00000080) /* Int. enable */
#define CICR_SPS ((uint)0x00000001) /* SCC Spread */ #define CICR_SPS ((uint)0x00000001) /* SCC Spread */
#ifdef CONFIG_NO_UCODE_PATCH
static inline void cpm_load_patch(cpm8xx_t __iomem *cp) { }
#else
void cpm_load_patch(cpm8xx_t __iomem *cp);
#endif
#endif /* __CPM_8XX__ */ #endif /* __CPM_8XX__ */

View file

@ -437,13 +437,7 @@ typedef struct comm_proc {
* depending upon the devices used and options chosen. * depending upon the devices used and options chosen.
* Some processors don't have all of it populated. * Some processors don't have all of it populated.
*/ */
u_char cp_dpmem[0x1C00]; /* BD / Data / ucode */ u_char cp_dpmem[0x2000]; /* BD / Data / ucode / Param RAM */
/* Parameter RAM */
union {
u_char cp_dparam[0x400];
u16 cp_dparam16[0x200];
};
} cpm8xx_t; } cpm8xx_t;
/* Internal memory map. /* Internal memory map.

View file

@ -95,9 +95,9 @@ extern void _outsl_ns(volatile u32 *port, const void *buf, int nl);
#define IO_SPACE_LIMIT ~0 #define IO_SPACE_LIMIT ~0
#define memset_io(a,b,c) memset((void *)(a),(b),(c)) #define memset_io(a,b,c) memset((void __force *)(a),(b),(c))
#define memcpy_fromio(a,b,c) memcpy((a),(void *)(b),(c)) #define memcpy_fromio(a,b,c) memcpy((a),(void __force *)(b),(c))
#define memcpy_toio(a,b,c) memcpy((void *)(a),(b),(c)) #define memcpy_toio(a,b,c) memcpy((void __force *)(a),(b),(c))
/* /*
* Enforce In-order Execution of I/O: * Enforce In-order Execution of I/O:

View file

@ -11,6 +11,7 @@
#include <env.h> #include <env.h>
#include <common.h> #include <common.h>
#include <mpc8xx.h> #include <mpc8xx.h>
#include <asm/cpm_8xx.h>
#include <asm/io.h> #include <asm/io.h>
#include <dm.h> #include <dm.h>
#include <stdio.h> #include <stdio.h>
@ -451,6 +452,9 @@ void iop_setup_miae(void)
/* Wait reset on FPGA_F */ /* Wait reset on FPGA_F */
udelay(100); udelay(100);
/* Load CPM relocation code */
cpm_load_patch(cp);
/* Set the front panel LED color to red */ /* Set the front panel LED color to red */
clrbits_8((unsigned char __iomem *)CONFIG_FPGA_BASE + 0x44, 0x02); clrbits_8((unsigned char __iomem *)CONFIG_FPGA_BASE + 0x44, 0x02);
@ -586,13 +590,8 @@ void iop_setup_miae(void)
setbits_be32(&cp->cp_peso, 0x00031980); setbits_be32(&cp->cp_peso, 0x00031980);
} }
int board_early_init_f(void)
{
return 0;
}
/* Specific board initialization */ /* Specific board initialization */
int board_early_init_r(void) int board_early_init_f(void)
{ {
immap_t __iomem *immr = (immap_t __iomem *)CONFIG_SYS_IMMR; immap_t __iomem *immr = (immap_t __iomem *)CONFIG_SYS_IMMR;
iop8xx_t __iomem *iop = &immr->im_ioport; iop8xx_t __iomem *iop = &immr->im_ioport;
@ -864,8 +863,6 @@ int board_early_init_r(void)
/* Check if fpga firmware is loaded */ /* Check if fpga firmware is loaded */
if (!(in_be32(&cp->cp_pedat) & 0x00000001)) { if (!(in_be32(&cp->cp_pedat) & 0x00000001)) {
printf("Reloading FPGA firmware.\n");
/* Load fpga firmware */ /* Load fpga firmware */
/* Activate PROG_FPGA_FIRMWARE for 1 usec */ /* Activate PROG_FPGA_FIRMWARE for 1 usec */
clrbits_be32(&cp->cp_pedat, 0x00000002); clrbits_be32(&cp->cp_pedat, 0x00000002);
@ -874,12 +871,8 @@ int board_early_init_r(void)
/* Wait 200 msec and check DONE_FPGA_FIRMWARE */ /* Wait 200 msec and check DONE_FPGA_FIRMWARE */
mdelay(200); mdelay(200);
if (!(in_be32(&cp->cp_pedat) & 0x00000001)) { if (!(in_be32(&cp->cp_pedat) & 0x00000001))
for (;;) { hang();
printf("error loading firmware.\n");
mdelay(500);
}
}
/* Send a reset signal and wait for 20 msec */ /* Send a reset signal and wait for 20 msec */
clrbits_be16(ADDR_CPLD_R_RESET, R_RST_STATUS); clrbits_be16(ADDR_CPLD_R_RESET, R_RST_STATUS);
@ -889,26 +882,8 @@ int board_early_init_r(void)
/* Wait 300 msec and check the reset state */ /* Wait 300 msec and check the reset state */
mdelay(300); mdelay(300);
if (!(in_be16(ADDR_CPLD_R_RESET) & R_RESET_STATUS)) { if (!(in_be16(ADDR_CPLD_R_RESET) & R_RESET_STATUS))
for (;;) { hang();
printf("Could not reset FPGA.\n");
mdelay(500);
}
}
/* is FPGA firmware loaded ? */
if (!(in_be32(&cp->cp_pedat) & 0x00000001)) {
printf("Reloading FPGA firmware\n");
/* Load FPGA firmware */
/* Activate PROG_FPGA_FIRMWARE for 1 usec */
clrbits_be32(&cp->cp_pedat, 0x00000002);
udelay(1);
setbits_be32(&cp->cp_pedat, 0x00000002);
/* Wait 200ms before checking DONE_FPGA_FIRMWARE */
mdelay(200);
}
iop_setup_common(); iop_setup_common();
} else { } else {

View file

@ -397,8 +397,3 @@ void ft_board_setup_phy3(void)
setbits_be32(&immr->qepio.ioport[2].pdat, 0x00000400); setbits_be32(&immr->qepio.ioport[2].pdat, 0x00000400);
} }
#define ADDR_FPGA_R_BASE ((unsigned char __iomem *)CONFIG_FPGA_BASE)
#define ADDR_FPGA_R_ALARMES_IN ((unsigned char __iomem *)CONFIG_FPGA_BASE + 0x31)
#define ADDR_FPGA_R_FAV ((unsigned char __iomem *)CONFIG_FPGA_BASE + 0x44)

View file

@ -10,6 +10,8 @@ CONFIG_MPC8xx=y
# CONFIG_PCI is not set # CONFIG_PCI is not set
CONFIG_TARGET_CMPC885=y CONFIG_TARGET_CMPC885=y
CONFIG_MPC885=y CONFIG_MPC885=y
CONFIG_SMC_UCODE_PATCH=y
CONFIG_SMC2_RPBASE=0x1fc0
CONFIG_CMD_IMMAP=y CONFIG_CMD_IMMAP=y
CONFIG_SYS_SIUMCR=0x00620000 CONFIG_SYS_SIUMCR=0x00620000
CONFIG_SYS_TBSCR=0x00C3 CONFIG_SYS_TBSCR=0x00C3
@ -31,7 +33,6 @@ CONFIG_AUTOBOOT_STOP_STR_ENABLE=y
CONFIG_AUTOBOOT_STOP_STR_SHA256="4813494d137e1631bba301d5acab6e7bb7aa74ce1185d456565ef51d737677b2" CONFIG_AUTOBOOT_STOP_STR_SHA256="4813494d137e1631bba301d5acab6e7bb7aa74ce1185d456565ef51d737677b2"
CONFIG_USE_BOOTCOMMAND=y CONFIG_USE_BOOTCOMMAND=y
CONFIG_BOOTCOMMAND="run flashboot" CONFIG_BOOTCOMMAND="run flashboot"
CONFIG_BOARD_EARLY_INIT_R=y
CONFIG_MISC_INIT_R=y CONFIG_MISC_INIT_R=y
CONFIG_HUSH_PARSER=y CONFIG_HUSH_PARSER=y
# CONFIG_CMD_BDI is not set # CONFIG_CMD_BDI is not set

View file

@ -83,15 +83,18 @@ static int serial_mpc8xx_probe(struct udevice *dev)
immap_t __iomem *im = (immap_t __iomem *)CONFIG_SYS_IMMR; immap_t __iomem *im = (immap_t __iomem *)CONFIG_SYS_IMMR;
smc_t __iomem *sp; smc_t __iomem *sp;
smc_uart_t __iomem *up; smc_uart_t __iomem *up;
u16 smc_rpbase;
cpm8xx_t __iomem *cp = &(im->im_cpm); cpm8xx_t __iomem *cp = &(im->im_cpm);
struct serialbuffer __iomem *rtx; struct serialbuffer __iomem *rtx;
/* initialize pointers to SMC */ /* initialize pointers to SMC */
sp = cp->cp_smc + SMC_INDEX; sp = cp->cp_smc + SMC_INDEX;
up = (smc_uart_t __iomem *)&cp->cp_dparam[PROFF_SMC]; up = (smc_uart_t __iomem *)&cp->cp_dpmem[PROFF_SMC];
/* Disable relocation */
out_be16(&up->smc_rpbase, 0); smc_rpbase = in_be16(&up->smc_rpbase);
if (smc_rpbase)
up = (smc_uart_t __iomem *)&cp->cp_dpmem[smc_rpbase];
/* Disable transmitter/receiver. */ /* Disable transmitter/receiver. */
clrbits_be16(&sp->smc_smcmr, SMCMR_REN | SMCMR_TEN); clrbits_be16(&sp->smc_smcmr, SMCMR_REN | SMCMR_TEN);
@ -154,15 +157,12 @@ static int serial_mpc8xx_probe(struct udevice *dev)
out_be16(&up->smc_maxidl, CONFIG_SYS_MAXIDLE); out_be16(&up->smc_maxidl, CONFIG_SYS_MAXIDLE);
out_be32(&rtx->rxindex, 0); out_be32(&rtx->rxindex, 0);
/* Initialize Tx/Rx parameters. */ out_be32(&up->smc_rstate, 0);
while (in_be16(&cp->cp_cpcr) & CPM_CR_FLG) /* wait if cp is busy */ out_be32(&up->smc_tstate, 0);
; out_be16(&up->smc_rbptr, CPM_SERIAL_BASE);
out_be16(&up->smc_tbptr, CPM_SERIAL_BASE + sizeof(cbd_t));
out_be16(&cp->cp_cpcr, out_be16(&up->smc_brkcr, 1);
mk_cr_cmd(CPM_CR_CH_SMC, CPM_CR_INIT_TRX) | CPM_CR_FLG); out_be16(&up->smc_brkec, 0);
while (in_be16(&cp->cp_cpcr) & CPM_CR_FLG) /* wait if cp is busy */
;
/* Enable transmitter/receiver. */ /* Enable transmitter/receiver. */
setbits_be16(&sp->smc_smcmr, SMCMR_REN | SMCMR_TEN); setbits_be16(&sp->smc_smcmr, SMCMR_REN | SMCMR_TEN);

View file

@ -51,11 +51,13 @@ static int mpc8xx_spi_probe(struct udevice *dev)
{ {
immap_t __iomem *immr = (immap_t __iomem *)CONFIG_SYS_IMMR; immap_t __iomem *immr = (immap_t __iomem *)CONFIG_SYS_IMMR;
cpm8xx_t __iomem *cp = &immr->im_cpm; cpm8xx_t __iomem *cp = &immr->im_cpm;
spi_t __iomem *spi = (spi_t __iomem *)&cp->cp_dparam[PROFF_SPI]; spi_t __iomem *spi = (spi_t __iomem *)&cp->cp_dpmem[PROFF_SPI];
u16 spi_rpbase;
cbd_t __iomem *tbdf, *rbdf; cbd_t __iomem *tbdf, *rbdf;
/* Disable relocation */ spi_rpbase = in_be16(&spi->spi_rpbase);
out_be16(&spi->spi_rpbase, 0x1d80); if (spi_rpbase)
spi = (spi_t __iomem *)&cp->cp_dpmem[spi_rpbase];
/* 1 */ /* 1 */
/* Initialize the parameter ram. /* Initialize the parameter ram.

View file

@ -9,6 +9,7 @@
/* Definitions for initial stack pointer and data area (in DPRAM) */ /* Definitions for initial stack pointer and data area (in DPRAM) */
#define CFG_SYS_INIT_RAM_ADDR (CONFIG_SYS_IMMR + 0x2800) #define CFG_SYS_INIT_RAM_ADDR (CONFIG_SYS_IMMR + 0x2800)
#define CFG_SYS_INIT_RAM_SIZE (0x2e00 - 0x2800) #define CFG_SYS_INIT_RAM_SIZE (0x2e00 - 0x2800)
#define CFG_SYS_INIT_SP (CONFIG_SYS_IMMR + 0x3c00)
/* RAM configuration (note that CFG_SYS_SDRAM_BASE must be zero) */ /* RAM configuration (note that CFG_SYS_SDRAM_BASE must be zero) */
#define CFG_SYS_SDRAM_BASE 0x00000000 #define CFG_SYS_SDRAM_BASE 0x00000000

View file

@ -14,6 +14,7 @@
/* Definitions for initial stack pointer and data area (in DPRAM) */ /* Definitions for initial stack pointer and data area (in DPRAM) */
#define CFG_SYS_INIT_RAM_ADDR (CONFIG_SYS_IMMR + 0x2800) #define CFG_SYS_INIT_RAM_ADDR (CONFIG_SYS_IMMR + 0x2800)
#define CFG_SYS_INIT_RAM_SIZE (0x2e00 - 0x2800) #define CFG_SYS_INIT_RAM_SIZE (0x2e00 - 0x2800)
#define CFG_SYS_INIT_SP (CONFIG_SYS_IMMR + 0x3c00)
/* RAM configuration (note that CFG_SYS_SDRAM_BASE must be zero) */ /* RAM configuration (note that CFG_SYS_SDRAM_BASE must be zero) */
#define CFG_SYS_SDRAM_BASE 0x00000000 #define CFG_SYS_SDRAM_BASE 0x00000000