diff options
Diffstat (limited to 'target/linux/ifxmips/files/arch/mips')
6 files changed, 90 insertions, 67 deletions
diff --git a/target/linux/ifxmips/files/arch/mips/ifxmips/Kconfig b/target/linux/ifxmips/files/arch/mips/ifxmips/Kconfig index d4e96af32..621020f83 100644 --- a/target/linux/ifxmips/files/arch/mips/ifxmips/Kconfig +++ b/target/linux/ifxmips/files/arch/mips/ifxmips/Kconfig @@ -18,6 +18,10 @@ config IFXMIPS_MEI bool "IFXMips mei" default y +config IFXMIPS_GPIO_RST_BTN + bool "Reset Button" + default y + choice prompt "prom_printf ASC" help diff --git a/target/linux/ifxmips/files/arch/mips/ifxmips/board.c b/target/linux/ifxmips/files/arch/mips/ifxmips/board.c index 8d12ebdaf..b7e0387e3 100644 --- a/target/linux/ifxmips/files/arch/mips/ifxmips/board.c +++ b/target/linux/ifxmips/files/arch/mips/ifxmips/board.c @@ -30,7 +30,9 @@ #include <asm/time.h> #include <asm/irq.h> #include <asm/io.h> +#include <linux/etherdevice.h> #include <asm/ifxmips/ifxmips.h> +#include <asm/ifxmips/ifxmips_mii0.h> #define MAX_IFXMIPS_DEVS 9 @@ -42,10 +44,13 @@ static unsigned int chiprev; static struct platform_device *ifxmips_devs[MAX_IFXMIPS_DEVS]; +static int cmdline_mac = 0; spinlock_t ebu_lock = SPIN_LOCK_UNLOCKED; EXPORT_SYMBOL_GPL(ebu_lock); +static struct ifxmips_mac ifxmips_mii_mac; + static struct platform_device ifxmips_led[] = { @@ -70,6 +75,9 @@ ifxmips_mii[] = { .id = 0, .name = "ifxmips_mii0", + .dev = { + .platform_data = &ifxmips_mii_mac, + } }, }; @@ -82,11 +90,6 @@ ifxmips_wdt[] = }, }; -static struct physmap_flash_data -ifxmips_mtd_data = { - .width = 2, -}; - static struct resource ifxmips_mtd_resource = { .start = IFXMIPS_FLASH_START, @@ -100,9 +103,6 @@ ifxmips_mtd[] = { .id = 0, .name = "ifxmips_mtd", - .dev = { - .platform_data = &ifxmips_mtd_data, - }, .num_resources = 1, .resource = &ifxmips_mtd_resource, }, @@ -148,11 +148,40 @@ get_system_type(void) return BOARD_SYSTEM_TYPE; } +#define IS_HEX(x) (((x >='0' && x <= '9') || (x >='a' && x <= 'f') || (x >='A' && x <= 'F'))?(1):(0)) +static int __init +ifxmips_set_mii0_mac(char *str) +{ + int i; + str = strchr(str, '='); + if(!str) + goto out; + str++; + if(strlen(str) != 17) + goto out; + for(i = 0; i < 6; i++) + { + if(!IS_HEX(str[3 * i]) || !IS_HEX(str[(3 * i) + 1])) + goto out; + if((i != 5) && (str[(3 * i) + 2] != ':')) + goto out; + ifxmips_mii_mac.mac[i] = simple_strtoul(&str[3 * i], NULL, 16); + } + if(is_valid_ether_addr(ifxmips_mii_mac.mac)) + cmdline_mac = 1; +out: + return 1; +} +__setup("mii0_mac", ifxmips_set_mii0_mac); + int __init ifxmips_init_devices(void) { int dev = 0; + if(!cmdline_mac) + random_ether_addr(ifxmips_mii_mac.mac); + ifxmips_devs[dev++] = ifxmips_led; ifxmips_devs[dev++] = ifxmips_gpio; ifxmips_devs[dev++] = ifxmips_mii; diff --git a/target/linux/ifxmips/files/arch/mips/ifxmips/clock.c b/target/linux/ifxmips/files/arch/mips/ifxmips/clock.c index d1e2ff4fa..c86b70cc0 100644 --- a/target/linux/ifxmips/files/arch/mips/ifxmips/clock.c +++ b/target/linux/ifxmips/files/arch/mips/ifxmips/clock.c @@ -429,3 +429,46 @@ void cgu_setup_pci_clk(int external_clock) ifxmips_w32((1 << 31) | (1 << 30), IFXMIPS_CGU_PCICR); } } + +unsigned int +ifxmips_get_ddr_hz(void) +{ + switch(ifxmips_r32(IFXMIPS_CGU_SYS) & 0x3) + { + case 0: + return CLOCK_167M; + case 1: + return CLOCK_133M; + case 2: + return CLOCK_111M; + } + return CLOCK_83M; +} +EXPORT_SYMBOL(ifxmips_get_ddr_hz); + +unsigned int +ifxmips_get_cpu_hz(void) +{ + unsigned int ddr_clock = ifxmips_get_ddr_hz(); + switch(ifxmips_r32(IFXMIPS_CGU_SYS) & 0xc) + { + case 0: + return CLOCK_333M; + case 4: + return ddr_clock; + } + return ddr_clock << 1; +} +EXPORT_SYMBOL(ifxmips_get_cpu_hz); + +unsigned int +ifxmips_get_fpi_hz(void) +{ + unsigned int ddr_clock = ifxmips_get_ddr_hz(); + if(ifxmips_r32(IFXMIPS_CGU_SYS) & 0x40) + return ddr_clock >> 1; + return ddr_clock; +} +EXPORT_SYMBOL(ifxmips_get_fpi_hz); + + diff --git a/target/linux/ifxmips/files/arch/mips/ifxmips/gpio.c b/target/linux/ifxmips/files/arch/mips/ifxmips/gpio.c index 931d3ac1d..01212d1ae 100644 --- a/target/linux/ifxmips/files/arch/mips/ifxmips/gpio.c +++ b/target/linux/ifxmips/files/arch/mips/ifxmips/gpio.c @@ -303,7 +303,7 @@ reset_button_poll(unsigned long unused) { struct event_t *event; - rst_button_timer.expires = jiffies + HZ; + rst_button_timer.expires = jiffies + (HZ / 4); add_timer(&rst_button_timer); if (pressed != ifxmips_port_get_input(IFXMIPS_RST_PORT, IFXMIPS_RST_PIN)) @@ -312,7 +312,6 @@ reset_button_poll(unsigned long unused) pressed = 0; else pressed = 1; - printk("reset button was %s\n", (pressed ? "pressed" : "released")); event = (struct event_t *) kzalloc(sizeof(struct event_t), GFP_ATOMIC); if (!event) { diff --git a/target/linux/ifxmips/files/arch/mips/ifxmips/interrupt.c b/target/linux/ifxmips/files/arch/mips/ifxmips/interrupt.c index e7557cef6..b47074d79 100644 --- a/target/linux/ifxmips/files/arch/mips/ifxmips/interrupt.c +++ b/target/linux/ifxmips/files/arch/mips/ifxmips/interrupt.c @@ -141,6 +141,7 @@ ifxmips_hw_irqdispatch(int module) if(irq == 0) return; + /* we need to do this due to a silicon bug */ irq = ls1bit32(irq); do_IRQ((int)irq + INT_NUM_IM0_IRL0 + (INT_NUM_IM_OFFSET * module)); diff --git a/target/linux/ifxmips/files/arch/mips/ifxmips/setup.c b/target/linux/ifxmips/files/arch/mips/ifxmips/setup.c index 7093b7f7e..a29a54d28 100644 --- a/target/linux/ifxmips/files/arch/mips/ifxmips/setup.c +++ b/target/linux/ifxmips/files/arch/mips/ifxmips/setup.c @@ -27,6 +27,7 @@ #include <asm/ifxmips/ifxmips.h> #include <asm/ifxmips/ifxmips_irq.h> #include <asm/ifxmips/ifxmips_pmu.h> +#include <asm/ifxmips/ifxmips_cgu.h> #include <asm/ifxmips/ifxmips_prom.h> static unsigned int r4k_offset; @@ -35,50 +36,9 @@ static unsigned int r4k_cur; extern void ifxmips_reboot_setup(void); unsigned int -ifxmips_get_ddr_hz(void) -{ - switch(ifxmips_r32(IFXMIPS_CGU_SYS) & 0x3) - { - case 0: - return CLOCK_167M; - case 1: - return CLOCK_133M; - case 2: - return CLOCK_111M; - } - return CLOCK_83M; -} -EXPORT_SYMBOL(ifxmips_get_ddr_hz); - -unsigned int -ifxmips_get_cpu_hz(void) -{ - unsigned int ddr_clock = ifxmips_get_ddr_hz(); - switch(ifxmips_r32(IFXMIPS_CGU_SYS) & 0xc) - { - case 0: - return CLOCK_333M; - case 4: - return ddr_clock; - } - return ddr_clock << 1; -} -EXPORT_SYMBOL(ifxmips_get_cpu_hz); - -unsigned int -ifxmips_get_fpi_hz(void) -{ - unsigned int ddr_clock = ifxmips_get_ddr_hz(); - if(ifxmips_r32(IFXMIPS_CGU_SYS) & 0x40) - return ddr_clock >> 1; - return ddr_clock; -} -EXPORT_SYMBOL(ifxmips_get_fpi_hz); - -unsigned int ifxmips_get_cpu_ver(void) { - return ifxmips_r32(IFXMIPS_MCD_CHIPID) & 0xFFFFF000; + return (ifxmips_r32(IFXMIPS_MPS_CHIPID) & 0xF0000000) >> 28; } EXPORT_SYMBOL(ifxmips_get_cpu_ver); @@ -100,27 +60,15 @@ ifxmips_get_counter_resolution(void) return res; } -int -ifxmips_be_handler(struct pt_regs *regs, int is_fixup) -{ - /*TODO*/ - printk(KERN_ERR "TODO: BUS error\n"); - - return MIPS_BE_FATAL; -} - void __init plat_time_init(void) { mips_hpt_frequency = ifxmips_get_cpu_hz() / ifxmips_get_counter_resolution(); r4k_cur = (read_c0_count() + r4k_offset); write_c0_compare(r4k_cur); - ifxmips_pmu_enable(IFXMIPS_PMU_PWDCR_GPT | IFXMIPS_PMU_PWDCR_FPI); - ifxmips_w32(0x100, IFXMIPS_GPTU_GPT_CLC); - - ifxmips_w32(0xffff, IFXMIPS_GPTU_GPT_CAPREL); - ifxmips_w32(0x80C0, IFXMIPS_GPTU_GPT_T6CON); + ifxmips_pmu_enable(IFXMIPS_PMU_PWDCR_GPT | IFXMIPS_PMU_PWDCR_FPI); + ifxmips_w32(0x100, IFXMIPS_GPTU_GPT_CLC); // set clock divider to 1 } void __init @@ -134,7 +82,6 @@ plat_mem_setup(void) write_c0_status(status); ifxmips_reboot_setup(); - board_be_handler = &ifxmips_be_handler; ioport_resource.start = IOPORT_RESOURCE_START; ioport_resource.end = IOPORT_RESOURCE_END; |