| /* |
| * This file is subject to the terms and conditions of the GNU General Public |
| * License. See the file "COPYING" in the main directory of this archive |
| * for more details. |
| * |
| * Copyright (C) 2008 Maxime Bizon <mbizon@freebox.fr> |
| */ |
| |
| #include <linux/init.h> |
| #include <linux/kernel.h> |
| #include <linux/platform_device.h> |
| #include <bcm63xx_cpu.h> |
| |
| static struct resource uart_resources[] = { |
| { |
| .start = -1, /* filled at runtime */ |
| .end = -1, /* filled at runtime */ |
| .flags = IORESOURCE_MEM, |
| }, |
| { |
| .start = -1, /* filled at runtime */ |
| .flags = IORESOURCE_IRQ, |
| }, |
| }; |
| |
| static struct platform_device bcm63xx_uart_device = { |
| .name = "bcm63xx_uart", |
| .id = 0, |
| .num_resources = ARRAY_SIZE(uart_resources), |
| .resource = uart_resources, |
| }; |
| |
| int __init bcm63xx_uart_register(void) |
| { |
| uart_resources[0].start = bcm63xx_regset_address(RSET_UART0); |
| uart_resources[0].end = uart_resources[0].start; |
| uart_resources[0].end += RSET_UART_SIZE - 1; |
| uart_resources[1].start = bcm63xx_get_irq_number(IRQ_UART0); |
| return platform_device_register(&bcm63xx_uart_device); |
| } |
| arch_initcall(bcm63xx_uart_register); |