/*************************************************************************** * __________ __ ___. * Open \______ \ ____ ____ | | _\_ |__ _______ ___ * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ * \/ \/ \/ \/ \/ * $Id$ * * Copyright (C) 2008 by Maurus Cuelenaere * * 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. * * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY * KIND, either express or implied. * ****************************************************************************/ #ifndef __SYSTEM_TARGET_H_ #define __SYSTEM_TARGET_H_ #include #include "config.h" #include "cpu.h" #include "mipsregs.h" #define CACHE_SIZE 16*1024 #define CACHE_LINE_SIZE 32 #include "mmu-mips.h" #define CFG_UART_BASE UART1_BASE /* Base of the UART channel */ /* no optimized byteswap functions implemented for mips, yet */ #define NEED_GENERIC_BYTESWAPS #define STORAGE_WANTS_ALIGN /* This one returns the old status */ static inline int set_interrupt_status(int status, int mask) { unsigned int res, oldstatus; res = oldstatus = read_c0_status(); res &= ~mask; res |= (status & mask); write_c0_status(res); return oldstatus; } static inline void enable_interrupt(void) { /* Set IE bit */ set_c0_status(ST0_IE); } static inline void disable_interrupt(void) { /* Clear IE bit */ clear_c0_status(ST0_IE); } static inline int disable_interrupt_save(int mask) { return set_interrupt_status(0, mask); } static inline void restore_interrupt(int status) { write_c0_status(status); } #define disable_irq() disable_interrupt() #define enable_irq() enable_interrupt() #define HIGHEST_IRQ_LEVEL 0 #define set_irq_level(status) set_interrupt_status((status), ST0_IE) #define disable_irq_save() disable_interrupt_save(ST0_IE) #define restore_irq(c0_status) restore_interrupt(c0_status) #define UNCACHED_ADDRESS(addr) ((unsigned int)(addr) | 0xA0000000) #define UNCACHED_ADDR(x) UNCACHED_ADDRESS((x)) #define PHYSADDR(x) ((x) & 0x1fffffff) void system_enable_irq(unsigned int irq); void udelay(unsigned int usec); void mdelay(unsigned int msec); void dma_enable(void); void dma_disable(void); #if CONFIG_CPU == JZ4732 #define DMA_AIC_TX_CHANNEL 0 #define DMA_NAND_CHANNEL 1 #define DMA_USB_CHANNEL 2 #define DMA_LCD_CHANNEL 3 #elif CONFIG_CPU == JZ4760B #define DMA_AIC_TX_CHANNEL 0 #define DMA_USB_CHANNEL 1 // Note: channel 5 and 11 cannot be used! #define DMA_SD_RX_CHANNEL0 6 #define DMA_SD_RX_CHANNEL1 7 #define DMA_SD_TX_CHANNEL0 8 #define DMA_SD_TX_CHANNEL1 9 #define DMA_NAND_CHANNEL 10 #define DMA_SD_RX_CHANNEL(n) 6+n #define DMA_SD_TX_CHANNEL(n) 8+n #endif #define XDMA_CALLBACK(n) DMA ## n #define DMA_CALLBACK(n) XDMA_CALLBACK(n) #define DMA_IRQ(n) (IRQ_DMA_0 + (n)) #define GPIO_IRQ(n) (IRQ_GPIO_0 + (n)) /*--------------------------------------------------------------------------- * Put core in a power-saving state. *--------------------------------------------------------------------------- */ static inline void core_sleep(void) { #if CONFIG_CPU == JZ4732 || CONFIG_CPU == JZ4760B __cpm_idle_mode(); #endif asm volatile( ".set push \n" ".set mips32r2 \n" ".set noreorder \n" "mfc0 $8, $12 \n" /* mfc t0, $12 */ "move $9, $8 \n" /* move t1, t0 */ "la $10, 0x8000000 \n" /* la t2, 0x8000000 */ "or $8, $8, $10 \n" /* Enable reduced power mode */ "mtc0 $8, $12 \n" /* mtc t0, $12 */ "wait \n" "mtc0 $9, $12 \n" /* mtc t1, $12 */ ".set pop \n" ::: "t0", "t1", "t2" ); enable_irq(); } #endif /* __SYSTEM_TARGET_H_ */