forked from Imagelibrary/rtems
2004-08-02 Jay Monkman <jtm@lopingdog.com>
* Makefile.am, configure.ac: Added CSB360 BSP * mcf5272/.cvsignore, mcf5272/ChangeLog, mcf5272/Makefile.am, mcf5272/clock/.cvsignore, mcf5272/clock/ckinit.c, mcf5272/include/.cvsignore, mcf5272/include/mcf5272.h, mcf5272/timer/.cvsignore, mcf5272/timer/timer.c, mcf5272/timer/timerisr.S: New files.
This commit is contained in:
@@ -1,3 +1,12 @@
|
|||||||
|
2004-08-02 Jay Monkman <jtm@lopingdog.com>
|
||||||
|
|
||||||
|
* Makefile.am, configure.ac: Added CSB360 BSP
|
||||||
|
* mcf5272/.cvsignore, mcf5272/ChangeLog, mcf5272/Makefile.am,
|
||||||
|
mcf5272/clock/.cvsignore, mcf5272/clock/ckinit.c,
|
||||||
|
mcf5272/include/.cvsignore, mcf5272/include/mcf5272.h,
|
||||||
|
mcf5272/timer/.cvsignore, mcf5272/timer/timer.c,
|
||||||
|
mcf5272/timer/timerisr.S: New files.
|
||||||
|
|
||||||
2004-04-02 Ralf Corsepius <ralf_corsepius@rtems.org>
|
2004-04-02 Ralf Corsepius <ralf_corsepius@rtems.org>
|
||||||
|
|
||||||
* mcf5206/timer/timerisr.S: Include <rtems/asm.h> instead of <asm.h>.
|
* mcf5206/timer/timerisr.S: Include <rtems/asm.h> instead of <asm.h>.
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
ACLOCAL_AMFLAGS = -I ../../../aclocal
|
ACLOCAL_AMFLAGS = -I ../../../aclocal
|
||||||
|
|
||||||
SUBDIRS = shared m68040 mcf5206
|
SUBDIRS = shared m68040 mcf5206 mcf5272
|
||||||
|
|
||||||
include $(top_srcdir)/../../../automake/subdirs.am
|
include $(top_srcdir)/../../../automake/subdirs.am
|
||||||
include $(top_srcdir)/../../../automake/local.am
|
include $(top_srcdir)/../../../automake/local.am
|
||||||
|
|||||||
@@ -48,5 +48,6 @@ AC_CONFIG_FILES([Makefile
|
|||||||
shared/Makefile
|
shared/Makefile
|
||||||
m68040/Makefile
|
m68040/Makefile
|
||||||
mcf5206/Makefile
|
mcf5206/Makefile
|
||||||
|
mcf5272/Makefile
|
||||||
])
|
])
|
||||||
AC_OUTPUT
|
AC_OUTPUT
|
||||||
|
|||||||
14
c/src/lib/libcpu/m68k/mcf5272/.cvsignore
Normal file
14
c/src/lib/libcpu/m68k/mcf5272/.cvsignore
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
aclocal.m4
|
||||||
|
autom4te*.cache
|
||||||
|
config.cache
|
||||||
|
config.guess
|
||||||
|
config.log
|
||||||
|
config.status
|
||||||
|
config.sub
|
||||||
|
configure
|
||||||
|
depcomp
|
||||||
|
install-sh
|
||||||
|
Makefile
|
||||||
|
Makefile.in
|
||||||
|
missing
|
||||||
|
mkinstalldirs
|
||||||
6
c/src/lib/libcpu/m68k/mcf5272/ChangeLog
Normal file
6
c/src/lib/libcpu/m68k/mcf5272/ChangeLog
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
2004-08-02 Jay Monkman <jtm@lopingdog.com>
|
||||||
|
|
||||||
|
* .cvsignore, ChangeLog, Makefile.am, clock/.cvsignore, clock/ckinit.c,
|
||||||
|
include/.cvsignore, include/mcf5272.h, timer/.cvsignore,
|
||||||
|
timer/timer.c, timer/timerisr.S: New files.
|
||||||
|
|
||||||
83
c/src/lib/libcpu/m68k/mcf5272/Makefile.am
Normal file
83
c/src/lib/libcpu/m68k/mcf5272/Makefile.am
Normal file
@@ -0,0 +1,83 @@
|
|||||||
|
##
|
||||||
|
## $Id$
|
||||||
|
##
|
||||||
|
|
||||||
|
include $(top_srcdir)/../../../automake/compile.am
|
||||||
|
|
||||||
|
CLEANFILES =
|
||||||
|
EXTRA_PROGRAMS =
|
||||||
|
noinst_DATA =
|
||||||
|
|
||||||
|
if mcf5272
|
||||||
|
|
||||||
|
# include
|
||||||
|
include_mcf5272dir = $(includedir)/mcf5272
|
||||||
|
include_mcf5272_HEADERS = include/mcf5272.h
|
||||||
|
|
||||||
|
## clock
|
||||||
|
EXTRA_PROGRAMS += clock.rel
|
||||||
|
CLEANFILES += clock.rel
|
||||||
|
clock_rel_SOURCES = clock/ckinit.c
|
||||||
|
clock_rel_CPPFLAGS = $(AM_CPPFLAGS) $(CFLAGS_OPTIMIZE_V)
|
||||||
|
clock_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)
|
||||||
|
|
||||||
|
EXTRA_PROGRAMS += clock_g.rel
|
||||||
|
CLEANFILES += clock_g.rel
|
||||||
|
clock_g_rel_SOURCES = $(clock_rel_SOURCES)
|
||||||
|
clock_g_rel_CPPFLAGS = $(AM_CPPFLAGS) $(CFLAGS_DEBUG_V)
|
||||||
|
clock_g_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)
|
||||||
|
|
||||||
|
noinst_DATA += clock$(LIB_VARIANT).rel
|
||||||
|
|
||||||
|
## console
|
||||||
|
#EXTRA_PROGRAMS += console.rel
|
||||||
|
#CLEANFILES += console.rel
|
||||||
|
#console_rel_SOURCES = console/console-io.c ../../../../libbsp/shared/console-polled.c
|
||||||
|
#console_rel_CPPFLAGS = $(AM_CPPFLAGS) $(CFLAGS_OPTIMIZE_V)
|
||||||
|
#console_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)
|
||||||
|
|
||||||
|
#EXTRA_PROGRAMS += console_g.rel
|
||||||
|
#CLEANFILES += console_g.rel
|
||||||
|
#console_g_rel_SOURCES = $(console_rel_SOURCES)
|
||||||
|
#console_g_rel_CPPFLAGS = $(AM_CPPFLAGS) $(CFLAGS_DEBUG_V)
|
||||||
|
#console_g_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)
|
||||||
|
#
|
||||||
|
#noinst_DATA += console$(LIB_VARIANT).rel
|
||||||
|
|
||||||
|
## timer
|
||||||
|
EXTRA_PROGRAMS += timer.rel
|
||||||
|
CLEANFILES += timer.rel
|
||||||
|
timer_rel_SOURCES = timer/timer.c timer/timerisr.S
|
||||||
|
timer_rel_CPPFLAGS = $(AM_CPPFLAGS) $(CFLAGS_OPTIMIZE_V)
|
||||||
|
timer_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)
|
||||||
|
|
||||||
|
EXTRA_PROGRAMS += timer_g.rel
|
||||||
|
CLEANFILES += timer_g.rel
|
||||||
|
timer_g_rel_SOURCES = $(timer_rel_SOURCES)
|
||||||
|
timer_g_rel_CPPFLAGS = $(AM_CPPFLAGS) $(CFLAGS_DEBUG_V)
|
||||||
|
timer_g_rel_LDFLAGS = $(RTEMS_RELLDFLAGS)
|
||||||
|
|
||||||
|
noinst_DATA += timer$(LIB_VARIANT).rel
|
||||||
|
endif
|
||||||
|
|
||||||
|
all-local: $(PREINSTALL_FILES)
|
||||||
|
|
||||||
|
PREINSTALL_DIRS =
|
||||||
|
PREINSTALL_FILES =
|
||||||
|
|
||||||
|
if mcf5272
|
||||||
|
$(PROJECT_INCLUDE)/mcf5272/$(dirstamp):
|
||||||
|
@$(mkdir_p) $(PROJECT_INCLUDE)/mcf5272
|
||||||
|
@: > $(PROJECT_INCLUDE)/mcf5272/$(dirstamp)
|
||||||
|
PREINSTALL_DIRS += $(PROJECT_INCLUDE)/mcf5272/$(dirstamp)
|
||||||
|
|
||||||
|
$(PROJECT_INCLUDE)/mcf5272/mcf5272.h: include/mcf5272.h $(PROJECT_INCLUDE)/mcf5272/$(dirstamp)
|
||||||
|
$(INSTALL_DATA) $< $(PROJECT_INCLUDE)/mcf5272/mcf5272.h
|
||||||
|
PREINSTALL_FILES += $(PROJECT_INCLUDE)/mcf5272/mcf5272.h
|
||||||
|
|
||||||
|
endif
|
||||||
|
|
||||||
|
CLEANFILES += $(PREINSTALL_FILES)
|
||||||
|
DISTCLEANFILES = $(PREINSTALL_DIRS)
|
||||||
|
|
||||||
|
include $(top_srcdir)/../../../automake/local.am
|
||||||
2
c/src/lib/libcpu/m68k/mcf5272/clock/.cvsignore
Normal file
2
c/src/lib/libcpu/m68k/mcf5272/clock/.cvsignore
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
Makefile
|
||||||
|
Makefile.in
|
||||||
226
c/src/lib/libcpu/m68k/mcf5272/clock/ckinit.c
Normal file
226
c/src/lib/libcpu/m68k/mcf5272/clock/ckinit.c
Normal file
@@ -0,0 +1,226 @@
|
|||||||
|
/*
|
||||||
|
* Clock Driver for MCF5272 CPU
|
||||||
|
*
|
||||||
|
* This driver initailizes timer1 on the MCF5272 as the
|
||||||
|
* main system clock
|
||||||
|
*
|
||||||
|
* Copyright 2004 Cogent Computer Systems
|
||||||
|
* Author: Jay Monkman <jtm@lopingdog.com>
|
||||||
|
*
|
||||||
|
* Based on MCF5206 clock driver by
|
||||||
|
* Victor V. Vengerov <vvv@oktet.ru>
|
||||||
|
*
|
||||||
|
* Based on work:
|
||||||
|
* David Fiddes, D.J@fiddes.surfaid.org
|
||||||
|
* http://www.calm.hw.ac.uk/davidf/coldfire/
|
||||||
|
*
|
||||||
|
* COPYRIGHT (c) 1989-1998.
|
||||||
|
* On-Line Applications Research Corporation (OAR).
|
||||||
|
* Copyright assigned to U.S. Government, 1994.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* ckinit.c,v 1.1 2001/10/26 19:32:40 joel Exp
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <bsp.h>
|
||||||
|
#include <rtems/libio.h>
|
||||||
|
#include <mcf5272/mcf5272.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Clock_driver_ticks is a monotonically increasing counter of the
|
||||||
|
* number of clock ticks since the driver was initialized.
|
||||||
|
*/
|
||||||
|
volatile rtems_unsigned32 Clock_driver_ticks;
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* These are set by clock driver during its init
|
||||||
|
*/
|
||||||
|
|
||||||
|
rtems_device_major_number rtems_clock_major = ~0;
|
||||||
|
rtems_device_minor_number rtems_clock_minor;
|
||||||
|
|
||||||
|
rtems_isr (*rtems_clock_hook)(rtems_vector_number) = NULL;
|
||||||
|
|
||||||
|
/* Clock_isr --
|
||||||
|
* This handles the timer interrupt by clearing the timer's interrupt
|
||||||
|
* flag and announcing the clock tick to the system.
|
||||||
|
*
|
||||||
|
* PARAMETERS:
|
||||||
|
* vector - timer interrupt vector number
|
||||||
|
|
||||||
|
* RETURNS:
|
||||||
|
* none
|
||||||
|
*/
|
||||||
|
rtems_isr
|
||||||
|
Clock_isr (rtems_vector_number vector)
|
||||||
|
{
|
||||||
|
/* Clear pending interrupt... */
|
||||||
|
g_timer_regs->ter1 = MCF5272_TER_REF | MCF5272_TER_CAP;
|
||||||
|
|
||||||
|
/* Announce the clock tick */
|
||||||
|
Clock_driver_ticks++;
|
||||||
|
rtems_clock_tick();
|
||||||
|
if (rtems_clock_hook != NULL) {
|
||||||
|
rtems_clock_hook(vector);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Clock_exit --
|
||||||
|
* This shuts down the timer if it was enabled and removes it
|
||||||
|
* from the MCF5206E interrupt mask.
|
||||||
|
*
|
||||||
|
* PARAMETERS:
|
||||||
|
* none
|
||||||
|
*
|
||||||
|
* RETURNS:
|
||||||
|
* none
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
Clock_exit(void)
|
||||||
|
{
|
||||||
|
if (BSP_Configuration.ticks_per_timeslice) {
|
||||||
|
unsigned32 icr;
|
||||||
|
/* disable all timer1 interrupts */
|
||||||
|
icr = g_intctrl_regs->icr1;
|
||||||
|
icr = icr & ~(MCF5272_ICR1_TMR1_MASK | MCF5272_ICR1_TMR1_PI);
|
||||||
|
icr |= (MCF5272_ICR1_TMR1_IPL(0) | MCF5272_ICR1_TMR1_PI);
|
||||||
|
g_intctrl_regs->icr1 = icr;
|
||||||
|
|
||||||
|
/* reset timer1 */
|
||||||
|
g_timer_regs->tmr1 = MCF5272_TMR_CLK_STOP;
|
||||||
|
|
||||||
|
/* clear pending */
|
||||||
|
g_timer_regs->ter1 = MCF5272_TER_REF | MCF5272_TER_CAP;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Install_clock --
|
||||||
|
* This initialises timer1 with the BSP timeslice config value
|
||||||
|
* as a reference and sets up the interrupt handler for clock ticks.
|
||||||
|
*
|
||||||
|
* PARAMETERS:
|
||||||
|
* clock_isr - clock interrupt handler routine
|
||||||
|
*
|
||||||
|
* RETURNS:
|
||||||
|
* none.
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
Install_clock(rtems_isr_entry clock_isr)
|
||||||
|
{
|
||||||
|
unsigned32 icr;
|
||||||
|
Clock_driver_ticks = 0;
|
||||||
|
if (BSP_Configuration.ticks_per_timeslice) {
|
||||||
|
|
||||||
|
/* Register the interrupt handler */
|
||||||
|
set_vector(clock_isr, BSP_INTVEC_TMR1, 1);
|
||||||
|
|
||||||
|
/* Reset timer 1 */
|
||||||
|
g_timer_regs->tmr1 = MCF5272_TMR_RST;
|
||||||
|
g_timer_regs->tmr1 = MCF5272_TMR_CLK_STOP;
|
||||||
|
g_timer_regs->tmr1 = MCF5272_TMR_RST;
|
||||||
|
g_timer_regs->tcn1 = 0; /* reset counter */
|
||||||
|
g_timer_regs->ter1 = MCF5272_TER_REF | MCF5272_TER_CAP;
|
||||||
|
|
||||||
|
/* Set Timer 1 prescaler so that it counts in microseconds */
|
||||||
|
g_timer_regs->tmr1 = (
|
||||||
|
((((BSP_SYSTEM_FREQUENCY / 1000000) - 1) << MCF5272_TMR_PS_SHIFT) |
|
||||||
|
MCF5272_TMR_CE_DISABLE |
|
||||||
|
MCF5272_TMR_ORI |
|
||||||
|
MCF5272_TMR_FRR |
|
||||||
|
MCF5272_TMR_CLK_MSTR |
|
||||||
|
MCF5272_TMR_RST));
|
||||||
|
|
||||||
|
/* Set the timer timeout value from the BSP config */
|
||||||
|
g_timer_regs->trr1 = BSP_Configuration.microseconds_per_tick - 1;
|
||||||
|
|
||||||
|
/* Feed system frequency to the timer */
|
||||||
|
g_timer_regs->tmr1 |= MCF5272_TMR_CLK_MSTR;
|
||||||
|
|
||||||
|
/* Configure timer1 interrupts */
|
||||||
|
icr = g_intctrl_regs->icr1;
|
||||||
|
icr = icr & ~(MCF5272_ICR1_TMR1_MASK | MCF5272_ICR1_TMR1_PI);
|
||||||
|
icr |= (MCF5272_ICR1_TMR1_IPL(BSP_INTLVL_TMR1) | MCF5272_ICR1_TMR1_PI);
|
||||||
|
g_intctrl_regs->icr1 = icr;
|
||||||
|
|
||||||
|
/* Register the driver exit procedure so we can shutdown */
|
||||||
|
atexit(Clock_exit);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Clock_initialize --
|
||||||
|
* This is called to setup the clock driver. It calls the hardware
|
||||||
|
* setup function and make the driver major/minor values available
|
||||||
|
* for other.
|
||||||
|
*
|
||||||
|
* PARAMETERS:
|
||||||
|
* major - clock device major number
|
||||||
|
* minor - clock device minor number
|
||||||
|
* pargp - device driver initialization argument (not used)
|
||||||
|
*
|
||||||
|
* RETURNS:
|
||||||
|
* RTEMS status code
|
||||||
|
*/
|
||||||
|
rtems_device_driver
|
||||||
|
Clock_initialize(rtems_device_major_number major,
|
||||||
|
rtems_device_minor_number minor,
|
||||||
|
void *pargp)
|
||||||
|
{
|
||||||
|
Install_clock (Clock_isr);
|
||||||
|
|
||||||
|
/* Make major/minor avail to others such as shared memory driver */
|
||||||
|
rtems_clock_major = major;
|
||||||
|
rtems_clock_minor = minor;
|
||||||
|
|
||||||
|
return RTEMS_SUCCESSFUL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Clock_control --
|
||||||
|
* I/O control (IOCTL) function for Clock driver. At this moment this
|
||||||
|
* just runs the interrupt handler or re-registers the interrupt handler
|
||||||
|
* on request.
|
||||||
|
*
|
||||||
|
* PARAMETERS:
|
||||||
|
* major - clock major device number
|
||||||
|
* minor - clock minor device number
|
||||||
|
* pargp - pointer to IOCTL arguments
|
||||||
|
*
|
||||||
|
* RETURNS:
|
||||||
|
* RTEMS status code
|
||||||
|
*/
|
||||||
|
rtems_device_driver
|
||||||
|
Clock_control(rtems_device_major_number major,
|
||||||
|
rtems_device_minor_number minor,
|
||||||
|
void *pargp)
|
||||||
|
{
|
||||||
|
rtems_unsigned32 isrlevel;
|
||||||
|
rtems_libio_ioctl_args_t *args = pargp;
|
||||||
|
|
||||||
|
if (args)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* This is hokey, but until we get a defined interface
|
||||||
|
* to do this, it will just be this simple...
|
||||||
|
*/
|
||||||
|
if (args->command == rtems_build_name('I', 'S', 'R', ' '))
|
||||||
|
{
|
||||||
|
Clock_isr(BSP_INTVEC_TMR1);
|
||||||
|
}
|
||||||
|
else if (args->command == rtems_build_name('N', 'E', 'W', ' '))
|
||||||
|
{
|
||||||
|
rtems_interrupt_disable( isrlevel );
|
||||||
|
(void) set_vector( args->buffer, BSP_INTVEC_TMR1, 1 );
|
||||||
|
rtems_interrupt_enable( isrlevel );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return RTEMS_SUCCESSFUL;
|
||||||
|
}
|
||||||
2
c/src/lib/libcpu/m68k/mcf5272/include/.cvsignore
Normal file
2
c/src/lib/libcpu/m68k/mcf5272/include/.cvsignore
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
Makefile
|
||||||
|
Makefile.in
|
||||||
702
c/src/lib/libcpu/m68k/mcf5272/include/mcf5272.h
Normal file
702
c/src/lib/libcpu/m68k/mcf5272/include/mcf5272.h
Normal file
@@ -0,0 +1,702 @@
|
|||||||
|
/*
|
||||||
|
* Coldfire MCF5272 definitions.
|
||||||
|
* Contents of this file based on information provided in
|
||||||
|
* Motorola MCF5272 User's Manual.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2004 Jay Monkman <jtm@lopingdog.com>
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* @(#) mcf5206e.h,v 1.1 2001/10/26 19:32:40 joel Exp
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __MCF5272_H__
|
||||||
|
#define __MCF5272_H__
|
||||||
|
|
||||||
|
#ifndef ASM
|
||||||
|
#include <rtems.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define bit(x) (1 << (x))
|
||||||
|
|
||||||
|
#define MCF5272_SIM_BASE(mbar) ((mbar) + 0x0000)
|
||||||
|
#define MCF5272_INT_BASE(mbar) ((mbar) + 0x0020)
|
||||||
|
#define MCF5272_CS_BASE(mbar) ((mbar) + 0x0040)
|
||||||
|
#define MCF5272_GPIO_BASE(mbar) ((mbar) + 0x0080)
|
||||||
|
#define MCF5272_QSPI_BASE(mbar) ((mbar) + 0x00A0)
|
||||||
|
#define MCF5272_PWM_BASE(mbar) ((mbar) + 0x00C0)
|
||||||
|
#define MCF5272_DMAC_BASE(mbar) ((mbar) + 0x00E0)
|
||||||
|
#define MCF5272_UART0_BASE(mbar) ((mbar) + 0x0100)
|
||||||
|
#define MCF5272_UART1_BASE(mbar) ((mbar) + 0x0140)
|
||||||
|
#define MCF5272_SDRAMC_BASE(mbar) ((mbar) + 0x0180)
|
||||||
|
#define MCF5272_TIMER_BASE(mbar) ((mbar) + 0x0200)
|
||||||
|
#define MCF5272_PLIC_BASE(mbar) ((mbar) + 0x0300)
|
||||||
|
#define MCF5272_ENET_BASE(mbar) ((mbar) + 0x0840)
|
||||||
|
#define MCF5272_USB_BASE(mbar) ((mbar) + 0x1000)
|
||||||
|
|
||||||
|
|
||||||
|
/* RAMBAR - SRAM Base Address Register */
|
||||||
|
#define MCF5272_RAMBAR_BA (0xfffff000) /* SRAM Base Address */
|
||||||
|
#define MCF5272_RAMBAR_WP (0x00000100) /* Write Protect */
|
||||||
|
#define MCF5272_RAMBAR_CI (0x00000020) /* CPU Space mask */
|
||||||
|
#define MCF5272_RAMBAR_SC (0x00000010) /* Supervisor Code Space Mask */
|
||||||
|
#define MCF5272_RAMBAR_SD (0x00000008) /* Supervisor Data Space Mask */
|
||||||
|
#define MCF5272_RAMBAR_UC (0x00000004) /* User Code Space Mask */
|
||||||
|
#define MCF5272_RAMBAR_UD (0x00000002) /* User Data Space Mask */
|
||||||
|
#define MCF5272_RAMBAR_V (0x00000001) /* Contents of RAMBAR are valid */
|
||||||
|
|
||||||
|
/* MBAR - Module Base Address Register */
|
||||||
|
#define MCF5272_MBAR_BA (0xffff0000) /* Base Address */
|
||||||
|
#define MCF5272_MBAR_SC (0x00000010) /* Supervisor Code Space Mask */
|
||||||
|
#define MCF5272_MBAR_SD (0x00000008) /* Supervisor Data Space Mask */
|
||||||
|
#define MCF5272_MBAR_UC (0x00000004) /* User Code Space Mask */
|
||||||
|
#define MCF5272_MBAR_UD (0x00000002) /* User Data Space Mask */
|
||||||
|
#define MCF5272_MBAR_V (0x00000001) /* Contents of MBAR are valid */
|
||||||
|
|
||||||
|
/* CACR - Cache Control Register */
|
||||||
|
#define MCF5272_CACR_CENB (0x80000000) /* Cache Enable */
|
||||||
|
#define MCF5272_CACR_CPDI (0x10000000) /* Disable CPUSHL Invalidation */
|
||||||
|
#define MCF5272_CACR_CFRZ (0x08000000) /* Cache Freeze */
|
||||||
|
#define MCF5272_CACR_CINV (0x01000000) /* Cache Invalidate */
|
||||||
|
#define MCF5272_CACR_CEIB (0x00000400) /* Cache Enable Noncacheable
|
||||||
|
instruction bursting */
|
||||||
|
#define MCF5272_CACR_DCM (0x00000200) /* Default cache mode - noncacheable*/
|
||||||
|
#define MCF5272_CACR_DBWE (0x00000100) /* Default Buffered Write Enable */
|
||||||
|
#define MCF5272_CACR_DWP (0x00000020) /* Default Write Protection */
|
||||||
|
#define MCF5272_CACR_CLNF (0x00000003) /* Cache Line Fill */
|
||||||
|
|
||||||
|
/* ACRx - Cache Access Control Registers */
|
||||||
|
#define MCF5272_ACR_BA (0xff000000) /* Address Base */
|
||||||
|
#define MCF5272_ACR_BAM (0x00ff0000) /* Address Mask */
|
||||||
|
#define MCF5272_ACR_EN (0x00008000) /* Enable */
|
||||||
|
#define MCF5272_ACR_SM_USR (0x00000000) /* Match if user mode */
|
||||||
|
#define MCF5272_ACR_SM_SVR (0x00002000) /* Match if supervisor mode */
|
||||||
|
#define MCF5272_ACR_SM_ANY (0x00004000) /* Match Always */
|
||||||
|
#define MCF527_ACR_CM (0x00000040) /* Cache Mode (1 - noncacheable) */
|
||||||
|
#define MCF5272_ACR_BWE (0x00000020) /* Buffered Write Enable */
|
||||||
|
#define MCF5272_ACR_WP (0x00000004) /* Write Protect */
|
||||||
|
#define MCF5272_ACR_BASE(base) ((base) & MCF5272_ACR_BA)
|
||||||
|
#define MCF5272_ACR_MASK(mask) (((mask) >> 8) & MCF5272_ACR_BAM)
|
||||||
|
|
||||||
|
|
||||||
|
#define MCF5272_ICR1_INT1_PI (bit(31))
|
||||||
|
#define MCF5272_ICR1_INT1_IPL(x) ((x) << 28)
|
||||||
|
#define MCF5272_ICR1_INT1_MASK ((7) << 28)
|
||||||
|
#define MCF5272_ICR1_INT2_PI (bit(27))
|
||||||
|
#define MCF5272_ICR1_INT2_IPL(x) ((x) << 24)
|
||||||
|
#define MCF5272_ICR1_INT2_MASK ((7) << 24)
|
||||||
|
#define MCF5272_ICR1_INT3_PI (bit(23))
|
||||||
|
#define MCF5272_ICR1_INT3_IPL(x) ((x) << 20)
|
||||||
|
#define MCF5272_ICR1_INT3_MASK ((7) << 20)
|
||||||
|
#define MCF5272_ICR1_INT3_PI (bit(19))
|
||||||
|
#define MCF5272_ICR1_INT3_IPL(x) ((x) << 16)
|
||||||
|
#define MCF5272_ICR1_INT3_MASK ((7) << 16)
|
||||||
|
#define MCF5272_ICR1_TMR0_PI (bit(15))
|
||||||
|
#define MCF5272_ICR1_TMR0_IPL(x) ((x) << 12)
|
||||||
|
#define MCF5272_ICR1_TMR0_MASK ((7) << 12)
|
||||||
|
#define MCF5272_ICR1_TMR1_PI (bit(11))
|
||||||
|
#define MCF5272_ICR1_TMR1_IPL(x) ((x) << 8)
|
||||||
|
#define MCF5272_ICR1_TMR1_MASK ((7) << 8)
|
||||||
|
#define MCF5272_ICR1_TMR2_PI (bit(7))
|
||||||
|
#define MCF5272_ICR1_TMR2_IPL(x) ((x) << 4)
|
||||||
|
#define MCF5272_ICR1_TMR2_MASK ((7) << 4)
|
||||||
|
#define MCF5272_ICR1_TMR3_PI (bit(3))
|
||||||
|
#define MCF5272_ICR1_TMR3_IPL(x) ((x) << 0)
|
||||||
|
#define MCF5272_ICR1_TMR3_MASK ((7) << 0)
|
||||||
|
|
||||||
|
#define MCF5272_ICR3_USB4_PI (bit(31))
|
||||||
|
#define MCF5272_ICR3_USB4_IPL(x) ((x) << 28)
|
||||||
|
#define MCF5272_ICR3_USB4_MASK ((7) << 28)
|
||||||
|
#define MCF5272_ICR3_USB5_PI (bit(27))
|
||||||
|
#define MCF5272_ICR3_USB5_IPL(x) ((x) << 24)
|
||||||
|
#define MCF5272_ICR3_USB5_MASK ((7) << 24)
|
||||||
|
#define MCF5272_ICR3_USB6_PI (bit(23))
|
||||||
|
#define MCF5272_ICR3_USB6_IPL(x) ((x) << 20)
|
||||||
|
#define MCF5272_ICR3_USB6_MASK ((7) << 20)
|
||||||
|
#define MCF5272_ICR3_USB7_PI (bit(19))
|
||||||
|
#define MCF5272_ICR3_USB7_IPL(x) ((x) << 16)
|
||||||
|
#define MCF5272_ICR3_USB7_MASK ((7) << 16)
|
||||||
|
#define MCF5272_ICR3_DMA_PI (bit(15))
|
||||||
|
#define MCF5272_ICR3_DMA_IPL(x) ((x) << 12)
|
||||||
|
#define MCF5272_ICR3_DMA_MASK ((7) << 12)
|
||||||
|
#define MCF5272_ICR3_ERX_PI (bit(11))
|
||||||
|
#define MCF5272_ICR3_ERX_IPL(x) ((x) << 8)
|
||||||
|
#define MCF5272_ICR3_ERX_MASK ((7) << 8)
|
||||||
|
#define MCF5272_ICR3_ETX_PI (bit(7))
|
||||||
|
#define MCF5272_ICR3_ETX_IPL(x) ((x) << 4)
|
||||||
|
#define MCF5272_ICR3_ETX_MASK ((7) << 4)
|
||||||
|
#define MCF5272_ICR3_ENTC_PI (bit(3))
|
||||||
|
#define MCF5272_ICR3_ENTC_IPL(x) ((x) << 0)
|
||||||
|
#define MCF5272_ICR3_ENTC_MASK ((7) << 0)
|
||||||
|
|
||||||
|
|
||||||
|
#define MCF5272_USR_RB (bit(7))
|
||||||
|
#define MCF5272_USR_FE (bit(6))
|
||||||
|
#define MCF5272_USR_PE (bit(5))
|
||||||
|
#define MCF5272_USR_OE (bit(4))
|
||||||
|
#define MCF5272_USR_TXEMP (bit(3))
|
||||||
|
#define MCF5272_USR_TXRDY (bit(2))
|
||||||
|
#define MCF5272_USR_FFULL (bit(1))
|
||||||
|
#define MCF5272_USR_RXRDY (bit(0))
|
||||||
|
|
||||||
|
#define MCF5272_TMR_PS_MASK 0xff00
|
||||||
|
#define MCF5272_TMR_PS_SHIFT 8
|
||||||
|
#define MCF5272_TMR_CE_DISABLE (0 << 6)
|
||||||
|
#define MCF5272_TMR_CE_RISING (1 << 6)
|
||||||
|
#define MCF5272_TMR_CE_FALLING (2 << 6)
|
||||||
|
#define MCF5272_TMR_CE_ANY (3 << 6)
|
||||||
|
#define MCF5272_TMR_OM (bit(5))
|
||||||
|
#define MCF5272_TMR_ORI (bit(4))
|
||||||
|
#define MCF5272_TMR_FRR (bit(3))
|
||||||
|
#define MCF5272_TMR_CLK_STOP (0 << 1)
|
||||||
|
#define MCF5272_TMR_CLK_MSTR (1 << 1)
|
||||||
|
#define MCF5272_TMR_CLK_MSTR16 (2 << 1)
|
||||||
|
#define MCF5272_TMR_CLK_TIN (3 << 1)
|
||||||
|
#define MCF5272_TMR_RST (bit(0))
|
||||||
|
#define MCF5272_TER_REF (bit(1))
|
||||||
|
#define MCF5272_TER_CAP (bit(0))
|
||||||
|
|
||||||
|
#define MCF5272_SCR_PRI (bit(8))
|
||||||
|
#define MCF5272_SCR_AR (bit(7))
|
||||||
|
#define MCF5272_SCR_SRST (bit(6))
|
||||||
|
#define MCF5272_SCR_BUSLOCK (bit(3))
|
||||||
|
#define MCF5272_SCR_HWR_128 (0)
|
||||||
|
#define MCF5272_SCR_HWR_256 (1)
|
||||||
|
#define MCF5272_SCR_HWR_512 (2)
|
||||||
|
#define MCF5272_SCR_HWR_1024 (3)
|
||||||
|
#define MCF5272_SCR_HWR_2048 (4)
|
||||||
|
#define MCF5272_SCR_HWR_4096 (5)
|
||||||
|
#define MCF5272_SCR_HWR_8192 (6)
|
||||||
|
#define MCF5272_SCR_HWR_16384 (7)
|
||||||
|
|
||||||
|
#define MCF5272_SPR_ADC (bit(15))
|
||||||
|
#define MCF5272_SPR_WPV (bit(15))
|
||||||
|
#define MCF5272_SPR_SMV (bit(15))
|
||||||
|
#define MCF5272_SPR_PE (bit(15))
|
||||||
|
#define MCF5272_SPR_HWT (bit(15))
|
||||||
|
#define MCF5272_SPR_RPV (bit(15))
|
||||||
|
#define MCF5272_SPR_EXT (bit(15))
|
||||||
|
#define MCF5272_SPR_SUV (bit(15))
|
||||||
|
#define MCF5272_SPR_ADCEN (bit(15))
|
||||||
|
#define MCF5272_SPR_WPVEN (bit(15))
|
||||||
|
#define MCF5272_SPR_SMVEN (bit(15))
|
||||||
|
#define MCF5272_SPR_PEEN (bit(15))
|
||||||
|
#define MCF5272_SPR_HWTEN (bit(15))
|
||||||
|
#define MCF5272_SPR_RPVEN (bit(15))
|
||||||
|
#define MCF5272_SPR_EXTEN (bit(15))
|
||||||
|
#define MCF5272_SPR_SUVEN (bit(15))
|
||||||
|
|
||||||
|
#define MCF5272_ENET_TX_RT (bit(25))
|
||||||
|
#define MCF5272_ENET_ETHERN_EN (bit(1))
|
||||||
|
#define MCF5272_ENET_RESET (bit(0))
|
||||||
|
|
||||||
|
#define MCF5272_ENET_EIR_HBERR (bit(31))
|
||||||
|
#define MCF5272_ENET_EIR_BABR (bit(30))
|
||||||
|
#define MCF5272_ENET_EIR_BABT (bit(29))
|
||||||
|
#define MCF5272_ENET_EIR_GRA (bit(28))
|
||||||
|
#define MCF5272_ENET_EIR_TXF (bit(27))
|
||||||
|
#define MCF5272_ENET_EIR_TXB (bit(26))
|
||||||
|
#define MCF5272_ENET_EIR_RXF (bit(25))
|
||||||
|
#define MCF5272_ENET_EIR_RXB (bit(24))
|
||||||
|
#define MCF5272_ENET_EIR_MII (bit(23))
|
||||||
|
#define MCF5272_ENET_EIR_EBERR (bit(22))
|
||||||
|
#define MCF5272_ENET_EIR_UMINT (bit(21))
|
||||||
|
|
||||||
|
#define MCF5272_ENET_RCR_PROM (bit(3))
|
||||||
|
#define MCF5272_ENET_RCR_MII (bit(2))
|
||||||
|
#define MCF5272_ENET_RCR_DRT (bit(1))
|
||||||
|
#define MCF5272_ENET_RCR_LOOP (bit(0))
|
||||||
|
|
||||||
|
#define MCF5272_ENET_TCR_FDEN (bit(2))
|
||||||
|
#define MCF5272_ENET_TCR_HBC (bit(1))
|
||||||
|
#define MCF5272_ENET_TCR_GTS (bit(0))
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef ASM
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned32 mbar; /* READ ONLY!! */
|
||||||
|
|
||||||
|
volatile unsigned16 scr;
|
||||||
|
volatile unsigned16 _res0;
|
||||||
|
|
||||||
|
volatile unsigned16 _res1;
|
||||||
|
volatile unsigned16 spr;
|
||||||
|
|
||||||
|
volatile unsigned32 pmr;
|
||||||
|
|
||||||
|
volatile unsigned16 _res2;
|
||||||
|
volatile unsigned16 alpr;
|
||||||
|
|
||||||
|
volatile unsigned32 dir;
|
||||||
|
} sim_regs_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned32 icr1;
|
||||||
|
volatile unsigned32 icr2;
|
||||||
|
volatile unsigned32 icr3;
|
||||||
|
volatile unsigned32 icr4;
|
||||||
|
volatile unsigned32 isr;
|
||||||
|
volatile unsigned32 pitr;
|
||||||
|
volatile unsigned32 piwr;
|
||||||
|
volatile unsigned8 _res0[3];
|
||||||
|
volatile unsigned8 pivr;
|
||||||
|
} intctrl_regs_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned32 csbr0;
|
||||||
|
volatile unsigned32 csor0;
|
||||||
|
volatile unsigned32 csbr1;
|
||||||
|
volatile unsigned32 csor1;
|
||||||
|
volatile unsigned32 csbr2;
|
||||||
|
volatile unsigned32 csor2;
|
||||||
|
volatile unsigned32 csbr3;
|
||||||
|
volatile unsigned32 csor3;
|
||||||
|
volatile unsigned32 csbr4;
|
||||||
|
volatile unsigned32 csor4;
|
||||||
|
volatile unsigned32 csbr5;
|
||||||
|
volatile unsigned32 csor5;
|
||||||
|
volatile unsigned32 csbr6;
|
||||||
|
volatile unsigned32 csor6;
|
||||||
|
volatile unsigned32 csbr7;
|
||||||
|
volatile unsigned32 csor7;
|
||||||
|
} chipsel_regs_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned32 pacnt;
|
||||||
|
|
||||||
|
volatile unsigned16 paddr;
|
||||||
|
volatile unsigned16 _res0;
|
||||||
|
|
||||||
|
volatile unsigned16 _res1;
|
||||||
|
volatile unsigned16 padat;
|
||||||
|
|
||||||
|
volatile unsigned32 pbcnt;
|
||||||
|
|
||||||
|
volatile unsigned16 pbddr;
|
||||||
|
volatile unsigned16 _res2;
|
||||||
|
|
||||||
|
volatile unsigned16 _res3;
|
||||||
|
volatile unsigned16 pbdat;
|
||||||
|
|
||||||
|
volatile unsigned16 pcddr;
|
||||||
|
volatile unsigned16 _res4;
|
||||||
|
|
||||||
|
volatile unsigned16 _res5;
|
||||||
|
volatile unsigned16 pcdat;
|
||||||
|
|
||||||
|
volatile unsigned32 pdcnt;
|
||||||
|
} gpio_regs_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned32 qmr;
|
||||||
|
volatile unsigned32 qdlyr;
|
||||||
|
volatile unsigned32 qwr;
|
||||||
|
volatile unsigned32 qir;
|
||||||
|
volatile unsigned32 qar;
|
||||||
|
volatile unsigned32 qdr;
|
||||||
|
} qspi_regs_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned8 pwcr1;
|
||||||
|
volatile unsigned8 _res0[3];
|
||||||
|
|
||||||
|
volatile unsigned8 pwcr2;
|
||||||
|
volatile unsigned8 _res1[3];
|
||||||
|
|
||||||
|
volatile unsigned8 pwcr3;
|
||||||
|
volatile unsigned8 _res2[3];
|
||||||
|
|
||||||
|
volatile unsigned8 pwwd1;
|
||||||
|
volatile unsigned8 _res3[3];
|
||||||
|
|
||||||
|
volatile unsigned8 pwwd2;
|
||||||
|
volatile unsigned8 _res4[3];
|
||||||
|
|
||||||
|
volatile unsigned8 pwwd3;
|
||||||
|
volatile unsigned8 _res5[3];
|
||||||
|
} pwm_regs_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned32 dcmr;
|
||||||
|
|
||||||
|
volatile unsigned16 _res0;
|
||||||
|
volatile unsigned16 dcir;
|
||||||
|
|
||||||
|
volatile unsigned32 dbcr;
|
||||||
|
|
||||||
|
volatile unsigned32 dsar;
|
||||||
|
|
||||||
|
volatile unsigned32 ddar;
|
||||||
|
} dma_regs_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned8 umr; /* 0x000 */
|
||||||
|
volatile unsigned8 _res0[3];
|
||||||
|
|
||||||
|
volatile unsigned8 ucsr; /* 0x004 */
|
||||||
|
volatile unsigned8 _res2[3];
|
||||||
|
|
||||||
|
volatile unsigned8 ucr; /* 0x008 */
|
||||||
|
volatile unsigned8 _res3[3];
|
||||||
|
|
||||||
|
volatile unsigned8 udata; /* 0x00c */
|
||||||
|
volatile unsigned8 _res4[3];
|
||||||
|
|
||||||
|
volatile unsigned8 uccr; /* 0x010 */
|
||||||
|
volatile unsigned8 _res6[3];
|
||||||
|
|
||||||
|
volatile unsigned8 uisr; /* 0x014 */
|
||||||
|
volatile unsigned8 _res8[3];
|
||||||
|
|
||||||
|
volatile unsigned8 ubg1; /* 0x018 */
|
||||||
|
volatile unsigned8 _res10[3];
|
||||||
|
|
||||||
|
volatile unsigned8 ubg2; /* 0x01c */
|
||||||
|
volatile unsigned8 _res11[3];
|
||||||
|
|
||||||
|
volatile unsigned8 uabr1; /* 0x020 */
|
||||||
|
volatile unsigned8 _res12[3];
|
||||||
|
|
||||||
|
volatile unsigned8 uabr2; /* 0x024 */
|
||||||
|
volatile unsigned8 _res13[3];
|
||||||
|
|
||||||
|
volatile unsigned8 utxfcsr; /* 0x028 */
|
||||||
|
volatile unsigned8 _res14[3];
|
||||||
|
|
||||||
|
volatile unsigned8 urxfcsr; /* 0x02c */
|
||||||
|
volatile unsigned8 _res15[3];
|
||||||
|
|
||||||
|
volatile unsigned8 ufpdn; /* 0x030 */
|
||||||
|
volatile unsigned8 _res16[3];
|
||||||
|
|
||||||
|
volatile unsigned8 uip; /* 0x034 */
|
||||||
|
volatile unsigned8 _res17[3];
|
||||||
|
|
||||||
|
volatile unsigned8 uop1; /* 0x038 */
|
||||||
|
volatile unsigned8 _res18[3];
|
||||||
|
|
||||||
|
volatile unsigned8 uop0; /* 0x03c */
|
||||||
|
volatile unsigned8 _res19[3];
|
||||||
|
} uart_regs_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned16 tmr0;
|
||||||
|
volatile unsigned16 _res0;
|
||||||
|
|
||||||
|
volatile unsigned16 trr0;
|
||||||
|
volatile unsigned16 _res1;
|
||||||
|
|
||||||
|
volatile unsigned16 tcap0;
|
||||||
|
volatile unsigned16 _res2;
|
||||||
|
|
||||||
|
volatile unsigned16 tcn0;
|
||||||
|
volatile unsigned16 _res3;
|
||||||
|
|
||||||
|
volatile unsigned16 ter0;
|
||||||
|
volatile unsigned16 _res4;
|
||||||
|
|
||||||
|
volatile unsigned8 _res40[12];
|
||||||
|
|
||||||
|
volatile unsigned16 tmr1;
|
||||||
|
volatile unsigned16 _res5;
|
||||||
|
|
||||||
|
volatile unsigned16 trr1;
|
||||||
|
volatile unsigned16 _res6;
|
||||||
|
|
||||||
|
volatile unsigned16 tcap1;
|
||||||
|
volatile unsigned16 _res7;
|
||||||
|
|
||||||
|
volatile unsigned16 tcn1;
|
||||||
|
volatile unsigned16 _res8;
|
||||||
|
|
||||||
|
volatile unsigned16 ter1;
|
||||||
|
volatile unsigned16 _res9;
|
||||||
|
|
||||||
|
volatile unsigned8 _res91[12];
|
||||||
|
|
||||||
|
volatile unsigned16 tmr2;
|
||||||
|
volatile unsigned16 _res10;
|
||||||
|
|
||||||
|
volatile unsigned16 trr2;
|
||||||
|
volatile unsigned16 _res11;
|
||||||
|
|
||||||
|
volatile unsigned16 tcap2;
|
||||||
|
volatile unsigned16 _res12;
|
||||||
|
|
||||||
|
volatile unsigned16 tcn2;
|
||||||
|
volatile unsigned16 _res13;
|
||||||
|
|
||||||
|
volatile unsigned16 ter2;
|
||||||
|
volatile unsigned16 _res14;
|
||||||
|
|
||||||
|
volatile unsigned8 _res140[12];
|
||||||
|
|
||||||
|
volatile unsigned16 tmr3;
|
||||||
|
volatile unsigned16 _res15;
|
||||||
|
|
||||||
|
volatile unsigned16 trr3;
|
||||||
|
volatile unsigned16 _res16;
|
||||||
|
|
||||||
|
volatile unsigned16 tcap3;
|
||||||
|
volatile unsigned16 _res17;
|
||||||
|
|
||||||
|
volatile unsigned16 tcn3;
|
||||||
|
volatile unsigned16 _res18;
|
||||||
|
|
||||||
|
volatile unsigned16 ter3;
|
||||||
|
volatile unsigned16 _res19;
|
||||||
|
|
||||||
|
volatile unsigned8 _res190[12];
|
||||||
|
|
||||||
|
volatile unsigned16 wrrr;
|
||||||
|
volatile unsigned16 _res20;
|
||||||
|
|
||||||
|
volatile unsigned16 wirr;
|
||||||
|
volatile unsigned16 _res21;
|
||||||
|
|
||||||
|
volatile unsigned16 wcr;
|
||||||
|
volatile unsigned16 _res22;
|
||||||
|
|
||||||
|
volatile unsigned16 wer;
|
||||||
|
volatile unsigned16 _res23;
|
||||||
|
} timer_regs_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned32 p0b1rr;
|
||||||
|
volatile unsigned32 p1b1rr;
|
||||||
|
volatile unsigned32 p2b1rr;
|
||||||
|
volatile unsigned32 p3b1rr;
|
||||||
|
volatile unsigned32 p0b2rr;
|
||||||
|
volatile unsigned32 p1b2rr;
|
||||||
|
volatile unsigned32 p2b2rr;
|
||||||
|
volatile unsigned32 p3b2rr;
|
||||||
|
|
||||||
|
volatile unsigned8 p0drr;
|
||||||
|
volatile unsigned8 p1drr;
|
||||||
|
volatile unsigned8 p2drr;
|
||||||
|
volatile unsigned8 p3drr;
|
||||||
|
|
||||||
|
volatile unsigned32 p0b1tr;
|
||||||
|
volatile unsigned32 p1b1tr;
|
||||||
|
volatile unsigned32 p2b1tr;
|
||||||
|
volatile unsigned32 p3b1tr;
|
||||||
|
volatile unsigned32 p0b2tr;
|
||||||
|
volatile unsigned32 p1b2tr;
|
||||||
|
volatile unsigned32 p2b2tr;
|
||||||
|
volatile unsigned32 p3b2tr;
|
||||||
|
|
||||||
|
volatile unsigned8 p0dtr;
|
||||||
|
volatile unsigned8 p1dtr;
|
||||||
|
volatile unsigned8 p2dtr;
|
||||||
|
volatile unsigned8 p3dtr;
|
||||||
|
|
||||||
|
volatile unsigned16 p0cr;
|
||||||
|
volatile unsigned16 p1cr;
|
||||||
|
volatile unsigned16 p2cr;
|
||||||
|
volatile unsigned16 p3cr;
|
||||||
|
volatile unsigned16 p0icr;
|
||||||
|
volatile unsigned16 p1icr;
|
||||||
|
volatile unsigned16 p2icr;
|
||||||
|
volatile unsigned16 p3icr;
|
||||||
|
volatile unsigned16 p0gmr;
|
||||||
|
volatile unsigned16 p1gmr;
|
||||||
|
volatile unsigned16 p2gmr;
|
||||||
|
volatile unsigned16 p3gmr;
|
||||||
|
volatile unsigned16 p0gmt;
|
||||||
|
volatile unsigned16 p1gmt;
|
||||||
|
volatile unsigned16 p2gmt;
|
||||||
|
volatile unsigned16 p3gmt;
|
||||||
|
|
||||||
|
volatile unsigned8 _res0;
|
||||||
|
volatile unsigned8 pgmts;
|
||||||
|
volatile unsigned8 pgmta;
|
||||||
|
volatile unsigned8 _res1;
|
||||||
|
volatile unsigned8 p0gcir;
|
||||||
|
volatile unsigned8 p1gcir;
|
||||||
|
volatile unsigned8 p2gcir;
|
||||||
|
volatile unsigned8 p3gcir;
|
||||||
|
volatile unsigned8 p0gcit;
|
||||||
|
volatile unsigned8 p1gcit;
|
||||||
|
volatile unsigned8 p2gcit;
|
||||||
|
volatile unsigned8 p3gcit;
|
||||||
|
volatile unsigned8 _res3[3];
|
||||||
|
volatile unsigned8 pgcitsr;
|
||||||
|
volatile unsigned8 _res4[3];
|
||||||
|
volatile unsigned8 pdcsr;
|
||||||
|
|
||||||
|
volatile unsigned16 p0psr;
|
||||||
|
volatile unsigned16 p1psr;
|
||||||
|
volatile unsigned16 p2psr;
|
||||||
|
volatile unsigned16 p3psr;
|
||||||
|
volatile unsigned16 pasr;
|
||||||
|
volatile unsigned8 _res5;
|
||||||
|
volatile unsigned8 plcr;
|
||||||
|
volatile unsigned16 _res6;
|
||||||
|
volatile unsigned16 pdrqr;
|
||||||
|
volatile unsigned16 p0sdr;
|
||||||
|
volatile unsigned16 p1sdr;
|
||||||
|
volatile unsigned16 p2sdr;
|
||||||
|
volatile unsigned16 p3sdr;
|
||||||
|
volatile unsigned16 _res7;
|
||||||
|
volatile unsigned16 pcsr;
|
||||||
|
} plic_regs_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned32 ecr;
|
||||||
|
volatile unsigned32 eir;
|
||||||
|
volatile unsigned32 eimr;
|
||||||
|
volatile unsigned32 ivsr;
|
||||||
|
volatile unsigned32 rdar;
|
||||||
|
volatile unsigned32 tdar;
|
||||||
|
volatile unsigned32 _res0[10];
|
||||||
|
volatile unsigned32 mmfr;
|
||||||
|
volatile unsigned32 mscr;
|
||||||
|
volatile unsigned32 _res1[17];
|
||||||
|
volatile unsigned32 frbr;
|
||||||
|
volatile unsigned32 frsr;
|
||||||
|
volatile unsigned32 _res2[4];
|
||||||
|
volatile unsigned32 tfwr;
|
||||||
|
volatile unsigned32 _res3[1];
|
||||||
|
volatile unsigned32 tfsr;
|
||||||
|
volatile unsigned32 _res4[21];
|
||||||
|
volatile unsigned32 rcr;
|
||||||
|
volatile unsigned32 mflr;
|
||||||
|
volatile unsigned32 _res5[14];
|
||||||
|
volatile unsigned32 tcr;
|
||||||
|
volatile unsigned32 _res6[158];
|
||||||
|
volatile unsigned32 malr;
|
||||||
|
volatile unsigned32 maur;
|
||||||
|
volatile unsigned32 htur;
|
||||||
|
volatile unsigned32 htlr;
|
||||||
|
volatile unsigned32 erdsr;
|
||||||
|
volatile unsigned32 etdsr;
|
||||||
|
volatile unsigned32 emrbr;
|
||||||
|
/* volatile unsigned8 fifo[448]; */
|
||||||
|
} enet_regs_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile unsigned16 _res0;
|
||||||
|
volatile unsigned16 fnr;
|
||||||
|
volatile unsigned16 _res1;
|
||||||
|
volatile unsigned16 fnmr;
|
||||||
|
volatile unsigned16 _res2;
|
||||||
|
volatile unsigned16 rfmr;
|
||||||
|
volatile unsigned16 _res3;
|
||||||
|
volatile unsigned16 rfmmr;
|
||||||
|
volatile unsigned8 _res4[3];
|
||||||
|
volatile unsigned8 far;
|
||||||
|
volatile unsigned32 asr;
|
||||||
|
volatile unsigned32 drr1;
|
||||||
|
volatile unsigned32 drr2;
|
||||||
|
volatile unsigned16 _res5;
|
||||||
|
volatile unsigned16 specr;
|
||||||
|
volatile unsigned16 _res6;
|
||||||
|
volatile unsigned16 ep0sr;
|
||||||
|
|
||||||
|
volatile unsigned32 iep0cfg;
|
||||||
|
volatile unsigned32 oep0cfg;
|
||||||
|
volatile unsigned32 ep1cfg;
|
||||||
|
volatile unsigned32 ep2cfg;
|
||||||
|
volatile unsigned32 ep3cfg;
|
||||||
|
volatile unsigned32 ep4cfg;
|
||||||
|
volatile unsigned32 ep5cfg;
|
||||||
|
volatile unsigned32 ep6cfg;
|
||||||
|
volatile unsigned32 ep7cfg;
|
||||||
|
volatile unsigned32 ep0ctl;
|
||||||
|
|
||||||
|
volatile unsigned16 _res7;
|
||||||
|
volatile unsigned16 ep1ctl;
|
||||||
|
volatile unsigned16 _res8;
|
||||||
|
volatile unsigned16 ep2ctl;
|
||||||
|
volatile unsigned16 _res9;
|
||||||
|
volatile unsigned16 ep3ctl;
|
||||||
|
volatile unsigned16 _res10;
|
||||||
|
volatile unsigned16 ep4ctl;
|
||||||
|
volatile unsigned16 _res11;
|
||||||
|
volatile unsigned16 ep5ctl;
|
||||||
|
volatile unsigned16 _res12;
|
||||||
|
volatile unsigned16 ep6ctl;
|
||||||
|
volatile unsigned16 _res13;
|
||||||
|
volatile unsigned16 ep7ctl;
|
||||||
|
|
||||||
|
volatile unsigned32 ep0isr;
|
||||||
|
|
||||||
|
volatile unsigned16 _res14;
|
||||||
|
volatile unsigned16 ep1isr;
|
||||||
|
volatile unsigned16 _res15;
|
||||||
|
volatile unsigned16 ep2isr;
|
||||||
|
volatile unsigned16 _res16;
|
||||||
|
volatile unsigned16 ep3isr;
|
||||||
|
volatile unsigned16 _res17;
|
||||||
|
volatile unsigned16 ep4isr;
|
||||||
|
volatile unsigned16 _res18;
|
||||||
|
volatile unsigned16 ep5isr;
|
||||||
|
volatile unsigned16 _res19;
|
||||||
|
volatile unsigned16 ep6isr;
|
||||||
|
volatile unsigned16 _res20;
|
||||||
|
volatile unsigned16 ep7isr;
|
||||||
|
|
||||||
|
volatile unsigned32 ep0imr;
|
||||||
|
|
||||||
|
volatile unsigned16 _res21;
|
||||||
|
volatile unsigned16 ep1imr;
|
||||||
|
volatile unsigned16 _res22;
|
||||||
|
volatile unsigned16 ep2imr;
|
||||||
|
volatile unsigned16 _res23;
|
||||||
|
volatile unsigned16 ep3imr;
|
||||||
|
volatile unsigned16 _res24;
|
||||||
|
volatile unsigned16 ep4imr;
|
||||||
|
volatile unsigned16 _res25;
|
||||||
|
volatile unsigned16 ep5imr;
|
||||||
|
volatile unsigned16 _res26;
|
||||||
|
volatile unsigned16 ep6imr;
|
||||||
|
volatile unsigned16 _res27;
|
||||||
|
volatile unsigned16 ep7imr;
|
||||||
|
|
||||||
|
volatile unsigned32 ep0dr;
|
||||||
|
volatile unsigned32 ep1dr;
|
||||||
|
volatile unsigned32 ep2dr;
|
||||||
|
volatile unsigned32 ep3dr;
|
||||||
|
volatile unsigned32 ep4dr;
|
||||||
|
volatile unsigned32 ep5dr;
|
||||||
|
volatile unsigned32 ep6dr;
|
||||||
|
volatile unsigned32 ep7dr;
|
||||||
|
|
||||||
|
volatile unsigned16 _res28;
|
||||||
|
volatile unsigned16 ep0dpr;
|
||||||
|
volatile unsigned16 _res29;
|
||||||
|
volatile unsigned16 ep1dpr;
|
||||||
|
volatile unsigned16 _res30;
|
||||||
|
volatile unsigned16 ep2dpr;
|
||||||
|
volatile unsigned16 _res31;
|
||||||
|
volatile unsigned16 ep3dpr;
|
||||||
|
volatile unsigned16 _res32;
|
||||||
|
volatile unsigned16 ep4dpr;
|
||||||
|
volatile unsigned16 _res33;
|
||||||
|
volatile unsigned16 ep5dpr;
|
||||||
|
volatile unsigned16 _res34;
|
||||||
|
volatile unsigned16 ep6dpr;
|
||||||
|
volatile unsigned16 _res35;
|
||||||
|
volatile unsigned16 ep7dpr;
|
||||||
|
/* unsigned8 ram[1024]; */
|
||||||
|
} usb_regs_t;
|
||||||
|
|
||||||
|
extern intctrl_regs_t *g_intctrl_regs;
|
||||||
|
extern chipsel_regs_t *g_chipsel_regs;
|
||||||
|
extern gpio_regs_t *g_gpio_regs;
|
||||||
|
extern qspi_regs_t *g_qspi_regs;
|
||||||
|
extern pwm_regs_t *g_pwm_regs;
|
||||||
|
extern dma_regs_t *g_dma_regs;
|
||||||
|
extern uart_regs_t *g_uart0_regs;
|
||||||
|
extern uart_regs_t *g_uart1_regs;
|
||||||
|
extern timer_regs_t *g_timer_regs;
|
||||||
|
extern plic_regs_t *g_plic_regs;
|
||||||
|
extern enet_regs_t *g_enet_regs;
|
||||||
|
extern usb_regs_t *g_usb_regs;
|
||||||
|
|
||||||
|
#endif /* ASM */
|
||||||
|
|
||||||
|
#endif /* __MCF5272_H__ */
|
||||||
2
c/src/lib/libcpu/m68k/mcf5272/timer/.cvsignore
Normal file
2
c/src/lib/libcpu/m68k/mcf5272/timer/.cvsignore
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
Makefile
|
||||||
|
Makefile.in
|
||||||
177
c/src/lib/libcpu/m68k/mcf5272/timer/timer.c
Normal file
177
c/src/lib/libcpu/m68k/mcf5272/timer/timer.c
Normal file
@@ -0,0 +1,177 @@
|
|||||||
|
/*
|
||||||
|
* Timer Init
|
||||||
|
*
|
||||||
|
* This module initializes TIMER 2 for on the MCF5272 for benchmarks.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2000 OKTET Ltd., St.-Petersburg, Russia
|
||||||
|
* Author: Victor V. Vengerov <vvv@oktet.ru>
|
||||||
|
*
|
||||||
|
* Based on work:
|
||||||
|
* Author:
|
||||||
|
* David Fiddes, D.J@fiddes.surfaid.org
|
||||||
|
* http://www.calm.hw.ac.uk/davidf/coldfire/
|
||||||
|
*
|
||||||
|
* COPYRIGHT (c) 1989-1998.
|
||||||
|
* On-Line Applications Research Corporation (OAR).
|
||||||
|
* Copyright assigned to U.S. Government, 1994.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* timer.c,v 1.1 2001/10/26 19:32:40 joel Exp
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <rtems.h>
|
||||||
|
#include <bsp.h>
|
||||||
|
#include <mcf5272/mcf5272.h>
|
||||||
|
|
||||||
|
#define TRR2_VAL 65530
|
||||||
|
|
||||||
|
rtems_unsigned32 Timer_interrupts;
|
||||||
|
|
||||||
|
rtems_boolean Timer_driver_Find_average_overhead;
|
||||||
|
|
||||||
|
/* External assembler interrupt handler routine */
|
||||||
|
extern rtems_isr timerisr(rtems_vector_number vector);
|
||||||
|
|
||||||
|
|
||||||
|
/* Timer_initialize --
|
||||||
|
* Initialize timer 2 for accurate time measurement.
|
||||||
|
*
|
||||||
|
* PARAMETERS:
|
||||||
|
* none
|
||||||
|
*
|
||||||
|
* RETURNS:
|
||||||
|
* none
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
Timer_initialize(void)
|
||||||
|
{
|
||||||
|
unsigned32 icr;
|
||||||
|
/* Catch timer2 interrupts */
|
||||||
|
set_vector(timerisr, BSP_INTVEC_TMR2, 0);
|
||||||
|
|
||||||
|
/* Reset Timer */
|
||||||
|
g_timer_regs->tmr2 = MCF5272_TMR_RST;
|
||||||
|
g_timer_regs->tmr2 = MCF5272_TMR_CLK_STOP;
|
||||||
|
g_timer_regs->tmr2 = MCF5272_TMR_RST;
|
||||||
|
g_timer_regs->tcn2 = 0; /* reset counter */
|
||||||
|
Timer_interrupts = 0; /* Clear timer ISR counter */
|
||||||
|
g_timer_regs->ter2 = MCF5272_TER_REF | MCF5272_TER_CAP;
|
||||||
|
g_timer_regs->trr2 = TRR2_VAL -1 ;
|
||||||
|
|
||||||
|
|
||||||
|
/* Set Timer 2 prescaler so that it counts in microseconds */
|
||||||
|
g_timer_regs->tmr2 = (
|
||||||
|
(((BSP_SYSTEM_FREQUENCY / 1000000) - 1) << MCF5272_TMR_PS_SHIFT) |
|
||||||
|
MCF5272_TMR_CE_DISABLE |
|
||||||
|
MCF5272_TMR_ORI |
|
||||||
|
MCF5272_TMR_FRR |
|
||||||
|
MCF5272_TMR_CLK_MSTR |
|
||||||
|
MCF5272_TMR_RST);
|
||||||
|
|
||||||
|
/* Initialize interrupts for timer2 */
|
||||||
|
icr = g_intctrl_regs->icr1;
|
||||||
|
icr = icr & ~(MCF5272_ICR1_TMR2_MASK | MCF5272_ICR1_TMR2_PI);
|
||||||
|
icr |= (MCF5272_ICR1_TMR2_IPL(BSP_INTLVL_TMR2) | MCF5272_ICR1_TMR2_PI);
|
||||||
|
g_intctrl_regs->icr1 = icr;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The following controls the behavior of Read_timer().
|
||||||
|
*
|
||||||
|
* FIND_AVG_OVERHEAD * instructs the routine to return the "raw" count.
|
||||||
|
*
|
||||||
|
* 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 2.0 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 */
|
||||||
|
|
||||||
|
/* Read_timer --
|
||||||
|
* Read timer value in microsecond units since timer start.
|
||||||
|
*
|
||||||
|
* PARAMETERS:
|
||||||
|
* none
|
||||||
|
*
|
||||||
|
* RETURNS:
|
||||||
|
* number of microseconds since timer has been started
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
Read_timer( void )
|
||||||
|
{
|
||||||
|
rtems_unsigned16 clicks;
|
||||||
|
rtems_unsigned32 total;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Read the timer and see how many clicks it has been since counter
|
||||||
|
* rolled over.
|
||||||
|
*/
|
||||||
|
clicks = g_timer_regs->tcn2;
|
||||||
|
|
||||||
|
/* Stop Timer... */
|
||||||
|
g_timer_regs->tmr2 = MCF5272_TMR_CLK_STOP | MCF5272_TMR_RST;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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 = (Timer_interrupts * TRR2_VAL) + clicks;
|
||||||
|
|
||||||
|
if ( Timer_driver_Find_average_overhead == 1 )
|
||||||
|
return total; /* in XXX microsecond units */
|
||||||
|
|
||||||
|
if ( total < LEAST_VALID )
|
||||||
|
return 0; /* below timer resolution */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return the count in microseconds
|
||||||
|
*/
|
||||||
|
return (total - AVG_OVERHEAD);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Empty_function --
|
||||||
|
* Empty function call used in loops to measure basic cost of looping
|
||||||
|
* in Timing Test Suite.
|
||||||
|
*
|
||||||
|
* PARAMETERS:
|
||||||
|
* none
|
||||||
|
*
|
||||||
|
* RETURNS:
|
||||||
|
* RTEMS_SUCCESSFUL
|
||||||
|
*/
|
||||||
|
rtems_status_code
|
||||||
|
Empty_function(void)
|
||||||
|
{
|
||||||
|
return RTEMS_SUCCESSFUL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set_find_average_overhead --
|
||||||
|
* This routine is invoked by the "Check Timer" (tmck) test in the
|
||||||
|
* RTEMS Timing Test Suite. It makes the Read_timer routine not
|
||||||
|
* subtract the overhead required to initialize and read the benchmark
|
||||||
|
* timer.
|
||||||
|
*
|
||||||
|
* PARAMETERS:
|
||||||
|
* find_flag - boolean flag, TRUE if overhead must not be subtracted.
|
||||||
|
*
|
||||||
|
* RETURNS:
|
||||||
|
* none
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
Set_find_average_overhead(rtems_boolean find_flag)
|
||||||
|
{
|
||||||
|
Timer_driver_Find_average_overhead = find_flag;
|
||||||
|
}
|
||||||
50
c/src/lib/libcpu/m68k/mcf5272/timer/timerisr.S
Normal file
50
c/src/lib/libcpu/m68k/mcf5272/timer/timerisr.S
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
/*
|
||||||
|
* Handle MCF5272 TIMER2 interrupts.
|
||||||
|
*
|
||||||
|
* All code in this routine is pure overhead which can perturb the
|
||||||
|
* accuracy of RTEMS' timing test suite.
|
||||||
|
*
|
||||||
|
* See also: Read_timer()
|
||||||
|
*
|
||||||
|
* To reduce overhead this is best to be the "rawest" hardware interupt
|
||||||
|
* handler you can write. This should be the only interrupt which can
|
||||||
|
* occur during the measured time period.
|
||||||
|
*
|
||||||
|
* An external counter, Timer_interrupts, is incremented.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2000 OKTET Ltd., St.-Petersburg, Russia
|
||||||
|
* Author: Victor V. Vengerov <vvv@oktet.ru>
|
||||||
|
*
|
||||||
|
* This file based on work:
|
||||||
|
* Author:
|
||||||
|
* David Fiddes, D.J@fiddes.surfaid.org
|
||||||
|
* http://www.calm.hw.ac.uk/davidf/coldfire/
|
||||||
|
*
|
||||||
|
* COPYRIGHT (c) 1989-1998.
|
||||||
|
* On-Line Applications Research Corporation (OAR).
|
||||||
|
* Copyright assigned to U.S. Government, 1994.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* timerisr.S,v 1.1 2001/10/26 19:32:40 joel Exp
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "asm.h"
|
||||||
|
#include "bsp.h"
|
||||||
|
/*
|
||||||
|
#include "mcf5272/mcf5272.h"
|
||||||
|
*/
|
||||||
|
|
||||||
|
BEGIN_CODE
|
||||||
|
PUBLIC(timerisr)
|
||||||
|
SYM(timerisr):
|
||||||
|
move.l a0, a7@-
|
||||||
|
move.b # (MCF5272_TER_REF + MCF5272_TER_CAP), (a0)
|
||||||
|
addq.l #1,SYM(Timer_interrupts) | increment timer value
|
||||||
|
move.l a7@+, a0
|
||||||
|
rte
|
||||||
|
END_CODE
|
||||||
|
END
|
||||||
Reference in New Issue
Block a user