Add support for the TRS-80 Model 3
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@690 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
c90fc3b5e6
commit
c558d34600
@ -341,5 +341,8 @@
|
|||||||
* Fix broken 'clean' target on z80sim configurations
|
* Fix broken 'clean' target on z80sim configurations
|
||||||
* Re-structure arch/z80 to provide support for all ZiLOG 8-bit microcontrollers (ez8
|
* Re-structure arch/z80 to provide support for all ZiLOG 8-bit microcontrollers (ez8
|
||||||
in particular for now).
|
in particular for now).
|
||||||
|
* Add support for TRS80-Model 3 based on the xtrs emulation (http://www.tim-mann.org/xtrs.html)
|
||||||
|
Per patch from Jacques Pelletier.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -995,6 +995,8 @@ nuttx-0.3.9 2008-xx-xx Gregory Nutt <spudmonkey@racsa.co.cr>
|
|||||||
* Fix broken 'clean' target on z80sim configurations
|
* Fix broken 'clean' target on z80sim configurations
|
||||||
* Re-structure arch/z80 to provide support for all ZiLOG 8-bit microcontrollers (ez8
|
* Re-structure arch/z80 to provide support for all ZiLOG 8-bit microcontrollers (ez8
|
||||||
in particular for now).
|
in particular for now).
|
||||||
|
* Add support for TRS80-Model 3 based on the xtrs emulation (http://www.tim-mann.org/xtrs.html)
|
||||||
|
Per patch from Jacques Pelletier.
|
||||||
|
|
||||||
pascal-0.1.3 2008-xx-xx Gregory Nutt <spudmonkey@racsa.co.cr>
|
pascal-0.1.3 2008-xx-xx Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
</b></big></h1>
|
</b></big></h1>
|
||||||
<p><small>by</small></p>
|
<p><small>by</small></p>
|
||||||
<p>Gregory Nutt</p>
|
<p>Gregory Nutt</p>
|
||||||
<p><small>Last Update: February 11, 2008</small></p>
|
<p><small>Last Update: February 15, 2008</small></p>
|
||||||
</center>
|
</center>
|
||||||
|
|
||||||
<center><h1>Table of Contents</h1></center>
|
<center><h1>Table of Contents</h1></center>
|
||||||
@ -442,7 +442,7 @@
|
|||||||
z80 instruction simulator.
|
z80 instruction simulator.
|
||||||
The set simulator can be found in the NuttX CVS at
|
The set simulator can be found in the NuttX CVS at
|
||||||
http://nuttx.cvs.sourceforge.net/nuttx/misc/sims/z80sim.
|
http://nuttx.cvs.sourceforge.net/nuttx/misc/sims/z80sim.
|
||||||
This port also the SDCC toolchain (http://sdcc.sourceforge.net/")
|
This port also uses the SDCC toolchain (http://sdcc.sourceforge.net/")
|
||||||
(verified with version 2.6.0 and 2.7.0).
|
(verified with version 2.6.0 and 2.7.0).
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
@ -590,7 +590,7 @@
|
|||||||
<h3><a name="supportedboards">2.3.3 Supported Boards</a></h3>
|
<h3><a name="supportedboards">2.3.3 Supported Boards</a></h3>
|
||||||
<p>
|
<p>
|
||||||
All of the specific boards supported by NuttX are identified below.
|
All of the specific boards supported by NuttX are identified below.
|
||||||
These the the specific <i><board-name></i>'s that may be used to configure NuttX
|
These are the specific <i><board-name></i>'s that may be used to configure NuttX
|
||||||
as described <a href="#configuringnuttx">below</a>.
|
as described <a href="#configuringnuttx">below</a>.
|
||||||
</p>
|
</p>
|
||||||
<ul>
|
<ul>
|
||||||
@ -637,15 +637,21 @@
|
|||||||
This port is not quite ready for prime time.
|
This port is not quite ready for prime time.
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
|
<li><code>configs/xtrs</code>
|
||||||
|
TRS80 Model 3. This port uses a vintage computer based on the Z80.
|
||||||
|
An emulator for this computer is available to run TRS80 programs on a
|
||||||
|
linux platform (http://www.tim-mann.org/xtrs.html).
|
||||||
|
</li>
|
||||||
|
|
||||||
<li><code>configs/z16f2800100zcog</code>
|
<li><code>configs/z16f2800100zcog</code>
|
||||||
z16f Microncontroller.
|
z16f Microcontroller.
|
||||||
This port use the Zilog z16f2800100zcog development kit and the
|
This port use the Zilog z16f2800100zcog development kit and the
|
||||||
Zilog ZDS-II Windows command line tools.
|
Zilog ZDS-II Windows command line tools.
|
||||||
The development environment is Cygwin under WinXP.
|
The development environment is Cygwin under WinXP.
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
<li><code>configs/z8encore000zco</code>
|
<li><code>configs/z8encore000zco</code>
|
||||||
z8Encore! Microncontroller. This port use the Zilog z8encore000zco
|
z8Encore! Microcontroller. This port use the Zilog z8encore000zco
|
||||||
development kit, Z8F6403 part, and the Zilog ZDS-II Windows command line
|
development kit, Z8F6403 part, and the Zilog ZDS-II Windows command line
|
||||||
tools. The development environment is Cygwin under WinXP.
|
tools. The development environment is Cygwin under WinXP.
|
||||||
</li>
|
</li>
|
||||||
@ -994,7 +1000,7 @@ The system can be re-made subsequently by just typing <code>make</code>.
|
|||||||
<p><b>Inputs:</b></p>
|
<p><b>Inputs:</b></p>
|
||||||
<ul>
|
<ul>
|
||||||
<li><code>tcb</code>: Refers to a task in the ready-to-run list (normally
|
<li><code>tcb</code>: Refers to a task in the ready-to-run list (normally
|
||||||
the task at the the head of the list). It most be
|
the task at the head of the list). It most be
|
||||||
stopped, its context saved and moved into one of the
|
stopped, its context saved and moved into one of the
|
||||||
waiting task lists. It it was the task at the head
|
waiting task lists. It it was the task at the head
|
||||||
of the ready-to-run list, then a context to the new
|
of the ready-to-run list, then a context to the new
|
||||||
@ -1293,7 +1299,7 @@ The system can be re-made subsequently by just typing <code>make</code>.
|
|||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
Some architectures require a description of the the RAM configuration:
|
Some architectures require a description of the RAM configuration:
|
||||||
</p>
|
</p>
|
||||||
<ul>
|
<ul>
|
||||||
<li><code>CONFIG_DRAM_SIZE</code>:
|
<li><code>CONFIG_DRAM_SIZE</code>:
|
||||||
@ -1301,7 +1307,7 @@ The system can be re-made subsequently by just typing <code>make</code>.
|
|||||||
<li><code>CONFIG_DRAM_START</code>:
|
<li><code>CONFIG_DRAM_START</code>:
|
||||||
The start address of DRAM (physical)</li>
|
The start address of DRAM (physical)</li>
|
||||||
<li><code>CONFIG_DRAM_VSTART</code>:
|
<li><code>CONFIG_DRAM_VSTART</code>:
|
||||||
The startaddress of DRAM (virtual)</li>
|
The start address of DRAM (virtual)</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
|
76
arch/z80/include/io.h
Normal file
76
arch/z80/include/io.h
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* arch/z80/include/io.h
|
||||||
|
* arch/chip/io.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2008 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in
|
||||||
|
* the documentation and/or other materials provided with the
|
||||||
|
* distribution.
|
||||||
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||||
|
* used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||||
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||||
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||||
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||||
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||||
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __ARCH_IO_H
|
||||||
|
#define __ARCH_IO_H
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <arch/chip/io.h>
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Definitions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Types
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Variables
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Function Prototypes
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __ASSEMBLY__
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define EXTERN extern "C"
|
||||||
|
extern "C" {
|
||||||
|
#else
|
||||||
|
#define EXTERN extern
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#undef EXTERN
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __ARCH_IO_H */
|
85
arch/z80/include/z80/io.h
Normal file
85
arch/z80/include/z80/io.h
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* arch/z80/include/z80/io.h
|
||||||
|
* arch/chip/io.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2008 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in
|
||||||
|
* the documentation and/or other materials provided with the
|
||||||
|
* distribution.
|
||||||
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||||
|
* used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||||
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||||
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||||
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||||
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||||
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/* This file should never be included directed but, rather, only indirectly
|
||||||
|
* through arch/io.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __ARCH_Z80_IO_H
|
||||||
|
#define __ARCH_Z80_IO_H
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Definitions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Types
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Inline functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Variables
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Function Prototypes
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __ASSEMBLY__
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define EXTERN extern "C"
|
||||||
|
extern "C" {
|
||||||
|
#else
|
||||||
|
#define EXTERN extern
|
||||||
|
#endif
|
||||||
|
|
||||||
|
EXTERN void outp(char p, char c);
|
||||||
|
EXTERN char inp(char p);
|
||||||
|
|
||||||
|
#undef EXTERN
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __ARCH_Z80_IO_H */
|
@ -153,8 +153,16 @@ pass1.ihx: up_mem.h asm_mem.h $(SDCCLIBDIR)/myz80.lib $(HEAD_AOBJ) board/libboar
|
|||||||
echo "-l $(TOPDIR)/$$LIB" >> pass1.lnk ;\
|
echo "-l $(TOPDIR)/$$LIB" >> pass1.lnk ;\
|
||||||
done
|
done
|
||||||
@echo "-l myz80.lib" >>pass1.lnk # Name of SDCC z80 library
|
@echo "-l myz80.lib" >>pass1.lnk # Name of SDCC z80 library
|
||||||
|
ifneq ($(CONFIG_LINKER_START_AREA),)
|
||||||
|
@echo "-b START=$(CONFIG_LINKER_START_AREA)" >>pass1.lnk # Start of START area
|
||||||
|
else
|
||||||
@echo "-b START=0" >>pass1.lnk # Start of START area
|
@echo "-b START=0" >>pass1.lnk # Start of START area
|
||||||
|
endif
|
||||||
|
ifneq ($(CONFIG_LINKER_CODE_AREA),)
|
||||||
|
@echo "-b _CODE=$(CONFIG_LINKER_CODE_AREA)" >>pass1.lnk # Start of _CODE area
|
||||||
|
else
|
||||||
@echo "-b _CODE=256" >>pass1.lnk # Start of _CODE area
|
@echo "-b _CODE=256" >>pass1.lnk # Start of _CODE area
|
||||||
|
endif
|
||||||
@echo "-i" >>pass1.lnk # Intel hex format
|
@echo "-i" >>pass1.lnk # Intel hex format
|
||||||
@echo "-x" >>pass1.lnk # Hexadecimal
|
@echo "-x" >>pass1.lnk # Hexadecimal
|
||||||
@echo "-m" >>pass1.lnk # Generate a map file
|
@echo "-m" >>pass1.lnk # Generate a map file
|
||||||
@ -178,8 +186,16 @@ nuttx.ihx: up_mem.h asm_mem.h $(SDCCLIBDIR)/myz80.lib $(HEAD_AOBJ) board/libboar
|
|||||||
echo "-l $(TOPDIR)/$$LIB" >> nuttx.lnk ;\
|
echo "-l $(TOPDIR)/$$LIB" >> nuttx.lnk ;\
|
||||||
done
|
done
|
||||||
@echo "-l myz80.lib" >>nuttx.lnk # Name of SDCC z80 library
|
@echo "-l myz80.lib" >>nuttx.lnk # Name of SDCC z80 library
|
||||||
|
ifneq ($(CONFIG_LINKER_START_AREA),)
|
||||||
|
@echo "-b START=$(CONFIG_LINKER_START_AREA)" >>nuttx.lnk # Start of START area
|
||||||
|
else
|
||||||
@echo "-b START=0" >>nuttx.lnk # Start of START area
|
@echo "-b START=0" >>nuttx.lnk # Start of START area
|
||||||
|
endif
|
||||||
|
ifneq ($(CONFIG_LINKER_CODE_AREA),)
|
||||||
|
@echo "-b _CODE=$(CONFIG_LINKER_CODE_AREA)" >>nuttx.lnk # Start of _CODE area
|
||||||
|
else
|
||||||
@echo "-b _CODE=256" >>nuttx.lnk # Start of _CODE area
|
@echo "-b _CODE=256" >>nuttx.lnk # Start of _CODE area
|
||||||
|
endif
|
||||||
@echo "-i" >>nuttx.lnk # Intel hex format
|
@echo "-i" >>nuttx.lnk # Intel hex format
|
||||||
@echo "-x" >>nuttx.lnk # Hexadecimal
|
@echo "-x" >>nuttx.lnk # Hexadecimal
|
||||||
@echo "-m" >>nuttx.lnk # Generate a map file
|
@echo "-m" >>nuttx.lnk # Generate a map file
|
||||||
|
@ -43,7 +43,7 @@ CMN_CSRCS = up_initialize.c up_allocateheap.c up_createstack.c \
|
|||||||
up_mdelay.c up_udelay.c up_usestack.c
|
up_mdelay.c up_udelay.c up_usestack.c
|
||||||
|
|
||||||
CHIP_ASRCS = z80_saveusercontext.asm z80_restoreusercontext.asm
|
CHIP_ASRCS = z80_saveusercontext.asm z80_restoreusercontext.asm
|
||||||
CHIP_CSRCS = z80_initialstate.c z80_irq.c z80_copystate.c \
|
CHIP_CSRCS = z80_initialstate.c z80_io.c z80_irq.c z80_copystate.c \
|
||||||
z80_schedulesigaction.c z80_sigdeliver.c \
|
z80_schedulesigaction.c z80_sigdeliver.c \
|
||||||
z80_registerdump.c
|
z80_registerdump.c
|
||||||
|
|
||||||
|
97
arch/z80/src/z80/z80_io.c
Normal file
97
arch/z80/src/z80/z80_io.c
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* arch/z80/src/z80/z80_io.c
|
||||||
|
*
|
||||||
|
* Copyright (C) 2008 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in
|
||||||
|
* the documentation and/or other materials provided with the
|
||||||
|
* distribution.
|
||||||
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||||
|
* used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||||
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||||
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||||
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||||
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||||
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
#include <nuttx/arch.h>
|
||||||
|
/* #include <nuttx/irq.h> */
|
||||||
|
|
||||||
|
#include "up_internal.h"
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Private Definitions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Private Data
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Private Functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: outb
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Output byte c on port p
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void outp(char p, char c)
|
||||||
|
{
|
||||||
|
_asm
|
||||||
|
ld c, 4(ix) ; port
|
||||||
|
ld a, 5(ix) ; value
|
||||||
|
out (c), a
|
||||||
|
_endasm;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: inpb
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Input byte from port p
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
char inp(char p)
|
||||||
|
{
|
||||||
|
_asm
|
||||||
|
ld c, 4(ix) ;port
|
||||||
|
in l, (c)
|
||||||
|
_endasm;
|
||||||
|
}
|
@ -127,11 +127,11 @@ defconfig -- This is a configuration file similar to the Linux
|
|||||||
CONFIG_ENDIAN_BIG - define if big endian (default is little
|
CONFIG_ENDIAN_BIG - define if big endian (default is little
|
||||||
endian)
|
endian)
|
||||||
|
|
||||||
Some architectures require a description of the the RAM configuration:
|
Some architectures require a description of the RAM configuration:
|
||||||
|
|
||||||
CONFIG_DRAM_SIZE - Describes the installed DRAM.
|
CONFIG_DRAM_SIZE - Describes the installed DRAM.
|
||||||
CONFIG_DRAM_START - The start address of DRAM (physical)
|
CONFIG_DRAM_START - The start address of DRAM (physical)
|
||||||
CONFIG_DRAM_VSTART - The startaddress of DRAM (virtual)
|
CONFIG_DRAM_VSTART - The start address of DRAM (virtual)
|
||||||
|
|
||||||
|
|
||||||
General build options
|
General build options
|
||||||
@ -305,12 +305,12 @@ configs/c5471evm
|
|||||||
This is a port to the Spectrum Digital C5471 evaluation board. The
|
This is a port to the Spectrum Digital C5471 evaluation board. The
|
||||||
TMS320C5471 is a dual core processor from TI with an ARM7TDMI general
|
TMS320C5471 is a dual core processor from TI with an ARM7TDMI general
|
||||||
purpose processor and a c54 DSP. It is also known as TMS320DA180 or just DA180.
|
purpose processor and a c54 DSP. It is also known as TMS320DA180 or just DA180.
|
||||||
NuttX runs on the ARM core and is built with with a GNU arm-elf toolchain*.
|
NuttX runs on the ARM core and is built with a GNU arm-elf toolchain*.
|
||||||
This port is complete, verified, and included in the NuttX release.
|
This port is complete, verified, and included in the NuttX release.
|
||||||
|
|
||||||
configs/mcu123-lpc214x
|
configs/mcu123-lpc214x
|
||||||
This is a port to the mcu123.com lpc214x development board.
|
This is a port to the mcu123.com lpc214x development board.
|
||||||
This OS is also built with the the arm-elf toolchain*
|
This OS is also built with the arm-elf toolchain*
|
||||||
|
|
||||||
configs/ntosd-dm320
|
configs/ntosd-dm320
|
||||||
This port uses the Neuros OSD with a GNU arm-elf toolchain*:
|
This port uses the Neuros OSD with a GNU arm-elf toolchain*:
|
||||||
@ -327,27 +327,32 @@ configs/mcu123-lpc214x
|
|||||||
|
|
||||||
configs/m68322evb
|
configs/m68322evb
|
||||||
This is a work in progress for the venerable m68322evb board from
|
This is a work in progress for the venerable m68322evb board from
|
||||||
Motorola. This OS is also built with the the arm-elf toolchain*.
|
Motorola. This OS is also built with the arm-elf toolchain*.
|
||||||
|
|
||||||
configs/pjrc-8051
|
configs/pjrc-8051
|
||||||
8051 Microcontroller. This port uses the PJRC 87C52 development system
|
8051 Microcontroller. This port uses the PJRC 87C52 development system
|
||||||
and the SDCC toolchain. This port is not quite ready for prime time.
|
and the SDCC toolchain. This port is not quite ready for prime time.
|
||||||
|
|
||||||
|
configs/xtrs
|
||||||
|
TRS80 Model 3. This port uses a vintage computer based on the Z80.
|
||||||
|
An emulator for this computer is available to run TRS80 programs on a
|
||||||
|
linux platform (http://www.tim-mann.org/xtrs.html).
|
||||||
|
|
||||||
configs/z16f2800100zcog
|
configs/z16f2800100zcog
|
||||||
z16f Microncontroller. This port use the Zilog z16f2800100zcog
|
z16f Microcontroller. This port use the Zilog z16f2800100zcog
|
||||||
development kit and the Zilog ZDS-II Windows command line tools. The
|
development kit and the Zilog ZDS-II Windows command line tools. The
|
||||||
development environment is Cygwin under WinXP.
|
development environment is Cygwin under WinXP.
|
||||||
|
|
||||||
configs/z8encore000zco
|
configs/z8encore000zco
|
||||||
z8Encore! Microncontroller. This port use the Zilog z8encore000zco
|
z8Encore! Microcontroller. This port use the Zilog z8encore000zco
|
||||||
development kit, Z8F6403 part, and the Zilog ZDS-II Windows command line
|
development kit, Z8F6403 part, and the Zilog ZDS-II Windows command line
|
||||||
tools. The development environment is Cygwin under WinXP.
|
tools. The development environment is Cygwin under WinXP.
|
||||||
|
|
||||||
configs/z80zim
|
configs/z80sim
|
||||||
z80 Microcontroller. This port uses a Z80 instruction set simulator.
|
z80 Microcontroller. This port uses a Z80 instruction set simulator.
|
||||||
That simulator can be found in the NuttX CVS at
|
That simulator can be found in the NuttX CVS at
|
||||||
http://nuttx.cvs.sourceforge.net/nuttx/misc/sims/z80sim.
|
http://nuttx.cvs.sourceforge.net/nuttx/misc/sims/z80sim.
|
||||||
This port also the SDCC toolchain (http://sdcc.sourceforge.net/")
|
This port also uses the SDCC toolchain (http://sdcc.sourceforge.net/")
|
||||||
(verified with version 2.6.0).
|
(verified with version 2.6.0).
|
||||||
|
|
||||||
Other ports for the for the TI TMS320DM270, M683222 and for MIPS are in various
|
Other ports for the for the TI TMS320DM270, M683222 and for MIPS are in various
|
||||||
@ -368,5 +373,3 @@ tools/configure.sh
|
|||||||
|
|
||||||
cd tools
|
cd tools
|
||||||
./configure.sh <board-name>/<config-dir>
|
./configure.sh <board-name>/<config-dir>
|
||||||
|
|
||||||
|
|
||||||
|
@ -346,7 +346,7 @@ void up_serialinit(void)
|
|||||||
{
|
{
|
||||||
#if defined(CONFIG_DEV_LOWCONSOLE)
|
#if defined(CONFIG_DEV_LOWCONSOLE)
|
||||||
(void)lowconsole_init();
|
(void)lowconsole_init();
|
||||||
#elif defiened(CONFIG_DEV_CONSOLE)
|
#elif defined(CONFIG_DEV_CONSOLE)
|
||||||
(void)uart_register("/dev/console", &g_uartport);
|
(void)uart_register("/dev/console", &g_uartport);
|
||||||
(void)uart_register("/dev/ttyS0", &g_uartport);
|
(void)uart_register("/dev/ttyS0", &g_uartport);
|
||||||
#endif
|
#endif
|
||||||
@ -368,6 +368,3 @@ int up_putc(int ch)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user