| /* |
| * MPC5200 PSC serial console support. |
| * |
| * Author: Grant Likely <grant.likely@secretlab.ca> |
| * |
| * Copyright (c) 2007 Secret Lab Technologies Ltd. |
| * Copyright (c) 2007 Freescale Semiconductor, Inc. |
| * |
| * It is assumed that the firmware (or the platform file) has already set |
| * up the port. |
| */ |
| |
| #include "types.h" |
| #include "io.h" |
| #include "ops.h" |
| |
| /* Programmable Serial Controller (PSC) status register bits */ |
| #define MPC52xx_PSC_SR 0x04 |
| #define MPC52xx_PSC_SR_RXRDY 0x0100 |
| #define MPC52xx_PSC_SR_RXFULL 0x0200 |
| #define MPC52xx_PSC_SR_TXRDY 0x0400 |
| #define MPC52xx_PSC_SR_TXEMP 0x0800 |
| |
| #define MPC52xx_PSC_BUFFER 0x0C |
| |
| static void *psc; |
| |
| static int psc_open(void) |
| { |
| /* Assume the firmware has already configured the PSC into |
| * uart mode */ |
| return 0; |
| } |
| |
| static void psc_putc(unsigned char c) |
| { |
| while (!(in_be16(psc + MPC52xx_PSC_SR) & MPC52xx_PSC_SR_TXRDY)) ; |
| out_8(psc + MPC52xx_PSC_BUFFER, c); |
| } |
| |
| static unsigned char psc_tstc(void) |
| { |
| return (in_be16(psc + MPC52xx_PSC_SR) & MPC52xx_PSC_SR_RXRDY) != 0; |
| } |
| |
| static unsigned char psc_getc(void) |
| { |
| while (!(in_be16(psc + MPC52xx_PSC_SR) & MPC52xx_PSC_SR_RXRDY)) ; |
| return in_8(psc + MPC52xx_PSC_BUFFER); |
| } |
| |
| int mpc5200_psc_console_init(void *devp, struct serial_console_data *scdp) |
| { |
| int n; |
| |
| /* Get the base address of the psc registers */ |
| n = getprop(devp, "virtual-reg", &psc, sizeof(psc)); |
| if (n != sizeof(psc)) { |
| if (!dt_xlate_reg(devp, 0, (void *)&psc, NULL)) |
| return -1; |
| } |
| |
| scdp->open = psc_open; |
| scdp->putc = psc_putc; |
| scdp->getc = psc_getc; |
| scdp->tstc = psc_tstc; |
| |
| return 0; |
| } |