/* * Copyright 2011 Freescale Semiconductor, Inc. * Copyright 2011 Linaro Ltd. * * The code contained herein is licensed under the GNU General Public * License. You may obtain a copy of the GNU General Public License * Version 2 or later at the following locations: * * http://www.opensource.org/licenses/gpl-license.html * http://www.gnu.org/copyleft/gpl.html */ #include #include #include #include #include "hardware.h" #define IMX6Q_UART1_BASE_ADDR 0x02020000 #define IMX6Q_UART2_BASE_ADDR 0x021e8000 #define IMX6Q_UART3_BASE_ADDR 0x021ec000 #define IMX6Q_UART4_BASE_ADDR 0x021f0000 #define IMX6Q_UART5_BASE_ADDR 0x021f4000 /* * IMX6Q_UART_BASE_ADDR is put in the middle to force the expansion * of IMX6Q_UART##n##_BASE_ADDR. */ #define IMX6Q_UART_BASE_ADDR(n) IMX6Q_UART##n##_BASE_ADDR #define IMX6Q_UART_BASE(n) IMX6Q_UART_BASE_ADDR(n) #define IMX6Q_DEBUG_UART_BASE IMX6Q_UART_BASE(CONFIG_DEBUG_IMX6Q_UART_PORT) static struct map_desc imx_lluart_desc = { #ifdef CONFIG_DEBUG_IMX6Q_UART .virtual = IMX_IO_P2V(IMX6Q_DEBUG_UART_BASE), .pfn = __phys_to_pfn(IMX6Q_DEBUG_UART_BASE), .length = 0x4000, .type = MT_DEVICE, #endif }; void __init imx_lluart_map_io(void) { if (imx_lluart_desc.virtual) iotable_init(&imx_lluart_desc, 1); }