forked from len0rd/rockbox
		
	git-svn-id: svn://svn.rockbox.org/rockbox/trunk@15427 a1c6a512-1295-4272-9138-f99709370657
		
			
				
	
	
		
			175 lines
		
	
	
	
		
			7.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			175 lines
		
	
	
	
		
			7.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /***************************************************************************
 | |
|  *             __________               __   ___.
 | |
|  *   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
 | |
|  *   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
 | |
|  *   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
 | |
|  *   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
 | |
|  *                     \/            \/     \/    \/            \/
 | |
|  * $Id$
 | |
|  *
 | |
|  * Copyright (C) 2004 by Thom Johansen 
 | |
|  *
 | |
|  * All files in this archive are subject to the GNU General Public License.
 | |
|  * See the file COPYING in the source tree root for full license agreement.
 | |
|  *
 | |
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
 | |
|  * KIND, either express or implied.
 | |
|  *
 | |
|  ****************************************************************************/
 | |
| #ifndef __PP5002_H__
 | |
| #define __PP5002_H__
 | |
| 
 | |
| /* Much info gleaned and/or copied from the iPodLinux project. */
 | |
| #define DRAM_START       0x28000000
 | |
| 
 | |
| /* LCD bridge */
 | |
| #define LCD1_BASE        0xc0001000
 | |
| 
 | |
| #define LCD1_CONTROL     (*(volatile unsigned long *)(0xc0001000))
 | |
| #define LCD1_CMD         (*(volatile unsigned long *)(0xc0001008))
 | |
| #define LCD1_DATA        (*(volatile unsigned long *)(0xc0001010))
 | |
| 
 | |
| #define LCD1_BUSY_MASK   0x8000
 | |
| 
 | |
| /* I2S controller */
 | |
| #define IISCONFIG        (*(volatile unsigned long *)(0xc0002500))
 | |
| #define IISFIFO_CFG      (*(volatile unsigned long *)(0xc000251c))
 | |
| #define IISFIFO_WR       (*(volatile unsigned long *)(0xc0002540))
 | |
| #define IISFIFO_RD       (*(volatile unsigned long *)(0xc0002580))
 | |
| 
 | |
| /* IISCONFIG bits: */
 | |
| #define IIS_TXFIFOEN      (1 << 2)
 | |
| #define IIS_TX_FREE_MASK  (0xf << 23)
 | |
| #define IIS_TX_FREE_COUNT ((IISFIFO_CFG & IIS_TX_FREE_MASK) >> 23)
 | |
| 
 | |
| /* IISFIFO_CFG bits: */
 | |
| #define IIS_IRQTX_REG    IISFIFO_CFG
 | |
| #define IIS_IRQTX        (1 << 9)
 | |
| 
 | |
| #define IDE_BASE         0xc0003000
 | |
| 
 | |
| #define IDE_CFG_STATUS   (*(volatile unsigned long *)(0xc0003024))
 | |
| 
 | |
| #define USB_BASE         0xc0005000
 | |
| 
 | |
| #define I2C_BASE         0xc0008000
 | |
| 
 | |
| /* Processor ID */
 | |
| #define PROCESSOR_ID     (*(volatile unsigned long *)(0xc4000000))
 | |
| 
 | |
| #define PROC_ID_CPU      0x55
 | |
| #define PROC_ID_COP      0xaa
 | |
| 
 | |
| #define GPIOA_ENABLE     (*(volatile unsigned char *)(0xcf000000))
 | |
| #define GPIOB_ENABLE     (*(volatile unsigned char *)(0xcf000004))
 | |
| #define GPIOC_ENABLE     (*(volatile unsigned char *)(0xcf000008))
 | |
| #define GPIOD_ENABLE     (*(volatile unsigned char *)(0xcf00000c))
 | |
| #define GPIOA_OUTPUT_EN  (*(volatile unsigned char *)(0xcf000010))
 | |
| #define GPIOB_OUTPUT_EN  (*(volatile unsigned char *)(0xcf000014))
 | |
| #define GPIOC_OUTPUT_EN  (*(volatile unsigned char *)(0xcf000018))
 | |
| #define GPIOD_OUTPUT_EN  (*(volatile unsigned char *)(0xcf00001c))
 | |
| #define GPIOA_OUTPUT_VAL (*(volatile unsigned char *)(0xcf000020))
 | |
| #define GPIOB_OUTPUT_VAL (*(volatile unsigned char *)(0xcf000024))
 | |
| #define GPIOC_OUTPUT_VAL (*(volatile unsigned char *)(0xcf000028))
 | |
| #define GPIOD_OUTPUT_VAL (*(volatile unsigned char *)(0xcf00002c))
 | |
| #define GPIOA_INPUT_VAL  (*(volatile unsigned char *)(0xcf000030))
 | |
| #define GPIOB_INPUT_VAL  (*(volatile unsigned char *)(0xcf000034))
 | |
| #define GPIOC_INPUT_VAL  (*(volatile unsigned char *)(0xcf000038))
 | |
| #define GPIOD_INPUT_VAL  (*(volatile unsigned char *)(0xcf00003c))
 | |
| #define GPIOA_INT_STAT   (*(volatile unsigned char *)(0xcf000040))
 | |
| #define GPIOB_INT_STAT   (*(volatile unsigned char *)(0xcf000044))
 | |
| #define GPIOC_INT_STAT   (*(volatile unsigned char *)(0xcf000048))
 | |
| #define GPIOD_INT_STAT   (*(volatile unsigned char *)(0xcf00004c))
 | |
| #define GPIOA_INT_EN     (*(volatile unsigned char *)(0xcf000050))
 | |
| #define GPIOB_INT_EN     (*(volatile unsigned char *)(0xcf000054))
 | |
| #define GPIOC_INT_EN     (*(volatile unsigned char *)(0xcf000058))
 | |
| #define GPIOD_INT_EN     (*(volatile unsigned char *)(0xcf00005c))
 | |
| #define GPIOA_INT_LEV    (*(volatile unsigned char *)(0xcf000060))
 | |
| #define GPIOB_INT_LEV    (*(volatile unsigned char *)(0xcf000064))
 | |
| #define GPIOC_INT_LEV    (*(volatile unsigned char *)(0xcf000068))
 | |
| #define GPIOD_INT_LEV    (*(volatile unsigned char *)(0xcf00006c))
 | |
| #define GPIOA_INT_CLR    (*(volatile unsigned char *)(0xcf000070))
 | |
| #define GPIOB_INT_CLR    (*(volatile unsigned char *)(0xcf000074))
 | |
| #define GPIOC_INT_CLR    (*(volatile unsigned char *)(0xcf000078))
 | |
| #define GPIOD_INT_CLR    (*(volatile unsigned char *)(0xcf00007c))
 | |
| 
 | |
| #define INT_FORCED_CLR   (*(volatile unsigned long *)(0xcf00101c))
 | |
| #define CPU_INT_STAT     (*(volatile unsigned long *)(0xcf001000))
 | |
| #define CPU_INT_EN       (*(volatile unsigned long *)(0xcf001024))
 | |
| #define CPU_INT_CLR      (*(volatile unsigned long *)(0xcf001028))
 | |
| #define CPU_INT_PRIORITY (*(volatile unsigned long *)(0xcf00102c))
 | |
| #define COP_INT_STAT     (*(volatile unsigned long *)(0xcf001010))
 | |
| #define COP_INT_EN       (*(volatile unsigned long *)(0xcf001034))
 | |
| #define COP_INT_CLR      (*(volatile unsigned long *)(0xcf001038))
 | |
| #define COP_INT_PRIORITY (*(volatile unsigned long *)(0xcf00103c))
 | |
| 
 | |
| #define IDE_IRQ          1
 | |
| #define SER0_IRQ         4
 | |
| #define I2S_IRQ          5
 | |
| #define SER1_IRQ         7
 | |
| #define TIMER1_IRQ      11
 | |
| #define TIMER2_IRQ      12
 | |
| #define GPIO_IRQ        14
 | |
| #define DMA_OUT_IRQ     30
 | |
| #define DMA_IN_IRQ      31
 | |
| 
 | |
| #define IDE_MASK         (1 << IDE_IRQ)
 | |
| #define SER0_MASK        (1 << SER0_IRQ)
 | |
| #define I2S_MASK         (1 << I2S_IRQ)
 | |
| #define SER1_MASK        (1 << SER1_IRQ)
 | |
| #define TIMER1_MASK      (1 << TIMER1_IRQ)
 | |
| #define TIMER2_MASK      (1 << TIMER2_IRQ)
 | |
| #define GPIO_MASK        (1 << GPIO_IRQ)
 | |
| #define DMA_OUT_MASK     (1 << DMA_OUT_IRQ)
 | |
| #define DMA_IN_MASK      (1 << DMA_IN_IRQ)
 | |
| 
 | |
| /* Yes, there is I2S_MASK but this cleans up the pcm code */
 | |
| #define IIS_MASK         DMA_OUT_MASK
 | |
| 
 | |
| #define TIMER1_CFG       (*(volatile unsigned long *)(0xcf001100))
 | |
| #define TIMER1_VAL       (*(volatile unsigned long *)(0xcf001104))
 | |
| #define TIMER2_CFG       (*(volatile unsigned long *)(0xcf001108))
 | |
| #define TIMER2_VAL       (*(volatile unsigned long *)(0xcf00110c))
 | |
| 
 | |
| #define USEC_TIMER       (*(volatile unsigned long *)(0xcf001110))
 | |
| 
 | |
| #define TIMING1_CTL      (*(volatile unsigned long *)(0xcf004000))
 | |
| #define TIMING2_CTL      (*(volatile unsigned long *)(0xcf004008))
 | |
| 
 | |
| #define PP_VER1          (*(volatile unsigned long *)(0xcf004030))
 | |
| #define PP_VER2          (*(volatile unsigned long *)(0xcf004034))
 | |
| #define PP_VER3          (*(volatile unsigned long *)(0xcf004038))
 | |
| #define PP_VER4          (*(volatile unsigned long *)(0xcf00403c))
 | |
| 
 | |
| #define CPU_CTL          (*(volatile unsigned char *)(0xcf004054))
 | |
| #define COP_CTL          (*(volatile unsigned char *)(0xcf004058))
 | |
| 
 | |
| #define PROC_CTL(core)   ((&CPU_CTL)[(core)*4])
 | |
| 
 | |
| #define PROC_SLEEP       0xca
 | |
| #define PROC_WAKE        0xce
 | |
| 
 | |
| 
 | |
| #define DEV_EN           (*(volatile unsigned long *)(0xcf005000))
 | |
| #define DEV_RS           (*(volatile unsigned long *)(0xcf005030))
 | |
| 
 | |
| #define DEV_I2C          (1<<8)
 | |
| #define DEV_USB          0x400000
 | |
| 
 | |
| #define CLOCK_ENABLE     (*(volatile unsigned long *)(0xcf005008))
 | |
| #define CLOCK_SOURCE     (*(volatile unsigned long *)(0xcf00500c))
 | |
| #define PLL_CONTROL      (*(volatile unsigned long *)(0xcf005010))
 | |
| #define PLL_DIV          (*(volatile unsigned long *)(0xcf005018))
 | |
| #define PLL_MULT         (*(volatile unsigned long *)(0xcf00501c))
 | |
| #define PLL_UNLOCK       (*(volatile unsigned long *)(0xcf005038))
 | |
| 
 | |
| #define MMAP0_LOGICAL    (*(volatile unsigned long *)(0xf000f000))
 | |
| #define MMAP0_PHYSICAL   (*(volatile unsigned long *)(0xf000f004))
 | |
| #define MMAP1_LOGICAL    (*(volatile unsigned long *)(0xf000f008))
 | |
| #define MMAP1_PHYSICAL   (*(volatile unsigned long *)(0xf000f00c))
 | |
| #define MMAP2_LOGICAL    (*(volatile unsigned long *)(0xf000f010))
 | |
| #define MMAP2_PHYSICAL   (*(volatile unsigned long *)(0xf000f014))
 | |
| #define MMAP3_LOGICAL    (*(volatile unsigned long *)(0xf000f018))
 | |
| #define MMAP3_PHYSICAL   (*(volatile unsigned long *)(0xf000f01c))
 | |
| 
 | |
| #endif
 |