forked from Imagelibrary/rtems
2005-03-11 Philippe Simons <loki_666@fastmail.fm>
* Makefile.am, configure.ac: Added gp32 BSP. * s3c2400/.cvsignore, s3c2400/Makefile.am, s3c2400/clock/clockdrv.c, s3c2400/include/s3c2400.h, s3c2400/irq/bsp_irq_asm.S, s3c2400/irq/bsp_irq_init.c, s3c2400/irq/irq.c, s3c2400/irq/irq.h, s3c2400/timer/timer.c: New files.
This commit is contained in:
@@ -1,3 +1,11 @@
|
||||
2005-03-11 Philippe Simons <loki_666@fastmail.fm>
|
||||
|
||||
* Makefile.am, configure.ac: Added gp32 BSP.
|
||||
* s3c2400/.cvsignore, s3c2400/Makefile.am, s3c2400/clock/clockdrv.c,
|
||||
s3c2400/include/s3c2400.h, s3c2400/irq/bsp_irq_asm.S,
|
||||
s3c2400/irq/bsp_irq_init.c, s3c2400/irq/irq.c, s3c2400/irq/irq.h,
|
||||
s3c2400/timer/timer.c: New files.
|
||||
|
||||
2005-03-08 Jay Monkman <jtm@lopingdog.com>
|
||||
|
||||
* mc9328mxl/irq/irq.h: Fixed error in declaration of bsp_vector_table.
|
||||
|
||||
@@ -4,7 +4,7 @@
|
||||
|
||||
ACLOCAL_AMFLAGS = -I ../../../aclocal
|
||||
|
||||
SUBDIRS = shared at91rm9200 mc9328mxl
|
||||
SUBDIRS = shared at91rm9200 mc9328mxl s3c2400
|
||||
|
||||
all-local: $(TMPINSTALL_FILES)
|
||||
|
||||
|
||||
@@ -24,14 +24,17 @@ RTEMS_PROG_CCAS
|
||||
RTEMS_CHECK_CUSTOM_BSP(RTEMS_BSP)
|
||||
|
||||
AM_CONDITIONAL(shared, test "$RTEMS_CPU_MODEL" = "at91rm9200" || \
|
||||
test "$RTEMS_CPU_MODEL" = "mc9328mxl")
|
||||
test "$RTEMS_CPU_MODEL" = "mc9328mxl" || \
|
||||
test "$RTEMS_CPU_MODEL" = "s3c2400")
|
||||
AM_CONDITIONAL(at91rm9200, test "$RTEMS_CPU_MODEL" = "at91rm9200")
|
||||
AM_CONDITIONAL(mc9328mxl, test "$RTEMS_CPU_MODEL" = "mc9328mxl")
|
||||
AM_CONDITIONAL(s3c2400, test "$RTEMS_CPU_MODEL" = "s3c2400")
|
||||
|
||||
# Explicitly list all Makefiles here
|
||||
AC_CONFIG_FILES([Makefile
|
||||
shared/Makefile
|
||||
at91rm9200/Makefile
|
||||
mc9328mxl/Makefile
|
||||
s3c2400/Makefile
|
||||
])
|
||||
AC_OUTPUT
|
||||
|
||||
2
c/src/lib/libcpu/arm/s3c2400/.cvsignore
Normal file
2
c/src/lib/libcpu/arm/s3c2400/.cvsignore
Normal file
@@ -0,0 +1,2 @@
|
||||
Makefile.in
|
||||
Makefile
|
||||
71
c/src/lib/libcpu/arm/s3c2400/Makefile.am
Normal file
71
c/src/lib/libcpu/arm/s3c2400/Makefile.am
Normal file
@@ -0,0 +1,71 @@
|
||||
##
|
||||
## $Id$
|
||||
##
|
||||
|
||||
noinst_PROGRAMS =
|
||||
|
||||
include $(top_srcdir)/../../../automake/compile.am
|
||||
|
||||
if s3c2400
|
||||
include_s3c2400dir = $(includedir)/s3c2400
|
||||
include_libcpudir = $(includedir)/libcpu
|
||||
include_HEADERS = include/s3c2400.h
|
||||
|
||||
## clock
|
||||
noinst_PROGRAMS += clock.rel
|
||||
clock_rel_SOURCES = clock/clockdrv.c
|
||||
clock_rel_CPPFLAGS = $(AM_CPPFLAGS)
|
||||
clock_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)
|
||||
|
||||
## timer
|
||||
noinst_PROGRAMS += timer.rel
|
||||
timer_rel_SOURCES = timer/timer.c
|
||||
timer_rel_CPPFLAGS = $(AM_CPPFLAGS)
|
||||
timer_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)
|
||||
|
||||
## interrupt
|
||||
include_HEADERS += irq/irq.h
|
||||
|
||||
noinst_PROGRAMS += irq.rel
|
||||
irq_rel_SOURCES = irq/irq.c irq/bsp_irq_init.c \
|
||||
../../../libbsp/arm/shared/irq/irq_init.c irq/bsp_irq_asm.S \
|
||||
../../../libbsp/arm/shared/irq/irq_asm.S irq/irq.h
|
||||
irq_rel_CPPFLAGS = $(AM_CPPFLAGS)
|
||||
irq_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)
|
||||
endif
|
||||
|
||||
## --
|
||||
all-local: $(PREINSTALL_FILES)
|
||||
|
||||
PREINSTALL_DIRS =
|
||||
PREINSTALL_FILES =
|
||||
|
||||
$(PROJECT_INCLUDE)/$(dirstamp):
|
||||
@$(mkdir_p) $(PROJECT_INCLUDE)
|
||||
@: > $(PROJECT_INCLUDE)/$(dirstamp)
|
||||
PREINSTALL_DIRS += $(PROJECT_INCLUDE)/$(dirstamp)
|
||||
|
||||
if s3c2400
|
||||
$(PROJECT_INCLUDE)/s3c2400/$(dirstamp):
|
||||
@$(mkdir_p) $(PROJECT_INCLUDE)/s3c2400
|
||||
@: > $(PROJECT_INCLUDE)/s3c2400/$(dirstamp)
|
||||
PREINSTALL_DIRS += $(PROJECT_INCLUDE)/s3c2400/$(dirstamp)
|
||||
|
||||
$(PROJECT_INCLUDE)/libcpu/$(dirstamp):
|
||||
@$(mkdir_p) $(PROJECT_INCLUDE)/libcpu
|
||||
@: > $(PROJECT_INCLUDE)/libcpu/$(dirstamp)
|
||||
PREINSTALL_DIRS += $(PROJECT_INCLUDE)/libcpu/$(dirstamp)
|
||||
|
||||
$(PROJECT_INCLUDE)/s3c2400.h: include/s3c2400.h $(PROJECT_INCLUDE)/$(dirstamp)
|
||||
$(INSTALL_DATA) $< $(PROJECT_INCLUDE)/s3c2400.h
|
||||
PREINSTALL_FILES += $(PROJECT_INCLUDE)/s3c2400.h
|
||||
|
||||
$(PROJECT_INCLUDE)/irq.h: irq/irq.h $(PROJECT_INCLUDE)/$(dirstamp)
|
||||
$(INSTALL_DATA) $< $(PROJECT_INCLUDE)/irq.h
|
||||
PREINSTALL_FILES += $(PROJECT_INCLUDE)/irq.h
|
||||
endif
|
||||
|
||||
CLEANFILES = $(PREINSTALL_FILES)
|
||||
DISTCLEANFILES = $(PREINSTALL_DIRS)
|
||||
|
||||
include $(top_srcdir)/../../../automake/local.am
|
||||
142
c/src/lib/libcpu/arm/s3c2400/clock/clockdrv.c
Normal file
142
c/src/lib/libcpu/arm/s3c2400/clock/clockdrv.c
Normal file
@@ -0,0 +1,142 @@
|
||||
/*
|
||||
* S3C2400 clock specific using the System Timer
|
||||
*
|
||||
* This is hardware specific part of the clock driver. At the end of this
|
||||
* file, the generic part of the driver is #included.
|
||||
*
|
||||
* The license and distribution terms for this file may be
|
||||
* found in the file LICENSE in this distribution or at
|
||||
*
|
||||
* http://www.OARcorp.com/rtems/license.html.
|
||||
*
|
||||
*
|
||||
* $Id$
|
||||
*/
|
||||
#include <rtems.h>
|
||||
#include <irq.h>
|
||||
#include <bsp.h>
|
||||
#include <s3c2400.h>
|
||||
|
||||
/* this is defined in ../../../shared/clockdrv_shell.c */
|
||||
rtems_isr Clock_isr(rtems_vector_number vector);
|
||||
static void clock_isr_on(const rtems_irq_connect_data *unused);
|
||||
static void clock_isr_off(const rtems_irq_connect_data *unused);
|
||||
static int clock_isr_is_on(const rtems_irq_connect_data *irq);
|
||||
|
||||
/* Replace the first value with the clock's interrupt name. */
|
||||
rtems_irq_connect_data clock_isr_data = {BSP_INT_TIMER4,
|
||||
(rtems_irq_hdl)Clock_isr,
|
||||
clock_isr_on,
|
||||
clock_isr_off,
|
||||
clock_isr_is_on,
|
||||
3, /* unused for ARM cpus */
|
||||
0 }; /* unused for ARM cpus */
|
||||
|
||||
/* If you follow the code, this is never used, so any value
|
||||
* should work
|
||||
*/
|
||||
#define CLOCK_VECTOR 0
|
||||
|
||||
|
||||
/**
|
||||
* When we get the clock interrupt
|
||||
* - clear the interrupt bit?
|
||||
* - restart the timer?
|
||||
*/
|
||||
#define Clock_driver_support_at_tick() \
|
||||
do { \
|
||||
ClearPending(BIT_TIMER4); \
|
||||
} while(0)
|
||||
|
||||
|
||||
/**
|
||||
* Installs the clock ISR. You shouldn't need to change this.
|
||||
*/
|
||||
#define Clock_driver_support_install_isr( _new, _old ) \
|
||||
do { \
|
||||
BSP_install_rtems_irq_handler(&clock_isr_data); \
|
||||
} while(0)
|
||||
|
||||
|
||||
/**
|
||||
* Initialize the hardware for the clock
|
||||
* - Set the frequency
|
||||
* - enable it
|
||||
* - clear any pending interrupts
|
||||
*
|
||||
* Since you may want the clock always running, you can
|
||||
* enable interrupts here. If you do so, the clock_isr_on(),
|
||||
* clock_isr_off(), and clock_isr_is_on() functions can be
|
||||
* NOPs.
|
||||
*/
|
||||
#define Clock_driver_support_initialize_hardware() \
|
||||
do { \
|
||||
uint32_t cr; \
|
||||
uint32_t freq,m,p,s; \
|
||||
/* set MUX for Timer4 to 1/16 */ \
|
||||
cr=rTCFG1 & 0xFFF0FFFF; \
|
||||
rTCFG1=(cr | (3<<16)); \
|
||||
/* compute MPLL freq */ \
|
||||
m = M_MDIV + 8; \
|
||||
p = M_PDIV + 2; \
|
||||
s = M_SDIV; \
|
||||
freq =(BSP_OSC_FREQ * m) / (p << s); \
|
||||
/* PCLK = MPLL/4 */ \
|
||||
freq = freq / 4; \
|
||||
/* set TIMER4 counter, input freq=PLCK/16/16Mhz*/ \
|
||||
freq = (freq /16)/16; \
|
||||
rTCNTB4 = ((freq / 1000) * BSP_Configuration.microseconds_per_tick) / 1000; \
|
||||
/*unmask TIMER4 irq*/ \
|
||||
rINTMSK&=~BIT_TIMER4; \
|
||||
/* start TIMER4 with autoreload */ \
|
||||
cr=rTCON & 0xFF8FFFFF; \
|
||||
rTCON=(cr|(0x6<<20)); \
|
||||
rTCON=(cr|(0x5<<20)); \
|
||||
} while (0)
|
||||
|
||||
/**
|
||||
* Do whatever you need to shut the clock down and remove the
|
||||
* interrupt handler. Since this normally only gets called on
|
||||
* RTEMS shutdown, you may not need to do anything other than
|
||||
* remove the ISR.
|
||||
*/
|
||||
#define Clock_driver_support_shutdown_hardware() \
|
||||
do { \
|
||||
/* Disable timer */ \
|
||||
BSP_remove_rtems_irq_handler(&clock_isr_data); \
|
||||
} while (0)
|
||||
|
||||
/**
|
||||
* Enables clock interrupt.
|
||||
*
|
||||
* If the interrupt is always on, this can be a NOP.
|
||||
*/
|
||||
static void clock_isr_on(const rtems_irq_connect_data *unused)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
/**
|
||||
* Disables clock interrupts
|
||||
*
|
||||
* If the interrupt is always on, this can be a NOP.
|
||||
*/
|
||||
static void clock_isr_off(const rtems_irq_connect_data *unused)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests to see if clock interrupt is enabled, and returns 1 if so.
|
||||
* If interrupt is not enabled, returns 0.
|
||||
*
|
||||
* If the interrupt is always on, this always returns 1.
|
||||
*/
|
||||
static int clock_isr_is_on(const rtems_irq_connect_data *irq)
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
/* Make sure to include this, and only at the end of the file */
|
||||
#include "../../../../libbsp/shared/clockdrv_shell.c"
|
||||
444
c/src/lib/libcpu/arm/s3c2400/include/s3c2400.h
Normal file
444
c/src/lib/libcpu/arm/s3c2400/include/s3c2400.h
Normal file
@@ -0,0 +1,444 @@
|
||||
/************************************************
|
||||
* NAME : s3c2400.h
|
||||
* Version : 3.7.2002
|
||||
*
|
||||
* Based on 24x.h for the Samsung Development Board
|
||||
************************************************/
|
||||
|
||||
#ifndef __S3C2400_H__
|
||||
#define __S3C2400_H__
|
||||
|
||||
/* Memory control */
|
||||
#define rBWSCON (*(volatile unsigned *)0x14000000)
|
||||
#define rBANKCON0 (*(volatile unsigned *)0x14000004)
|
||||
#define rBANKCON1 (*(volatile unsigned *)0x14000008)
|
||||
#define rBANKCON2 (*(volatile unsigned *)0x1400000C)
|
||||
#define rBANKCON3 (*(volatile unsigned *)0x14000010)
|
||||
#define rBANKCON4 (*(volatile unsigned *)0x14000014)
|
||||
#define rBANKCON5 (*(volatile unsigned *)0x14000018)
|
||||
#define rBANKCON6 (*(volatile unsigned *)0x1400001C)
|
||||
#define rBANKCON7 (*(volatile unsigned *)0x14000020)
|
||||
#define rREFRESH (*(volatile unsigned *)0x14000024)
|
||||
#define rBANKSIZE (*(volatile unsigned *)0x14000028)
|
||||
#define rMRSRB6 (*(volatile unsigned *)0x1400002C)
|
||||
#define rMRSRB7 (*(volatile unsigned *)0x14000030)
|
||||
|
||||
|
||||
/* INTERRUPT */
|
||||
#define rSRCPND (*(volatile unsigned *)0x14400000)
|
||||
#define rINTMOD (*(volatile unsigned *)0x14400004)
|
||||
#define rINTMSK (*(volatile unsigned *)0x14400008)
|
||||
#define rPRIORITY (*(volatile unsigned *)0x1440000C)
|
||||
#define rINTPND (*(volatile unsigned *)0x14400010)
|
||||
#define rINTOFFSET (*(volatile unsigned *)0x14400014)
|
||||
|
||||
|
||||
/* DMA */
|
||||
#define rDISRC0 (*(volatile unsigned *)0x14600000)
|
||||
#define rDIDST0 (*(volatile unsigned *)0x14600004)
|
||||
#define rDCON0 (*(volatile unsigned *)0x14600008)
|
||||
#define rDSTAT0 (*(volatile unsigned *)0x1460000C)
|
||||
#define rDCSRC0 (*(volatile unsigned *)0x14600010)
|
||||
#define rDCDST0 (*(volatile unsigned *)0x14600014)
|
||||
#define rDMASKTRIG0 (*(volatile unsigned *)0x14600018)
|
||||
#define rDISRC1 (*(volatile unsigned *)0x14600020)
|
||||
#define rDIDST1 (*(volatile unsigned *)0x14600024)
|
||||
#define rDCON1 (*(volatile unsigned *)0x14600028)
|
||||
#define rDSTAT1 (*(volatile unsigned *)0x1460002C)
|
||||
#define rDCSRC1 (*(volatile unsigned *)0x14600030)
|
||||
#define rDCDST1 (*(volatile unsigned *)0x14600034)
|
||||
#define rDMASKTRIG1 (*(volatile unsigned *)0x14600038)
|
||||
#define rDISRC2 (*(volatile unsigned *)0x14600040)
|
||||
#define rDIDST2 (*(volatile unsigned *)0x14600044)
|
||||
#define rDCON2 (*(volatile unsigned *)0x14600048)
|
||||
#define rDSTAT2 (*(volatile unsigned *)0x1460004C)
|
||||
#define rDCSRC2 (*(volatile unsigned *)0x14600050)
|
||||
#define rDCDST2 (*(volatile unsigned *)0x14600054)
|
||||
#define rDMASKTRIG2 (*(volatile unsigned *)0x14600058)
|
||||
#define rDISRC3 (*(volatile unsigned *)0x14600060)
|
||||
#define rDIDST3 (*(volatile unsigned *)0x14600064)
|
||||
#define rDCON3 (*(volatile unsigned *)0x14600068)
|
||||
#define rDSTAT3 (*(volatile unsigned *)0x1460006C)
|
||||
#define rDCSRC3 (*(volatile unsigned *)0x14600070)
|
||||
#define rDCDST3 (*(volatile unsigned *)0x14600074)
|
||||
#define rDMASKTRIG3 (*(volatile unsigned *)0x14600078)
|
||||
|
||||
|
||||
/* CLOCK & POWER MANAGEMENT */
|
||||
#define rLOCKTIME (*(volatile unsigned *)0x14800000)
|
||||
#define rMPLLCON (*(volatile unsigned *)0x14800004)
|
||||
#define rUPLLCON (*(volatile unsigned *)0x14800008)
|
||||
#define rCLKCON (*(volatile unsigned *)0x1480000C)
|
||||
#define rCLKSLOW (*(volatile unsigned *)0x14800010)
|
||||
#define rCLKDIVN (*(volatile unsigned *)0x14800014)
|
||||
|
||||
|
||||
/* LCD CONTROLLER */
|
||||
#define rLCDCON1 (*(volatile unsigned *)0x14A00000)
|
||||
#define rLCDCON2 (*(volatile unsigned *)0x14A00004)
|
||||
#define rLCDCON3 (*(volatile unsigned *)0x14A00008)
|
||||
#define rLCDCON4 (*(volatile unsigned *)0x14A0000C)
|
||||
#define rLCDCON5 (*(volatile unsigned *)0x14A00010)
|
||||
#define rLCDSADDR1 (*(volatile unsigned *)0x14A00014)
|
||||
#define rLCDSADDR2 (*(volatile unsigned *)0x14A00018)
|
||||
#define rLCDSADDR3 (*(volatile unsigned *)0x14A0001C)
|
||||
#define rREDLUT (*(volatile unsigned *)0x14A00020)
|
||||
#define rGREENLUT (*(volatile unsigned *)0x14A00024)
|
||||
#define rBLUELUT (*(volatile unsigned *)0x14A00028)
|
||||
#define rDP1_2 (*(volatile unsigned *)0x14A0002C)
|
||||
#define rDP4_7 (*(volatile unsigned *)0x14A00030)
|
||||
#define rDP3_5 (*(volatile unsigned *)0x14A00034)
|
||||
#define rDP2_3 (*(volatile unsigned *)0x14A00038)
|
||||
#define rDP5_7 (*(volatile unsigned *)0x14A0003c)
|
||||
#define rDP3_4 (*(volatile unsigned *)0x14A00040)
|
||||
#define rDP4_5 (*(volatile unsigned *)0x14A00044)
|
||||
#define rDP6_7 (*(volatile unsigned *)0x14A00048)
|
||||
#define rDITHMODE (*(volatile unsigned *)0x14A0004C)
|
||||
#define rTPAL (*(volatile unsigned *)0x14A00050)
|
||||
#define GP32_PALETTE (*(volatile unsigned *)0x14A00400) /* SJS */
|
||||
|
||||
|
||||
/* UART */
|
||||
#define rULCON0 (*(volatile unsigned char *)0x15000000)
|
||||
#define rUCON0 (*(volatile unsigned short *)0x15000004)
|
||||
#define rUFCON0 (*(volatile unsigned char *)0x15000008)
|
||||
#define rUMCON0 (*(volatile unsigned char *)0x1500000C)
|
||||
#define rUTRSTAT0 (*(volatile unsigned char *)0x15000010)
|
||||
#define rUERSTAT0 (*(volatile unsigned char *)0x15000014)
|
||||
#define rUFSTAT0 (*(volatile unsigned short *)0x15000018)
|
||||
#define rUMSTAT0 (*(volatile unsigned char *)0x1500001C)
|
||||
#define rUBRDIV0 (*(volatile unsigned short *)0x15000028)
|
||||
|
||||
#define rULCON1 (*(volatile unsigned char *)0x15004000)
|
||||
#define rUCON1 (*(volatile unsigned short *)0x15004004)
|
||||
#define rUFCON1 (*(volatile unsigned char *)0x15004008)
|
||||
#define rUMCON1 (*(volatile unsigned char *)0x1500400C)
|
||||
#define rUTRSTAT1 (*(volatile unsigned char *)0x15004010)
|
||||
#define rUERSTAT1 (*(volatile unsigned char *)0x15004014)
|
||||
#define rUFSTAT1 (*(volatile unsigned short *)0x15004018)
|
||||
#define rUMSTAT1 (*(volatile unsigned char *)0x1500401C)
|
||||
#define rUBRDIV1 (*(volatile unsigned short *)0x15004028)
|
||||
|
||||
#ifdef __BIG_ENDIAN
|
||||
#define rUTXH0 (*(volatile unsigned char *)0x15000023)
|
||||
#define rURXH0 (*(volatile unsigned char *)0x15000027)
|
||||
#define rUTXH1 (*(volatile unsigned char *)0x15004023)
|
||||
#define rURXH1 (*(volatile unsigned char *)0x15004027)
|
||||
|
||||
#define WrUTXH0(ch) (*(volatile unsigned char *)0x15000023)=(unsigned char)(ch)
|
||||
#define RdURXH0() (*(volatile unsigned char *)0x15000027)
|
||||
#define WrUTXH1(ch) (*(volatile unsigned char *)0x15004023)=(unsigned char)(ch)
|
||||
#define RdURXH1() (*(volatile unsigned char *)0x15004027)
|
||||
|
||||
#define UTXH0 (0x15000020+3) /* byte_access address by DMA */
|
||||
#define URXH0 (0x15000024+3)
|
||||
#define UTXH1 (0x15004020+3)
|
||||
#define URXH1 (0x15004024+3)
|
||||
|
||||
#else /* Little Endian */
|
||||
#define rUTXH0 (*(volatile unsigned char *)0x15000020)
|
||||
#define rURXH0 (*(volatile unsigned char *)0x15000024)
|
||||
#define rUTXH1 (*(volatile unsigned char *)0x15004020)
|
||||
#define rURXH1 (*(volatile unsigned char *)0x15004024)
|
||||
|
||||
#define WrUTXH0(ch) (*(volatile unsigned char *)0x15000020)=(unsigned char)(ch)
|
||||
#define RdURXH0() (*(volatile unsigned char *)0x15000024)
|
||||
#define WrUTXH1(ch) (*(volatile unsigned char *)0x15004020)=(unsigned char)(ch)
|
||||
#define RdURXH1() (*(volatile unsigned char *)0x15004024)
|
||||
|
||||
#define UTXH0 (0x15000020) /* byte_access address by DMA */
|
||||
#define URXH0 (0x15000024)
|
||||
#define UTXH1 (0x15004020)
|
||||
#define URXH1 (0x15004024)
|
||||
#endif
|
||||
|
||||
|
||||
/* PWM TIMER */
|
||||
#define rTCFG0 (*(volatile unsigned *)0x15100000)
|
||||
#define rTCFG1 (*(volatile unsigned *)0x15100004)
|
||||
#define rTCON (*(volatile unsigned *)0x15100008)
|
||||
#define rTCNTB0 (*(volatile unsigned *)0x1510000C)
|
||||
#define rTCMPB0 (*(volatile unsigned *)0x15100010)
|
||||
#define rTCNTO0 (*(volatile unsigned *)0x15100014)
|
||||
#define rTCNTB1 (*(volatile unsigned *)0x15100018)
|
||||
#define rTCMPB1 (*(volatile unsigned *)0x1510001C)
|
||||
#define rTCNTO1 (*(volatile unsigned *)0x15100020)
|
||||
#define rTCNTB2 (*(volatile unsigned *)0x15100024)
|
||||
#define rTCMPB2 (*(volatile unsigned *)0x15100028)
|
||||
#define rTCNTO2 (*(volatile unsigned *)0x1510002C)
|
||||
#define rTCNTB3 (*(volatile unsigned *)0x15100030)
|
||||
#define rTCMPB3 (*(volatile unsigned *)0x15100034)
|
||||
#define rTCNTO3 (*(volatile unsigned *)0x15100038)
|
||||
#define rTCNTB4 (*(volatile unsigned *)0x1510003C)
|
||||
#define rTCNTO4 (*(volatile unsigned *)0x15100040)
|
||||
|
||||
|
||||
/* USB DEVICE */
|
||||
#define rFUNC_ADDR_REG (*(volatile unsigned *)0x15200140)
|
||||
#define rPWR_REG (*(volatile unsigned *)0x15200144)
|
||||
#define rINT_REG (*(volatile unsigned *)0x15200148)
|
||||
#define rINT_MASK_REG (*(volatile unsigned *)0x1520014C)
|
||||
#define rFRAME_NUM_REG (*(volatile unsigned *)0x15200150)
|
||||
#define rRESUME_CON_REG (*(volatile unsigned *)0x15200154)
|
||||
#define rEP0_CSR (*(volatile unsigned *)0x15200160)
|
||||
#define rEP0_MAXP (*(volatile unsigned *)0x15200164)
|
||||
#define rEP0_OUT_CNT (*(volatile unsigned *)0x15200168)
|
||||
#define rEP0_FIFO (*(volatile unsigned *)0x1520016C)
|
||||
#define rEP1_IN_CSR (*(volatile unsigned *)0x15200180)
|
||||
#define rEP1_IN_MAXP (*(volatile unsigned *)0x15200184)
|
||||
#define rEP1_FIFO (*(volatile unsigned *)0x15200188)
|
||||
#define rEP2_IN_CSR (*(volatile unsigned *)0x15200190)
|
||||
#define rEP2_IN_MAXP (*(volatile unsigned *)0x15200194)
|
||||
#define rEP2_FIFO (*(volatile unsigned *)0x15200198)
|
||||
#define rEP3_OUT_CSR (*(volatile unsigned *)0x152001A0)
|
||||
#define rEP3_OUT_MAXP (*(volatile unsigned *)0x152001A4)
|
||||
#define rEP3_OUT_CNT (*(volatile unsigned *)0x152001A8)
|
||||
#define rEP3_FIFO (*(volatile unsigned *)0x152001AC)
|
||||
#define rEP4_OUT_CSR (*(volatile unsigned *)0x152001B0)
|
||||
#define rEP4_OUT_MAXP (*(volatile unsigned *)0x152001B4)
|
||||
#define rEP4_OUT_CNT (*(volatile unsigned *)0x152001B8)
|
||||
#define rEP4_FIFO (*(volatile unsigned *)0x152001BC)
|
||||
#define rDMA_CON (*(volatile unsigned *)0x152001C0)
|
||||
#define rDMA_UNIT (*(volatile unsigned *)0x152001C4)
|
||||
#define rDMA_FIFO (*(volatile unsigned *)0x152001C8)
|
||||
#define rDMA_TX (*(volatile unsigned *)0x152001CC)
|
||||
#define rTEST_MODE (*(volatile unsigned *)0x152001F4)
|
||||
#define rIN_CON_REG (*(volatile unsigned *)0x152001F8)
|
||||
|
||||
|
||||
/* WATCH DOG TIMER */
|
||||
#define rWTCON (*(volatile unsigned *)0x15300000)
|
||||
#define rWTDAT (*(volatile unsigned *)0x15300004)
|
||||
#define rWTCNT (*(volatile unsigned *)0x15300008)
|
||||
|
||||
|
||||
/* IIC */
|
||||
#define rIICCON (*(volatile unsigned *)0x15400000)
|
||||
#define rIICSTAT (*(volatile unsigned *)0x15400004)
|
||||
#define rIICADD (*(volatile unsigned *)0x15400008)
|
||||
#define rIICDS (*(volatile unsigned *)0x1540000C)
|
||||
|
||||
|
||||
/* IIS */
|
||||
#define rIISCON (*(volatile unsigned *)0x15508000)
|
||||
#define rIISMOD (*(volatile unsigned *)0x15508004)
|
||||
#define rIISPSR (*(volatile unsigned *)0x15508008)
|
||||
#define rIISFIFCON (*(volatile unsigned *)0x1550800C)
|
||||
|
||||
#ifdef __BIG_ENDIAN
|
||||
#define IISFIF ((volatile unsigned short *)0x15508012)
|
||||
|
||||
#else /* Little Endian */
|
||||
#define IISFIF ((volatile unsigned short *)0x15508010)
|
||||
#endif
|
||||
|
||||
|
||||
/* I/O PORT */
|
||||
#define rPACON (*(volatile unsigned *)0x15600000)
|
||||
#define rPADAT (*(volatile unsigned *)0x15600004)
|
||||
|
||||
#define rPBCON (*(volatile unsigned *)0x15600008)
|
||||
#define rPBDAT (*(volatile unsigned *)0x1560000C)
|
||||
#define rPBUP (*(volatile unsigned *)0x15600010)
|
||||
|
||||
#define rPCCON (*(volatile unsigned *)0x15600014)
|
||||
#define rPCDAT (*(volatile unsigned *)0x15600018)
|
||||
#define rPCUP (*(volatile unsigned *)0x1560001C)
|
||||
|
||||
#define rPDCON (*(volatile unsigned *)0x15600020)
|
||||
#define rPDDAT (*(volatile unsigned *)0x15600024)
|
||||
#define rPDUP (*(volatile unsigned *)0x15600028)
|
||||
|
||||
#define rPECON (*(volatile unsigned *)0x1560002C)
|
||||
#define rPEDAT (*(volatile unsigned *)0x15600030)
|
||||
#define rPEUP (*(volatile unsigned *)0x15600034)
|
||||
|
||||
#define rPFCON (*(volatile unsigned *)0x15600038)
|
||||
#define rPFDAT (*(volatile unsigned *)0x1560003C)
|
||||
#define rPFUP (*(volatile unsigned *)0x15600040)
|
||||
|
||||
#define rPGCON (*(volatile unsigned *)0x15600044)
|
||||
#define rPGDAT (*(volatile unsigned *)0x15600048)
|
||||
#define rPGUP (*(volatile unsigned *)0x1560004C)
|
||||
|
||||
#define rOPENCR (*(volatile unsigned *)0x15600050)
|
||||
#define rMISCCR (*(volatile unsigned *)0x15600054)
|
||||
#define rEXTINT (*(volatile unsigned *)0x15600058)
|
||||
|
||||
|
||||
/* RTC */
|
||||
#ifdef __BIG_ENDIAN
|
||||
#define rRTCCON (*(volatile unsigned char *)0x15700043)
|
||||
#define rRTCALM (*(volatile unsigned char *)0x15700053)
|
||||
#define rALMSEC (*(volatile unsigned char *)0x15700057)
|
||||
#define rALMMIN (*(volatile unsigned char *)0x1570005B)
|
||||
#define rALMHOUR (*(volatile unsigned char *)0x1570005F)
|
||||
#define rALMDAY (*(volatile unsigned char *)0x15700063)
|
||||
#define rALMMON (*(volatile unsigned char *)0x15700067)
|
||||
#define rALMYEAR (*(volatile unsigned char *)0x1570006B)
|
||||
#define rRTCRST (*(volatile unsigned char *)0x1570006F)
|
||||
#define rBCDSEC (*(volatile unsigned char *)0x15700073)
|
||||
#define rBCDMIN (*(volatile unsigned char *)0x15700077)
|
||||
#define rBCDHOUR (*(volatile unsigned char *)0x1570007B)
|
||||
#define rBCDDAY (*(volatile unsigned char *)0x1570007F)
|
||||
#define rBCDDATE (*(volatile unsigned char *)0x15700083)
|
||||
#define rBCDMON (*(volatile unsigned char *)0x15700087)
|
||||
#define rBCDYEAR (*(volatile unsigned char *)0x1570008B)
|
||||
#define rTICINT (*(volatile unsigned char *)0x15700047)
|
||||
|
||||
#else /* Little Endian */
|
||||
#define rRTCCON (*(volatile unsigned char *)0x15700040)
|
||||
#define rRTCALM (*(volatile unsigned char *)0x15700050)
|
||||
#define rALMSEC (*(volatile unsigned char *)0x15700054)
|
||||
#define rALMMIN (*(volatile unsigned char *)0x15700058)
|
||||
#define rALMHOUR (*(volatile unsigned char *)0x1570005C)
|
||||
#define rALMDAY (*(volatile unsigned char *)0x15700060)
|
||||
#define rALMMON (*(volatile unsigned char *)0x15700064)
|
||||
#define rALMYEAR (*(volatile unsigned char *)0x15700068)
|
||||
#define rRTCRST (*(volatile unsigned char *)0x1570006C)
|
||||
#define rBCDSEC (*(volatile unsigned char *)0x15700070)
|
||||
#define rBCDMIN (*(volatile unsigned char *)0x15700074)
|
||||
#define rBCDHOUR (*(volatile unsigned char *)0x15700078)
|
||||
#define rBCDDAY (*(volatile unsigned char *)0x1570007C)
|
||||
#define rBCDDATE (*(volatile unsigned char *)0x15700080)
|
||||
#define rBCDMON (*(volatile unsigned char *)0x15700084)
|
||||
#define rBCDYEAR (*(volatile unsigned char *)0x15700088)
|
||||
#define rTICINT (*(volatile unsigned char *)0x15700044)
|
||||
#endif
|
||||
|
||||
|
||||
/* ADC */
|
||||
#define rADCCON (*(volatile unsigned *)0x15800000)
|
||||
#define rADCDAT (*(volatile unsigned *)0x15800004)
|
||||
|
||||
|
||||
/* SPI */
|
||||
#define rSPCON (*(volatile unsigned *)0x15900000)
|
||||
#define rSPSTA (*(volatile unsigned *)0x15900004)
|
||||
#define rSPPIN (*(volatile unsigned *)0x15900008)
|
||||
#define rSPPRE (*(volatile unsigned *)0x1590000C)
|
||||
#define rSPTDAT (*(volatile unsigned *)0x15900010)
|
||||
#define rSPRDAT (*(volatile unsigned *)0x15900014)
|
||||
|
||||
|
||||
/* MMC INTERFACE */
|
||||
#define rMMCON (*(volatile unsigned *)0x15a00000)
|
||||
#define rMMCRR (*(volatile unsigned *)0x15a00004)
|
||||
#define rMMFCON (*(volatile unsigned *)0x15a00008)
|
||||
#define rMMSTA (*(volatile unsigned *)0x15a0000C)
|
||||
#define rMMFSTA (*(volatile unsigned *)0x15a00010)
|
||||
#define rMMPRE (*(volatile unsigned *)0x15a00014)
|
||||
#define rMMLEN (*(volatile unsigned *)0x15a00018)
|
||||
#define rMMCR7 (*(volatile unsigned *)0x15a0001C)
|
||||
#define rMMRSP0 (*(volatile unsigned *)0x15a00020)
|
||||
#define rMMRSP1 (*(volatile unsigned *)0x15a00024)
|
||||
#define rMMRSP2 (*(volatile unsigned *)0x15a00028)
|
||||
#define rMMRSP3 (*(volatile unsigned *)0x15a0002C)
|
||||
#define rMMCMD0 (*(volatile unsigned *)0x15a00030)
|
||||
#define rMMCMD1 (*(volatile unsigned *)0x15a00034)
|
||||
#define rMMCR16 (*(volatile unsigned *)0x15a00038)
|
||||
#define rMMDAT (*(volatile unsigned *)0x15a0003C)
|
||||
|
||||
|
||||
#define _ISR_STARTADDRESS rtems_vector_table
|
||||
/* ISR */
|
||||
#define pISR_RESET (*(unsigned *)(_ISR_STARTADDRESS+0x0))
|
||||
#define pISR_UNDEF (*(unsigned *)(_ISR_STARTADDRESS+0x4))
|
||||
#define pISR_SWI (*(unsigned *)(_ISR_STARTADDRESS+0x8))
|
||||
#define pISR_PABORT (*(unsigned *)(_ISR_STARTADDRESS+0xC))
|
||||
#define pISR_DABORT (*(unsigned *)(_ISR_STARTADDRESS+0x10))
|
||||
#define pISR_RESERVED (*(unsigned *)(_ISR_STARTADDRESS+0x14))
|
||||
#define pISR_IRQ (*(unsigned *)(_ISR_STARTADDRESS+0x18))
|
||||
#define pISR_FIQ (*(unsigned *)(_ISR_STARTADDRESS+0x1C))
|
||||
|
||||
#define pISR_EINT0 (*(unsigned *)(_ISR_STARTADDRESS+0x20))
|
||||
#define pISR_EINT1 (*(unsigned *)(_ISR_STARTADDRESS+0x24))
|
||||
#define pISR_EINT2 (*(unsigned *)(_ISR_STARTADDRESS+0x28))
|
||||
#define pISR_EINT3 (*(unsigned *)(_ISR_STARTADDRESS+0x2C))
|
||||
#define pISR_EINT4 (*(unsigned *)(_ISR_STARTADDRESS+0x30))
|
||||
#define pISR_EINT5 (*(unsigned *)(_ISR_STARTADDRESS+0x34))
|
||||
#define pISR_EINT6 (*(unsigned *)(_ISR_STARTADDRESS+0x38))
|
||||
#define pISR_EINT7 (*(unsigned *)(_ISR_STARTADDRESS+0x3C))
|
||||
#define pISR_TICK (*(unsigned *)(_ISR_STARTADDRESS+0x40))
|
||||
#define pISR_WDT (*(unsigned *)(_ISR_STARTADDRESS+0x44))
|
||||
#define pISR_TIMER0 (*(unsigned *)(_ISR_STARTADDRESS+0x48))
|
||||
#define pISR_TIMER1 (*(unsigned *)(_ISR_STARTADDRESS+0x4C))
|
||||
#define pISR_TIMER2 (*(unsigned *)(_ISR_STARTADDRESS+0x50))
|
||||
#define pISR_TIMER3 (*(unsigned *)(_ISR_STARTADDRESS+0x54))
|
||||
#define pISR_TIMER4 (*(unsigned *)(_ISR_STARTADDRESS+0x58))
|
||||
#define pISR_UERR01 (*(unsigned *)(_ISR_STARTADDRESS+0x5C))
|
||||
#define pISR_NOTUSED (*(unsigned *)(_ISR_STARTADDRESS+0x60))
|
||||
#define pISR_DMA0 (*(unsigned *)(_ISR_STARTADDRESS+0x64))
|
||||
#define pISR_DMA1 (*(unsigned *)(_ISR_STARTADDRESS+0x68))
|
||||
#define pISR_DMA2 (*(unsigned *)(_ISR_STARTADDRESS+0x6C))
|
||||
#define pISR_DMA3 (*(unsigned *)(_ISR_STARTADDRESS+0x70))
|
||||
#define pISR_MMC (*(unsigned *)(_ISR_STARTADDRESS+0x74))
|
||||
#define pISR_SPI (*(unsigned *)(_ISR_STARTADDRESS+0x78))
|
||||
#define pISR_URXD0 (*(unsigned *)(_ISR_STARTADDRESS+0x7C))
|
||||
#define pISR_URXD1 (*(unsigned *)(_ISR_STARTADDRESS+0x80))
|
||||
#define pISR_USBD (*(unsigned *)(_ISR_STARTADDRESS+0x84))
|
||||
#define pISR_USBH (*(unsigned *)(_ISR_STARTADDRESS+0x88))
|
||||
#define pISR_IIC (*(unsigned *)(_ISR_STARTADDRESS+0x8C))
|
||||
#define pISR_UTXD0 (*(unsigned *)(_ISR_STARTADDRESS+0x90))
|
||||
#define pISR_UTXD1 (*(unsigned *)(_ISR_STARTADDRESS+0x94))
|
||||
#define pISR_RTC (*(unsigned *)(_ISR_STARTADDRESS+0x98))
|
||||
#define pISR_ADC (*(unsigned *)(_ISR_STARTADDRESS+0xA0))
|
||||
|
||||
|
||||
/* PENDING BIT */
|
||||
#define BIT_EINT0 (0x1)
|
||||
#define BIT_EINT1 (0x1<<1)
|
||||
#define BIT_EINT2 (0x1<<2)
|
||||
#define BIT_EINT3 (0x1<<3)
|
||||
#define BIT_EINT4 (0x1<<4)
|
||||
#define BIT_EINT5 (0x1<<5)
|
||||
#define BIT_EINT6 (0x1<<6)
|
||||
#define BIT_EINT7 (0x1<<7)
|
||||
#define BIT_TICK (0x1<<8)
|
||||
#define BIT_WDT (0x1<<9)
|
||||
#define BIT_TIMER0 (0x1<<10)
|
||||
#define BIT_TIMER1 (0x1<<11)
|
||||
#define BIT_TIMER2 (0x1<<12)
|
||||
#define BIT_TIMER3 (0x1<<13)
|
||||
#define BIT_TIMER4 (0x1<<14)
|
||||
#define BIT_UERR01 (0x1<<15)
|
||||
#define BIT_NOTUSED (0x1<<16)
|
||||
#define BIT_DMA0 (0x1<<17)
|
||||
#define BIT_DMA1 (0x1<<18)
|
||||
#define BIT_DMA2 (0x1<<19)
|
||||
#define BIT_DMA3 (0x1<<20)
|
||||
#define BIT_MMC (0x1<<21)
|
||||
#define BIT_SPI (0x1<<22)
|
||||
#define BIT_URXD0 (0x1<<23)
|
||||
#define BIT_URXD1 (0x1<<24)
|
||||
#define BIT_USBD (0x1<<25)
|
||||
#define BIT_USBH (0x1<<26)
|
||||
#define BIT_IIC (0x1<<27)
|
||||
#define BIT_UTXD0 (0x1<<28)
|
||||
#define BIT_UTXD1 (0x1<<29)
|
||||
#define BIT_RTC (0x1<<30)
|
||||
#define BIT_ADC (0x1<<31)
|
||||
#define BIT_ALLMSK (0xFFFFFFFF)
|
||||
|
||||
#define ClearPending(bit) {\
|
||||
rSRCPND = bit;\
|
||||
rINTPND = bit;\
|
||||
rINTPND;\
|
||||
}
|
||||
/* Wait until rINTPND is changed for the case that the ISR is very short. */
|
||||
#define LCD_WIDTH 240
|
||||
#define LCD_HEIGH 320
|
||||
#define LCD_ASPECT ((flaot)(LCD_WIDTH/LCD_HEIGHT))
|
||||
|
||||
#define GP32_KEY_SELECT 512
|
||||
#define GP32_KEY_START 256
|
||||
#define GP32_KEY_A 64
|
||||
#define GP32_KEY_B 32
|
||||
#define GP32_KEY_L 16
|
||||
#define GP32_KEY_R 128
|
||||
#define GP32_KEY_UP 8
|
||||
#define GP32_KEY_DOWN 2
|
||||
#define GP32_KEY_LEFT 1
|
||||
#define GP32_KEY_RIGHT 4
|
||||
|
||||
#endif /*__S3C2400_H__*/
|
||||
40
c/src/lib/libcpu/arm/s3c2400/irq/bsp_irq_asm.S
Normal file
40
c/src/lib/libcpu/arm/s3c2400/irq/bsp_irq_asm.S
Normal file
@@ -0,0 +1,40 @@
|
||||
/* bsp_irq_asm.S
|
||||
*
|
||||
* This file contains the implementation of the IRQ handler
|
||||
* for a specific BSP
|
||||
*
|
||||
* CopyRight (C) 2000 Canon Research France SA.
|
||||
* Emmanuel Raguet, mailto:raguet@crf.canon.fr
|
||||
*
|
||||
* The license and distribution terms for this file may be
|
||||
* found in found in the file LICENSE in this distribution or at
|
||||
* http://www.rtems.com/license/LICENSE.
|
||||
*
|
||||
* $Id$
|
||||
*/
|
||||
|
||||
#define __asm__
|
||||
|
||||
/*
|
||||
* Function to obtain, execute an IT handler and acknowledge the IT
|
||||
*/
|
||||
|
||||
.globl ExecuteITHandler
|
||||
|
||||
ExecuteITHandler :
|
||||
|
||||
ldr r0, =0x14400014 /* Read rINTOFFSET */
|
||||
ldr r1, [r0]
|
||||
|
||||
ldr r0, =bsp_vector_table
|
||||
ldr r0, [r0, r1, LSL #2] /* Read the address */
|
||||
|
||||
stmdb sp!,{lr}
|
||||
ldr lr, =IRQ_return /* prepare the return from handler */
|
||||
|
||||
mov pc, r0
|
||||
|
||||
IRQ_return:
|
||||
ldmia sp!,{lr}
|
||||
|
||||
mov pc, lr
|
||||
27
c/src/lib/libcpu/arm/s3c2400/irq/bsp_irq_init.c
Normal file
27
c/src/lib/libcpu/arm/s3c2400/irq/bsp_irq_init.c
Normal file
@@ -0,0 +1,27 @@
|
||||
/* irq_init.c
|
||||
*
|
||||
* This file contains the implementation of rtems initialization
|
||||
* related to interrupt handling.
|
||||
*
|
||||
* CopyRight (C) 2000 Canon Research Centre France SA.
|
||||
* Emmanuel Raguet, mailto:raguet@crf.canon.fr
|
||||
*
|
||||
* The license and distribution terms for this file may be
|
||||
* found in the file LICENSE in this distribution or at
|
||||
* http://www.rtems.com/license/LICENSE.
|
||||
*
|
||||
* $Id$
|
||||
*/
|
||||
#include <irq.h>
|
||||
#include <bsp.h>
|
||||
#include <s3c2400.h>
|
||||
|
||||
extern void default_int_handler();
|
||||
|
||||
void BSP_rtems_irq_mngt_init()
|
||||
{
|
||||
/*
|
||||
* Here is the code to initialize the INT for
|
||||
* the specified BSP
|
||||
*/
|
||||
}
|
||||
110
c/src/lib/libcpu/arm/s3c2400/irq/irq.c
Normal file
110
c/src/lib/libcpu/arm/s3c2400/irq/irq.c
Normal file
@@ -0,0 +1,110 @@
|
||||
/* irq.c
|
||||
*
|
||||
* This file contains the implementation of the function described in irq.h
|
||||
*
|
||||
* CopyRight (C) 2000 Canon Research France SA.
|
||||
* Emmanuel Raguet, mailto:raguet@crf.canon.fr
|
||||
*
|
||||
* The license and distribution terms for this file may be
|
||||
* found in found in the file LICENSE in this distribution or at
|
||||
* http://www.rtems.com/license/LICENSE.
|
||||
*
|
||||
* $Id$
|
||||
*/
|
||||
|
||||
|
||||
#include <bsp.h>
|
||||
#include <irq.h>
|
||||
#include <rtems/score/thread.h>
|
||||
#include <rtems/score/apiext.h>
|
||||
#include <s3c2400.h>
|
||||
|
||||
/*
|
||||
* This function check that the value given for the irq line
|
||||
* is valid.
|
||||
*/
|
||||
|
||||
static int isValidInterrupt(int irq)
|
||||
{
|
||||
if ( (irq < 0) || (irq > BSP_MAX_INT)) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
/*
|
||||
* ------------------- RTEMS Single Irq Handler Mngt Routines ----------------
|
||||
*/
|
||||
|
||||
int BSP_install_rtems_irq_handler (const rtems_irq_connect_data* irq)
|
||||
{
|
||||
rtems_irq_hdl *HdlTable;
|
||||
rtems_interrupt_level level;
|
||||
|
||||
if (!isValidInterrupt(irq->name)) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* Check if default handler is actually connected. If not issue an error.
|
||||
*/
|
||||
HdlTable = VECTOR_TABLE;
|
||||
if (*(HdlTable + irq->name) != default_int_handler) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
_CPU_ISR_Disable(level);
|
||||
|
||||
/*
|
||||
* store the new handler
|
||||
*/
|
||||
*(HdlTable + irq->name) = irq->hdl;
|
||||
|
||||
/*
|
||||
* Enable interrupt on device
|
||||
*/
|
||||
if(irq->on)
|
||||
{
|
||||
irq->on(irq);
|
||||
}
|
||||
|
||||
_CPU_ISR_Enable(level);
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
int BSP_remove_rtems_irq_handler (const rtems_irq_connect_data* irq)
|
||||
{
|
||||
rtems_irq_hdl *HdlTable;
|
||||
rtems_interrupt_level level;
|
||||
|
||||
if (!isValidInterrupt(irq->name)) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* Check if the handler is actually connected. If not issue an error.
|
||||
*/
|
||||
HdlTable = VECTOR_TABLE;
|
||||
if (*(HdlTable + irq->name) != irq->hdl) {
|
||||
return 0;
|
||||
}
|
||||
_CPU_ISR_Disable(level);
|
||||
|
||||
/*
|
||||
* Disable interrupt on device
|
||||
*/
|
||||
if(irq->off) {
|
||||
irq->off(irq);
|
||||
}
|
||||
|
||||
/*
|
||||
* restore the default irq value
|
||||
*/
|
||||
*(HdlTable + irq->name) = default_int_handler;
|
||||
|
||||
_CPU_ISR_Enable(level);
|
||||
|
||||
return 1;
|
||||
}
|
||||
207
c/src/lib/libcpu/arm/s3c2400/irq/irq.h
Normal file
207
c/src/lib/libcpu/arm/s3c2400/irq/irq.h
Normal file
@@ -0,0 +1,207 @@
|
||||
/* irq.h
|
||||
*
|
||||
* This include file describe the data structure and the functions implemented
|
||||
* by rtems to write interrupt handlers.
|
||||
*
|
||||
* Copyright (c) 2000 Canon Research Centre France SA.
|
||||
* Emmanuel Raguet, mailto:raguet@crf.canon.fr
|
||||
*
|
||||
* The license and distribution terms for this file may be
|
||||
* found in found in the file LICENSE in this distribution or at
|
||||
* http://www.rtems.com/license/LICENSE.
|
||||
*
|
||||
* $Id$
|
||||
*/
|
||||
|
||||
#ifndef _IRQ_H_
|
||||
#define _IRQ_H_
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/*
|
||||
* Include some preprocessor value also used by assember code
|
||||
*/
|
||||
|
||||
#include <rtems.h>
|
||||
#include <s3c2400.h>
|
||||
|
||||
extern void default_int_handler();
|
||||
/*-------------------------------------------------------------------------+
|
||||
| Constants
|
||||
+--------------------------------------------------------------------------*/
|
||||
|
||||
/* enum of the possible interrupt sources */
|
||||
typedef enum {
|
||||
BSP_EINT0 = 0,
|
||||
BSP_EINT1,
|
||||
BSP_EINT2,
|
||||
BSP_EINT3,
|
||||
BSP_EINT4,
|
||||
BSP_EINT5,
|
||||
BSP_EINT6,
|
||||
BSP_EINT7,
|
||||
BSP_INT_TICK,
|
||||
BSP_INT_WDT,
|
||||
BSP_INT_TIMER0,
|
||||
BSP_INT_TIMER1,
|
||||
BSP_INT_TIMER2,
|
||||
BSP_INT_TIMER3,
|
||||
BSP_INT_TIMER4,
|
||||
BSP_INT_UERR01,
|
||||
_res0,
|
||||
BSP_INT_DMA0,
|
||||
BSP_INT_DMA1,
|
||||
BSP_INT_DMA2,
|
||||
BSP_INT_DMA3,
|
||||
BSP_INT_MMC,
|
||||
BSP_INT_SPI,
|
||||
BSP_INT_URXD0,
|
||||
BSP_INT_URXD1,
|
||||
BSP_INT_USBD,
|
||||
BSP_INT_USBH,
|
||||
BSP_INT_IIC,
|
||||
BSP_INT_UTXD0,
|
||||
BSP_INT_UTXD1,
|
||||
BSP_INT_RTC,
|
||||
BSP_INT_ADC,
|
||||
|
||||
BSP_MAX_INT
|
||||
} rtems_irq_symbolic_name;
|
||||
|
||||
extern void *bsp_vector_table;
|
||||
#define VECTOR_TABLE &bsp_vector_table
|
||||
|
||||
/*
|
||||
* Type definition for RTEMS managed interrupts
|
||||
*/
|
||||
typedef unsigned char rtems_irq_level;
|
||||
typedef unsigned char rtems_irq_trigger;
|
||||
|
||||
struct __rtems_irq_connect_data__; /* forward declaratiuon */
|
||||
|
||||
typedef void (*rtems_irq_hdl) (void);
|
||||
typedef void (*rtems_irq_enable) (const struct __rtems_irq_connect_data__*);
|
||||
typedef void (*rtems_irq_disable) (const struct __rtems_irq_connect_data__*);
|
||||
typedef int (*rtems_irq_is_enabled) (const struct __rtems_irq_connect_data__*);
|
||||
|
||||
typedef struct __rtems_irq_connect_data__ {
|
||||
/*
|
||||
* IRQ line
|
||||
*/
|
||||
rtems_irq_symbolic_name name;
|
||||
|
||||
/*
|
||||
* handler. See comment on handler properties below in function prototype.
|
||||
*/
|
||||
rtems_irq_hdl hdl;
|
||||
|
||||
/*
|
||||
* function for enabling interrupts at device level (ONLY!).
|
||||
* The BSP code will automatically enable it at i8259s level.
|
||||
* RATIONALE : anyway such code has to exist in current driver code.
|
||||
* It is usually called immediately AFTER connecting the interrupt handler.
|
||||
* RTEMS may well need such a function when restoring normal interrupt
|
||||
* processing after a debug session.
|
||||
*
|
||||
*/
|
||||
rtems_irq_enable on;
|
||||
|
||||
/*
|
||||
* function for disabling interrupts at device level (ONLY!).
|
||||
* The code will disable it at i8259s level. RATIONALE : anyway
|
||||
* such code has to exist for clean shutdown. It is usually called
|
||||
* BEFORE disconnecting the interrupt. RTEMS may well need such
|
||||
* a function when disabling normal interrupt processing for
|
||||
* a debug session. May well be a NOP function.
|
||||
*/
|
||||
rtems_irq_disable off;
|
||||
|
||||
/*
|
||||
* function enabling to know what interrupt may currently occur
|
||||
* if someone manipulates the i8259s interrupt mask without care...
|
||||
*/
|
||||
rtems_irq_is_enabled isOn;
|
||||
|
||||
/*
|
||||
* priority level at the vplus level
|
||||
*/
|
||||
rtems_irq_level irqLevel;
|
||||
|
||||
/*
|
||||
* Trigger way : Rising or falling edge or High or low level
|
||||
*/
|
||||
rtems_irq_trigger irqTrigger;
|
||||
|
||||
} rtems_irq_connect_data;
|
||||
|
||||
/*-------------------------------------------------------------------------+
|
||||
| Function Prototypes.
|
||||
+--------------------------------------------------------------------------*/
|
||||
/*
|
||||
* ------------------ RTEMS Single Irq Handler Mngt Routines ----------------
|
||||
*/
|
||||
|
||||
/*
|
||||
* function to initialize the interrupt for a specific BSP
|
||||
*/
|
||||
void BSP_rtems_irq_mngt_init();
|
||||
|
||||
|
||||
/*
|
||||
* function to connect a particular irq handler. This hanlder will NOT be called
|
||||
* directly as the result of the corresponding interrupt. Instead, a RTEMS
|
||||
* irq prologue will be called that will :
|
||||
*
|
||||
* 1) save the C scratch registers,
|
||||
* 2) switch to a interrupt stack if the interrupt is not nested,
|
||||
* 3) store the current i8259s' interrupt masks
|
||||
* 4) modify them to disable the current interrupt at 8259 level (and may
|
||||
* be others depending on software priorities)
|
||||
* 5) aknowledge the i8259s',
|
||||
* 6) demask the processor,
|
||||
* 7) call the application handler
|
||||
*
|
||||
* As a result the hdl function provided
|
||||
*
|
||||
* a) can perfectly be written is C,
|
||||
* b) may also well directly call the part of the RTEMS API that can be used
|
||||
* from interrupt level,
|
||||
* c) It only responsible for handling the jobs that need to be done at
|
||||
* the device level including (aknowledging/re-enabling the interrupt at device,
|
||||
* level, getting the data,...)
|
||||
*
|
||||
* When returning from the function, the following will be performed by
|
||||
* the RTEMS irq epilogue :
|
||||
*
|
||||
* 1) masks the interrupts again,
|
||||
* 2) restore the original i8259s' interrupt masks
|
||||
* 3) switch back on the orinal stack if needed,
|
||||
* 4) perform rescheduling when necessary,
|
||||
* 5) restore the C scratch registers...
|
||||
* 6) restore initial execution flow
|
||||
*
|
||||
*/
|
||||
int BSP_install_rtems_irq_handler (const rtems_irq_connect_data*);
|
||||
|
||||
/*
|
||||
* function to get the current RTEMS irq handler for ptr->name. It enables to
|
||||
* define hanlder chain...
|
||||
*/
|
||||
int BSP_get_current_rtems_irq_handler (rtems_irq_connect_data* ptr);
|
||||
|
||||
/*
|
||||
* function to get disconnect the RTEMS irq handler for ptr->name.
|
||||
* This function checks that the value given is the current one for safety reason.
|
||||
* The user can use the previous function to get it.
|
||||
*/
|
||||
int BSP_remove_rtems_irq_handler (const rtems_irq_connect_data*);
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* _IRQ_H_ */
|
||||
/* end of include file */
|
||||
132
c/src/lib/libcpu/arm/s3c2400/timer/timer.c
Normal file
132
c/src/lib/libcpu/arm/s3c2400/timer/timer.c
Normal file
@@ -0,0 +1,132 @@
|
||||
/*
|
||||
* S3C2400 Timer driver
|
||||
*
|
||||
* This uses timer 1 for timing measurments.
|
||||
*
|
||||
* The license and distribution terms for this file may be
|
||||
* found in the file LICENSE in this distribution or at
|
||||
*
|
||||
* http://www.OARcorp.com/rtems/license.html.
|
||||
*
|
||||
* Notes:
|
||||
* This file manages the benchmark timer used by the RTEMS Timing Test
|
||||
* Suite. Each measured time period is demarcated by calls to
|
||||
* Timer_initialize() and Read_timer(). Read_timer() usually returns
|
||||
* the number of microseconds since Timer_initialize() exitted.
|
||||
*
|
||||
* It is important that the timer start/stop overhead be determined
|
||||
* when porting or modifying this code.
|
||||
*
|
||||
* $Id$
|
||||
*/
|
||||
|
||||
#include <rtems.h>
|
||||
#include <bsp.h>
|
||||
#include <s3c2400.h>
|
||||
|
||||
uint32_t g_start;
|
||||
uint32_t g_freq;
|
||||
|
||||
rtems_boolean Timer_driver_Find_average_overhead;
|
||||
|
||||
|
||||
/*
|
||||
* Set up Timer 1
|
||||
*/
|
||||
void Timer_initialize( void )
|
||||
{
|
||||
uint32_t cr;
|
||||
uint32_t m;
|
||||
uint32_t p;
|
||||
uint32_t s;
|
||||
|
||||
/* stop TIMER1*/
|
||||
cr=rTCON & 0xFFFFF0FF;
|
||||
rTCON=(cr | (0x0 << 8));
|
||||
|
||||
/* set MUX for Timer1 to 1/2 */
|
||||
cr=rTCFG1 & 0xFFFFFF0F;
|
||||
rTCFG1=(cr | (0<<4));
|
||||
|
||||
/* compute MPLL freq */
|
||||
m = M_MDIV + 8;
|
||||
p = M_PDIV + 2;
|
||||
s = M_SDIV;
|
||||
g_freq =(BSP_OSC_FREQ * m) / (p << s);
|
||||
|
||||
/* PCLK = MPLL/4 */
|
||||
g_freq = g_freq / 4;
|
||||
|
||||
/* input freq=PLCK/2 Mhz*/
|
||||
g_freq = g_freq / 2000;
|
||||
rTCNTB1 = 0xFFFF;
|
||||
|
||||
/* start TIMER1 with manual reload */
|
||||
cr=rTCON & 0xFFFFF0FF;
|
||||
rTCON=(cr | (0x1 << 9));
|
||||
rTCON=(cr | (0x1 << 8));
|
||||
|
||||
g_start = rTCNTO1;
|
||||
}
|
||||
|
||||
/*
|
||||
* The following controls the behavior of Read_timer().
|
||||
*
|
||||
* AVG_OVEREHAD is the overhead for starting and stopping the timer. It
|
||||
* is usually deducted from the number returned.
|
||||
*
|
||||
* LEAST_VALID is the lowest number this routine should trust. Numbers
|
||||
* below this are "noise" and zero is returned.
|
||||
*/
|
||||
|
||||
#define AVG_OVERHEAD 0 /* It typically takes X.X microseconds */
|
||||
/* (Y countdowns) to start/stop the timer. */
|
||||
/* This value is in microseconds. */
|
||||
#define LEAST_VALID 1 /* Don't trust a clicks value lower than this */
|
||||
|
||||
int Read_timer( void )
|
||||
{
|
||||
uint32_t t;
|
||||
unsigned long long total;
|
||||
|
||||
t = rTCNTO1;
|
||||
/*
|
||||
* Total is calculated by taking into account the number of timer overflow
|
||||
* interrupts since the timer was initialized and clicks since the last
|
||||
* interrupts.
|
||||
*/
|
||||
|
||||
total = (g_start - t);
|
||||
|
||||
/* convert to microseconds */
|
||||
total = (total*1000) / g_freq;
|
||||
|
||||
if ( Timer_driver_Find_average_overhead == 1 ) {
|
||||
return (int) total;
|
||||
} else if ( total < LEAST_VALID ) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* Somehow convert total into microseconds
|
||||
*/
|
||||
return (total - AVG_OVERHEAD);
|
||||
}
|
||||
|
||||
/*
|
||||
* Empty function call used in loops to measure basic cost of looping
|
||||
* in Timing Test Suite.
|
||||
*/
|
||||
|
||||
rtems_status_code Empty_function( void )
|
||||
{
|
||||
return RTEMS_SUCCESSFUL;
|
||||
}
|
||||
|
||||
void Set_find_average_overhead(
|
||||
rtems_boolean find_flag
|
||||
)
|
||||
{
|
||||
Timer_driver_Find_average_overhead = find_flag;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user