| /* |
| * Copyright (C) 2009 Lemote Inc. |
| * Author: Wu Zhangjin, wuzhangjin@gmail.com |
| * |
| * 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/module.h> |
| #include <asm/bootinfo.h> |
| |
| #include <loongson.h> |
| |
| /* raw */ |
| unsigned long loongson_uart_base[MAX_UARTS] = {}; |
| /* ioremapped */ |
| unsigned long _loongson_uart_base[MAX_UARTS] = {}; |
| |
| EXPORT_SYMBOL(loongson_uart_base); |
| EXPORT_SYMBOL(_loongson_uart_base); |
| |
| void prom_init_loongson_uart_base(void) |
| { |
| switch (mips_machtype) { |
| case MACH_LOONGSON_GENERIC: |
| /* The CPU provided serial port (CPU) */ |
| loongson_uart_base[0] = LOONGSON_REG_BASE + 0x1e0; |
| break; |
| case MACH_LEMOTE_FL2E: |
| loongson_uart_base[0] = LOONGSON_PCIIO_BASE + 0x3f8; |
| break; |
| case MACH_LEMOTE_FL2F: |
| case MACH_LEMOTE_LL2F: |
| loongson_uart_base[0] = LOONGSON_PCIIO_BASE + 0x2f8; |
| break; |
| case MACH_LEMOTE_ML2F7: |
| case MACH_LEMOTE_YL2F89: |
| case MACH_DEXXON_GDIUM2F10: |
| case MACH_LEMOTE_NAS: |
| default: |
| /* The CPU provided serial port (LPC) */ |
| loongson_uart_base[0] = LOONGSON_LIO1_BASE + 0x3f8; |
| break; |
| } |
| |
| _loongson_uart_base[0] = |
| (unsigned long)ioremap_nocache(loongson_uart_base[0], 8); |
| } |