| /* |
| * PQ2ADS platform support |
| * |
| * Author: Kumar Gala <galak@kernel.crashing.org> |
| * Derived from: est8260_setup.c by Allen Curtis |
| * |
| * Copyright 2004 Freescale Semiconductor, Inc. |
| * |
| * This program is free software; you can redistribute it and/or modify it |
| * under the terms of the GNU General Public License as published by the |
| * Free Software Foundation; either version 2 of the License, or (at your |
| * option) any later version. |
| */ |
| |
| #include <linux/init.h> |
| |
| #include <asm/io.h> |
| #include <asm/mpc8260.h> |
| #include <asm/cpm2.h> |
| #include <asm/immap_cpm2.h> |
| |
| void __init |
| m82xx_board_setup(void) |
| { |
| cpm2_map_t* immap = ioremap(CPM_MAP_ADDR, sizeof(cpm2_map_t)); |
| u32 *bcsr = ioremap(BCSR_ADDR+4, sizeof(u32)); |
| |
| /* Enable the 2nd UART port */ |
| clrbits32(bcsr, BCSR1_RS232_EN2); |
| |
| #ifdef CONFIG_SERIAL_CPM_SCC1 |
| clrbits32((u32*)&immap->im_scc[0].scc_sccm, UART_SCCM_TX | UART_SCCM_RX); |
| clrbits32((u32*)&immap->im_scc[0].scc_gsmrl, SCC_GSMRL_ENR | SCC_GSMRL_ENT); |
| #endif |
| |
| #ifdef CONFIG_SERIAL_CPM_SCC2 |
| clrbits32((u32*)&immap->im_scc[1].scc_sccm, UART_SCCM_TX | UART_SCCM_RX); |
| clrbits32((u32*)&immap->im_scc[1].scc_gsmrl, SCC_GSMRL_ENR | SCC_GSMRL_ENT); |
| #endif |
| |
| #ifdef CONFIG_SERIAL_CPM_SCC3 |
| clrbits32((u32*)&immap->im_scc[2].scc_sccm, UART_SCCM_TX | UART_SCCM_RX); |
| clrbits32((u32*)&immap->im_scc[2].scc_gsmrl, SCC_GSMRL_ENR | SCC_GSMRL_ENT); |
| #endif |
| |
| #ifdef CONFIG_SERIAL_CPM_SCC4 |
| clrbits32((u32*)&immap->im_scc[3].scc_sccm, UART_SCCM_TX | UART_SCCM_RX); |
| clrbits32((u32*)&immap->im_scc[3].scc_gsmrl, SCC_GSMRL_ENR | SCC_GSMRL_ENT); |
| #endif |
| |
| iounmap(bcsr); |
| iounmap(immap); |
| } |