2 * arch/arm/mach-w90x900/cpu.h
4 * Based on linux/include/asm-arm/plat-s3c24xx/cpu.h by Ben Dooks
6 * Copyright (c) 2008 Nuvoton technology corporation
9 * Header file for NUC900 CPU support
11 * Wan ZongShun <mcuos.com@gmail.com>
13 * This program is free software; you can redistribute it and/or modify
14 * it under the terms of the GNU General Public License version 2 as
15 * published by the Free Software Foundation.
19 #define IODESC_ENT(y) \
21 .virtual = (unsigned long)W90X900_VA_##y, \
22 .pfn = __phys_to_pfn(W90X900_PA_##y), \
23 .length = W90X900_SZ_##y, \
27 #define NUC900_8250PORT(name) \
29 .membase = name##_BA, \
30 .mapbase = name##_PA, \
32 .uartclk = 11313600, \
35 .flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST, \
38 /*Cpu identifier register*/
40 #define NUC900PDID W90X900_VA_GCR
41 #define NUC910_CPUID 0x02900910
42 #define NUC920_CPUID 0x02900920
43 #define NUC950_CPUID 0x02900950
44 #define NUC960_CPUID 0x02900960
46 /* extern file from cpu.c */
48 extern void nuc900_clock_source(struct device *dev, unsigned char *src);
49 extern void nuc900_init_clocks(void);
50 extern void nuc900_map_io(struct map_desc *mach_desc, int mach_size);
51 extern void nuc900_board_init(struct platform_device **device, int size);
53 /* for either public between 910 and 920, or between 920 and 950 */
55 extern struct platform_device nuc900_serial_device;
56 extern struct platform_device nuc900_device_fmi;
57 extern struct platform_device nuc900_device_kpi;
58 extern struct platform_device nuc900_device_rtc;
59 extern struct platform_device nuc900_device_ts;
60 extern struct platform_device nuc900_device_lcd;