summaryrefslogtreecommitdiff
path: root/ecos/packages/hal/cortexm/lm3s/var/current/include
diff options
context:
space:
mode:
Diffstat (limited to 'ecos/packages/hal/cortexm/lm3s/var/current/include')
-rw-r--r--ecos/packages/hal/cortexm/lm3s/var/current/include/hal_cache.h66
-rw-r--r--ecos/packages/hal/cortexm/lm3s/var/current/include/hal_diag.h88
-rw-r--r--ecos/packages/hal/cortexm/lm3s/var/current/include/plf_stub.h88
-rw-r--r--ecos/packages/hal/cortexm/lm3s/var/current/include/var_arch.h61
-rw-r--r--ecos/packages/hal/cortexm/lm3s/var/current/include/var_intr.h119
-rw-r--r--ecos/packages/hal/cortexm/lm3s/var/current/include/var_io.h1371
-rw-r--r--ecos/packages/hal/cortexm/lm3s/var/current/include/variant.inc54
7 files changed, 1847 insertions, 0 deletions
diff --git a/ecos/packages/hal/cortexm/lm3s/var/current/include/hal_cache.h b/ecos/packages/hal/cortexm/lm3s/var/current/include/hal_cache.h
new file mode 100644
index 0000000..450f2bf
--- /dev/null
+++ b/ecos/packages/hal/cortexm/lm3s/var/current/include/hal_cache.h
@@ -0,0 +1,66 @@
+#ifndef CYGONCE_HAL_CACHE_H
+#define CYGONCE_HAL_CACHE_H
+
+//=============================================================================
+//
+// hal_cache.h
+//
+// HAL cache control API
+//
+//=============================================================================
+// ####ECOSGPLCOPYRIGHTBEGIN####
+// -------------------------------------------
+// This file is part of eCos, the Embedded Configurable Operating System.
+// Copyright (C) 2011 Free Software Foundation, Inc.
+//
+// eCos is free software; you can redistribute it and/or modify it under
+// the terms of the GNU General Public License as published by the Free
+// Software Foundation; either version 2 or (at your option) any later
+// version.
+//
+// eCos is distributed in the hope that it will be useful, but WITHOUT
+// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+// for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with eCos; if not, write to the Free Software Foundation, Inc.,
+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+//
+// As a special exception, if other files instantiate templates or use
+// macros or inline functions from this file, or you compile this file
+// and link it with other works to produce a work based on this file,
+// this file does not by itself cause the resulting work to be covered by
+// the GNU General Public License. However the source code for this file
+// must still be made available in accordance with section (3) of the GNU
+// General Public License v2.
+//
+// This exception does not invalidate any other reasons why a work based
+// on this file might be covered by the GNU General Public License.
+// -------------------------------------------
+// ####ECOSGPLCOPYRIGHTEND####
+//=============================================================================
+//#####DESCRIPTIONBEGIN####
+//
+// Author(s): ccoutand
+// Contributors:
+// Date: 2011-01-18
+// Purpose: Cache control API
+// Description: The Stellaris LM3S Cortex-M3 microcontroller does not require
+// cache control. File is kept empty.
+//
+// Usage:
+// #include <cyg/hal/hal_cache.h>
+// ...
+//
+//
+//####DESCRIPTIONEND####
+//
+//=============================================================================
+
+#include <cyg/infra/cyg_type.h>
+
+
+//-----------------------------------------------------------------------------
+#endif // ifndef CYGONCE_HAL_CACHE_H
+// End of hal_cache.h
diff --git a/ecos/packages/hal/cortexm/lm3s/var/current/include/hal_diag.h b/ecos/packages/hal/cortexm/lm3s/var/current/include/hal_diag.h
new file mode 100644
index 0000000..9bf882f
--- /dev/null
+++ b/ecos/packages/hal/cortexm/lm3s/var/current/include/hal_diag.h
@@ -0,0 +1,88 @@
+#ifndef CYGONCE_HAL_DIAG_H
+#define CYGONCE_HAL_DIAG_H
+//=============================================================================
+//
+// hal_diag.h
+//
+// HAL diagnostics
+//
+//=============================================================================
+// ####ECOSGPLCOPYRIGHTBEGIN####
+// -------------------------------------------
+// This file is part of eCos, the Embedded Configurable Operating System.
+// Copyright (C) 2011 Free Software Foundation, Inc.
+//
+// eCos is free software; you can redistribute it and/or modify it under
+// the terms of the GNU General Public License as published by the Free
+// Software Foundation; either version 2 or (at your option) any later
+// version.
+//
+// eCos is distributed in the hope that it will be useful, but WITHOUT
+// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+// for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with eCos; if not, write to the Free Software Foundation, Inc.,
+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+//
+// As a special exception, if other files instantiate templates or use
+// macros or inline functions from this file, or you compile this file
+// and link it with other works to produce a work based on this file,
+// this file does not by itself cause the resulting work to be covered by
+// the GNU General Public License. However the source code for this file
+// must still be made available in accordance with section (3) of the GNU
+// General Public License v2.
+//
+// This exception does not invalidate any other reasons why a work based
+// on this file might be covered by the GNU General Public License.
+// -------------------------------------------
+// ####ECOSGPLCOPYRIGHTEND####
+//=============================================================================
+//#####DESCRIPTIONBEGIN####
+//
+// Author(s): ccoutand
+// Date: 2011-01-18
+// Purpose: HAL diagnostics
+// Description:
+// Usage: #include <cyg/hal/var_io.h>
+//
+//####DESCRIPTIONEND####
+//
+//=============================================================================
+
+#include <pkgconf/hal.h>
+#include <cyg/infra/cyg_type.h>
+#include <cyg/hal/hal_if.h>
+
+//-----------------------------------------------------------------------------
+
+#if defined(CYGSEM_HAL_VIRTUAL_VECTOR_DIAG)
+
+# define HAL_DIAG_INIT() hal_if_diag_init()
+# define HAL_DIAG_WRITE_CHAR(_c_) hal_if_diag_write_char(_c_)
+# define HAL_DIAG_READ_CHAR(_c_) hal_if_diag_read_char(&_c_)
+
+#else
+
+__externC void hal_lm3s_diag_init(void);
+__externC void hal_lm3s_diag_putc(char);
+__externC cyg_uint8 hal_lm3s_diag_getc(void);
+
+# ifndef HAL_DIAG_INIT
+# define HAL_DIAG_INIT() hal_lm3s_diag_init()
+# endif
+
+# ifndef HAL_DIAG_WRITE_CHAR
+# define HAL_DIAG_WRITE_CHAR(__c) hal_lm3s_diag_putc(__c)
+# endif
+
+# ifndef HAL_DIAG_READ_CHAR
+# define HAL_DIAG_READ_CHAR(__c) (__c) = hal_lm3s_diag_getc()
+# endif
+
+#endif // CYGSEM_HAL_VIRTUAL_VECTOR_DIAG
+
+//-----------------------------------------------------------------------------
+#endif // CYGONCE_HAL_DIAG_H
+// EOF of hal_diag.h
diff --git a/ecos/packages/hal/cortexm/lm3s/var/current/include/plf_stub.h b/ecos/packages/hal/cortexm/lm3s/var/current/include/plf_stub.h
new file mode 100644
index 0000000..0b5c216
--- /dev/null
+++ b/ecos/packages/hal/cortexm/lm3s/var/current/include/plf_stub.h
@@ -0,0 +1,88 @@
+#ifndef CYGONCE_HAL_PLF_STUB_H
+#define CYGONCE_HAL_PLF_STUB_H
+
+//=============================================================================
+//
+// plf_stub.h
+//
+// Platform header for GDB stub support.
+//
+//=============================================================================
+// ####ECOSGPLCOPYRIGHTBEGIN####
+// -------------------------------------------
+// This file is part of eCos, the Embedded Configurable Operating System.
+// Copyright (C) 2011 Free Software Foundation, Inc.
+//
+// eCos is free software; you can redistribute it and/or modify it under
+// the terms of the GNU General Public License as published by the Free
+// Software Foundation; either version 2 or (at your option) any later
+// version.
+//
+// eCos is distributed in the hope that it will be useful, but WITHOUT
+// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+// for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with eCos; if not, write to the Free Software Foundation, Inc.,
+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+//
+// As a special exception, if other files instantiate templates or use
+// macros or inline functions from this file, or you compile this file
+// and link it with other works to produce a work based on this file,
+// this file does not by itself cause the resulting work to be covered by
+// the GNU General Public License. However the source code for this file
+// must still be made available in accordance with section (3) of the GNU
+// General Public License v2.
+//
+// This exception does not invalidate any other reasons why a work based
+// on this file might be covered by the GNU General Public License.
+// -------------------------------------------
+// ####ECOSGPLCOPYRIGHTEND####
+//=============================================================================
+//#####DESCRIPTIONBEGIN####
+//
+// Author(s): ccoutand
+// Date: 2011-01-18
+// Purpose: Platform HAL stub support for Stellaris Cortex-M3
+// variant boards.
+// Usage: #include <cyg/hal/plf_stub.h>
+//
+//####DESCRIPTIONEND####
+//
+//=============================================================================
+
+#include <pkgconf/hal.h>
+#include CYGBLD_HAL_PLATFORM_H
+
+#ifdef CYGDBG_HAL_DEBUG_GDB_INCLUDE_STUBS
+
+#include <cyg/infra/cyg_type.h> // CYG_UNUSED_PARAM
+
+#include <cyg/hal/cortexm_stub.h> // architecture stub support
+
+#include <cyg/hal/hal_io.h>
+
+//----------------------------------------------------------------------------
+// Define some platform specific communication details. This is mostly
+// handled by hal_if now, but we need to make sure the comms tables are
+// properly initialized.
+
+__externC void cyg_hal_plf_comms_init(void);
+
+#define HAL_STUB_PLATFORM_INIT_SERIAL() cyg_hal_plf_comms_init()
+
+#define HAL_STUB_PLATFORM_SET_BAUD_RATE(baud) CYG_UNUSED_PARAM(int, (baud))
+#define HAL_STUB_PLATFORM_INTERRUPTIBLE 0
+#define HAL_STUB_PLATFORM_INIT_BREAK_IRQ() CYG_EMPTY_STATEMENT
+
+//----------------------------------------------------------------------------
+// Stub initializer.
+
+#define HAL_STUB_PLATFORM_INIT() CYG_EMPTY_STATEMENT
+
+#endif // ifdef CYGDBG_HAL_DEBUG_GDB_INCLUDE_STUBS
+
+//-----------------------------------------------------------------------------
+#endif // CYGONCE_HAL_PLF_STUB_H
+// End of plf_stub.h
diff --git a/ecos/packages/hal/cortexm/lm3s/var/current/include/var_arch.h b/ecos/packages/hal/cortexm/lm3s/var/current/include/var_arch.h
new file mode 100644
index 0000000..424f196
--- /dev/null
+++ b/ecos/packages/hal/cortexm/lm3s/var/current/include/var_arch.h
@@ -0,0 +1,61 @@
+#ifndef CYGONCE_HAL_VAR_ARCH_H
+#define CYGONCE_HAL_VAR_ARCH_H
+//=============================================================================
+//
+// var_arch.h
+//
+// Stellaris Cortex-M3 variant architecture overrides
+//
+//=============================================================================
+// ####ECOSGPLCOPYRIGHTBEGIN####
+// -------------------------------------------
+// This file is part of eCos, the Embedded Configurable Operating System.
+// Copyright (C) 2011 Free Software Foundation, Inc.
+//
+// eCos is free software; you can redistribute it and/or modify it under
+// the terms of the GNU General Public License as published by the Free
+// Software Foundation; either version 2 or (at your option) any later
+// version.
+//
+// eCos is distributed in the hope that it will be useful, but WITHOUT
+// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+// for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with eCos; if not, write to the Free Software Foundation, Inc.,
+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+//
+// As a special exception, if other files instantiate templates or use
+// macros or inline functions from this file, or you compile this file
+// and link it with other works to produce a work based on this file,
+// this file does not by itself cause the resulting work to be covered by
+// the GNU General Public License. However the source code for this file
+// must still be made available in accordance with section (3) of the GNU
+// General Public License v2.
+//
+// This exception does not invalidate any other reasons why a work based
+// on this file might be covered by the GNU General Public License.
+// -------------------------------------------
+// ####ECOSGPLCOPYRIGHTEND####
+//=============================================================================
+//#####DESCRIPTIONBEGIN####
+//
+// Author(s): ccoutand
+// Date: 2011-01-18
+// Purpose: Stellaris Cortex-M3 variant architecture overrides
+// Description:
+// Usage: #include <cyg/hal/hal_arch.h>
+//
+//####DESCRIPTIONEND####
+//
+//=============================================================================
+
+#include <pkgconf/hal.h>
+#include <cyg/hal/hal_io.h>
+
+#include <cyg/hal/plf_arch.h>
+
+//-----------------------------------------------------------------------------
+#endif // CYGONCE_HAL_VAR_ARCH_H
+// EOF of var_arch.h
diff --git a/ecos/packages/hal/cortexm/lm3s/var/current/include/var_intr.h b/ecos/packages/hal/cortexm/lm3s/var/current/include/var_intr.h
new file mode 100644
index 0000000..075b681
--- /dev/null
+++ b/ecos/packages/hal/cortexm/lm3s/var/current/include/var_intr.h
@@ -0,0 +1,119 @@
+#ifndef CYGONCE_HAL_VAR_INTR_H
+#define CYGONCE_HAL_VAR_INTR_H
+//==========================================================================
+//
+// var_intr.h
+//
+// HAL Interrupt and clock assignments for Stellaris Cortex-M3 variants
+//
+//==========================================================================
+// ####ECOSGPLCOPYRIGHTBEGIN####
+// -------------------------------------------
+// This file is part of eCos, the Embedded Configurable Operating System.
+// Copyright (C) 2011 Free Software Foundation, Inc.
+//
+// eCos is free software; you can redistribute it and/or modify it under
+// the terms of the GNU General Public License as published by the Free
+// Software Foundation; either version 2 or (at your option) any later
+// version.
+//
+// eCos is distributed in the hope that it will be useful, but WITHOUT
+// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+// for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with eCos; if not, write to the Free Software Foundation, Inc.,
+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+//
+// As a special exception, if other files instantiate templates or use
+// macros or inline functions from this file, or you compile this file
+// and link it with other works to produce a work based on this file,
+// this file does not by itself cause the resulting work to be covered by
+// the GNU General Public License. However the source code for this file
+// must still be made available in accordance with section (3) of the GNU
+// General Public License v2.
+//
+// This exception does not invalidate any other reasons why a work based
+// on this file might be covered by the GNU General Public License.
+// -------------------------------------------
+// ####ECOSGPLCOPYRIGHTEND####
+//==========================================================================
+//#####DESCRIPTIONBEGIN####
+//
+// Author(s): ccoutand
+// Date: 2011-01-18
+// Purpose: Define Interrupt support
+// Description: The interrupt specifics for Stellaris Cortex-M3
+// are defined here.
+//
+// Usage: #include <cyg/hal/var_intr.h>
+// However applications should include using <cyg/hal/hal_intr.h>
+// instead to allow for platform overrides.
+//
+//####DESCRIPTIONEND####
+//
+//==========================================================================
+
+#include <cyg/hal/plf_intr.h>
+
+//==========================================================================
+
+#define CYGNUM_HAL_INTERRUPT_GPIOA (0+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GPIOB (1+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GPIOC (2+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GPIOD (3+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GPIOE (4+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_UART0 (5+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_UART1 (6+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_SSI0 (7+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_I2C (8+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_PWM0 (10+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_PWM1 (11+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_PWM2 (12+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_QIE (13+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_ADC0_S0 (14+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_ADC0_S1 (15+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_ADC0_S2 (16+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_ADC0_S3 (17+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_WDT (18+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GTIM0_A (19+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GTIM0_B (20+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GTIM1_A (21+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GTIM1_B (22+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GTIM2_A (23+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GTIM2_B (24+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_AC0 (25+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_AC1 (26+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_AC2 (27+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_SCTL (28+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_FMS (29+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GPIOF (30+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GPIOG (31+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GPIOH (32+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GTIM3_A (35+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_GTIM3_B (36+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_CAN0 (39+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_ETH0 (42+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+#define CYGNUM_HAL_INTERRUPT_HIM (43+CYGNUM_HAL_INTERRUPT_EXTERNAL)
+
+#ifndef CYGNUM_HAL_INTERRUPT_NVIC_MAX
+# define CYGNUM_HAL_INTERRUPT_NVIC_MAX (CYGNUM_HAL_INTERRUPT_HIM)
+#endif
+
+#define CYGNUM_HAL_ISR_MIN 0
+#ifndef CYGNUM_HAL_ISR_MAX
+# define CYGNUM_HAL_ISR_MAX (CYGNUM_HAL_INTERRUPT_NVIC_MAX)
+#endif
+#define CYGNUM_HAL_ISR_COUNT (CYGNUM_HAL_ISR_MAX + 1)
+
+#define CYGNUM_HAL_VSR_MIN 0
+#ifndef CYGNUM_HAL_VSR_MAX
+# define CYGNUM_HAL_VSR_MAX (CYGNUM_HAL_VECTOR_SYS_TICK+CYGNUM_HAL_INTERRUPT_NVIC_MAX)
+#endif
+#define CYGNUM_HAL_VSR_COUNT (CYGNUM_HAL_VSR_MAX+1)
+
+
+//----------------------------------------------------------------------------
+#endif // CYGONCE_HAL_VAR_INTR_H
+// EOF var_intr.h
diff --git a/ecos/packages/hal/cortexm/lm3s/var/current/include/var_io.h b/ecos/packages/hal/cortexm/lm3s/var/current/include/var_io.h
new file mode 100644
index 0000000..7e2ffc0
--- /dev/null
+++ b/ecos/packages/hal/cortexm/lm3s/var/current/include/var_io.h
@@ -0,0 +1,1371 @@
+#ifndef CYGONCE_HAL_VAR_IO_H
+#define CYGONCE_HAL_VAR_IO_H
+//=============================================================================
+//
+// var_io.h
+//
+// Variant specific registers
+//
+//=============================================================================
+// ####ECOSGPLCOPYRIGHTBEGIN####
+// -------------------------------------------
+// This file is part of eCos, the Embedded Configurable Operating System.
+// Copyright (C) 2011 Free Software Foundation, Inc.
+//
+// eCos is free software; you can redistribute it and/or modify it under
+// the terms of the GNU General Public License as published by the Free
+// Software Foundation; either version 2 or (at your option) any later
+// version.
+//
+// eCos is distributed in the hope that it will be useful, but WITHOUT
+// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+// for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with eCos; if not, write to the Free Software Foundation, Inc.,
+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+//
+// As a special exception, if other files instantiate templates or use
+// macros or inline functions from this file, or you compile this file
+// and link it with other works to produce a work based on this file,
+// this file does not by itself cause the resulting work to be covered by
+// the GNU General Public License. However the source code for this file
+// must still be made available in accordance with section (3) of the GNU
+// General Public License v2.
+//
+// This exception does not invalidate any other reasons why a work based
+// on this file might be covered by the GNU General Public License.
+// -------------------------------------------
+// ####ECOSGPLCOPYRIGHTEND####
+//=============================================================================
+//#####DESCRIPTIONBEGIN####
+//
+// Author(s): ccoutand
+// Date: 2011-01-18
+// Purpose: Stellaris Cortex-M3 variant specific registers
+// Description:
+// Usage: #include <cyg/hal/var_io.h>
+//
+//####DESCRIPTIONEND####
+//
+//=============================================================================
+
+#include <pkgconf/hal_cortexm_lm3s.h>
+
+#include <cyg/hal/plf_io.h>
+
+//=============================================================================
+// Peripherals
+
+#define CYGHWR_HAL_LM3S_FLASH 0x00000000
+#define CYGHWR_HAL_LM3S_SRAM 0x20000000
+
+#define CYGHWR_HAL_LM3S_WDT0 0x40000000
+#define CYGHWR_HAL_LM3S_GPIOA 0x40004000
+#define CYGHWR_HAL_LM3S_GPIOB 0x40005000
+#define CYGHWR_HAL_LM3S_GPIOC 0x40006000
+#define CYGHWR_HAL_LM3S_GPIOD 0x40007000
+#define CYGHWR_HAL_LM3S_SSI0 0x40008000
+#define CYGHWR_HAL_LM3S_SSI1 0x40009000
+#define CYGHWR_HAL_LM3S_UART0 0x4000C000
+#define CYGHWR_HAL_LM3S_UART1 0x4000D000
+#define CYGHWR_HAL_LM3S_UART2 0x4000E000
+#define CYGHWR_HAL_LM3S_I2C_M0 0x40020000
+#define CYGHWR_HAL_LM3S_I2C_S0 0x40020800
+#define CYGHWR_HAL_LM3S_GPIOE 0x40024000
+#define CYGHWR_HAL_LM3S_GPIOF 0x40025000
+#define CYGHWR_HAL_LM3S_GPIOG 0x40026000
+#define CYGHWR_HAL_LM3S_GPIOH 0x40027000
+#define CYGHWR_HAL_LM3S_PWM 0x40028000
+#define CYGHWR_HAL_LM3S_QEI0 0x4002C000
+#define CYGHWR_HAL_LM3S_GPTIM0 0x40030000
+#define CYGHWR_HAL_LM3S_GPTIM1 0x40031000
+#define CYGHWR_HAL_LM3S_GPTIM2 0x40032000
+#define CYGHWR_HAL_LM3S_GPTIM3 0x40033000
+#define CYGHWR_HAL_LM3S_ADC0 0x40038000
+#define CYGHWR_HAL_LM3S_AC 0x4003C000
+#define CYGHWR_HAL_LM3S_CAN0 0x40040000
+#define CYGHWR_HAL_LM3S_ETH0 0x40048000
+#define CYGHWR_HAL_LM3S_FMC 0x400FD000
+#define CYGHWR_HAL_LM3S_SC 0x400FE000
+
+#define CYGHWR_HAL_LM3S_ITM 0xE0000000
+#define CYGHWR_HAL_LM3S_DWT 0xE0001000
+#define CYGHWR_HAL_LM3S_FPB 0xE0002000
+#define CYGHWR_HAL_LM3S_CORTEXM3 0xE000E000
+#define CYGHWR_HAL_LM3S_TPIU 0xE0040000
+
+
+//=============================================================================
+// Device signature and ID registers
+
+#define CYGHWR_HAL_LM3S_MCU_ID (CYGHWR_HAL_LM3S_CORTEXM3 + 0xD00)
+#define CYGHWR_HAL_LM3S_MCU_ID_REV(__x) ((__x)&0xF)
+#define CYGHWR_HAL_LM3S_MCU_PART_NO(__x) (((__x)>>4)&0x0FFF)
+#define CYGHWR_HAL_LM3S_MCU_VAR_NO(__x) (((__x)>>20)&0xF)
+
+
+//=============================================================================
+// System Control
+
+#define CYGHWR_HAL_LM3S_SC_DID0 0x000
+#define CYGHWR_HAL_LM3S_SC_DID1 0x004
+#define CYGHWR_HAL_LM3S_SC_DIC0 0x008
+#define CYGHWR_HAL_LM3S_SC_DIC1 0x010
+#define CYGHWR_HAL_LM3S_SC_DIC2 0x014
+#define CYGHWR_HAL_LM3S_SC_DIC3 0x018
+#define CYGHWR_HAL_LM3S_SC_DIC4 0x01c
+#define CYGHWR_HAL_LM3S_SC_PBORCTL 0x030
+#define CYGHWR_HAL_LM3S_SC_LDORCTL 0x034
+#define CYGHWR_HAL_LM3S_SC_SRCR0 0x040
+#define CYGHWR_HAL_LM3S_SC_SRCR1 0x044
+#define CYGHWR_HAL_LM3S_SC_SRCR2 0x048
+#define CYGHWR_HAL_LM3S_SC_RIS 0x050
+#define CYGHWR_HAL_LM3S_SC_IMC 0x054
+#define CYGHWR_HAL_LM3S_SC_MISC 0x058
+#define CYGHWR_HAL_LM3S_SC_RESC 0x05C
+#define CYGHWR_HAL_LM3S_SC_RCC 0x060
+#define CYGHWR_HAL_LM3S_SC_PLLCFG 0x064
+#define CYGHWR_HAL_LM3S_SC_RCGC0 0x100
+#define CYGHWR_HAL_LM3S_SC_RCGC1 0x104
+#define CYGHWR_HAL_LM3S_SC_RCGC2 0x108
+#define CYGHWR_HAL_LM3S_SC_SCGC0 0x110
+#define CYGHWR_HAL_LM3S_SC_SCGC1 0x114
+#define CYGHWR_HAL_LM3S_SC_SCGC2 0x118
+#define CYGHWR_HAL_LM3S_SC_DCGC0 0x120
+#define CYGHWR_HAL_LM3S_SC_DCGC1 0x124
+#define CYGHWR_HAL_LM3S_SC_DCGC2 0x128
+#define CYGHWR_HAL_LM3S_SC_FMPRE 0x130
+#define CYGHWR_HAL_LM3S_SC_FMPPE 0x134
+#define CYGHWR_HAL_LM3S_SC_USECRL 0x140
+#define CYGHWR_HAL_LM3S_SC_DSLPCLKCFG 0x144
+#define CYGHWR_HAL_LM3S_SC_CLKVCLR 0x150
+#define CYGHWR_HAL_LM3S_SC_LDOARST 0x160
+
+// PBORCTL bits
+#define CYGHWR_HAL_LM3S_SC_PBORCTL_BORWT BIT_(0)
+#define CYGHWR_HAL_LM3S_SC_PBORCTL_BORIOR BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_PBORCTL_BORTIM(__x) VALUE_(2,__x)
+
+// RIS bits
+#define CYGHWR_HAL_LM3S_SC_RIS_PLLFRIS BIT_(0)
+#define CYGHWR_HAL_LM3S_SC_RIS_BORRIS BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_RIS_LDORIS BIT_(2)
+#define CYGHWR_HAL_LM3S_SC_RIS_MOFRIS BIT_(3)
+#define CYGHWR_HAL_LM3S_SC_RIS_IOFRIS BIT_(4)
+#define CYGHWR_HAL_LM3S_SC_RIS_CLFRIS BIT_(5)
+#define CYGHWR_HAL_LM3S_SC_RIS_PLLLRIS BIT_(6)
+
+// IMC bits
+#define CYGHWR_HAL_LM3S_SC_IMC_PLLFIM BIT_(0)
+#define CYGHWR_HAL_LM3S_SC_IMC_BORRIM BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_IMC_LDOIM BIT_(2)
+#define CYGHWR_HAL_LM3S_SC_IMC_MOFIM BIT_(3)
+#define CYGHWR_HAL_LM3S_SC_IMC_IOFIM BIT_(4)
+#define CYGHWR_HAL_LM3S_SC_IMC_CLIM BIT_(5)
+#define CYGHWR_HAL_LM3S_SC_IMC_PLLLFIM BIT_(6)
+
+// MISC bits
+#define CYGHWR_HAL_LM3S_SC_MISC_BORMIS BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_MISC_LDOMIS BIT_(2)
+#define CYGHWR_HAL_LM3S_SC_MISC_MOFMIS BIT_(3)
+#define CYGHWR_HAL_LM3S_SC_MISC_IOFMIS BIT_(4)
+#define CYGHWR_HAL_LM3S_SC_MISC_CLMIS BIT_(5)
+#define CYGHWR_HAL_LM3S_SC_MISC_PLLLMIS BIT_(6)
+
+// RESC bits
+#define CYGHWR_HAL_LM3S_SC_RESC_EXT BIT_(0)
+#define CYGHWR_HAL_LM3S_SC_RESC_POR BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_RESC_BOR BIT_(2)
+#define CYGHWR_HAL_LM3S_SC_RESC_WDT BIT_(3)
+#define CYGHWR_HAL_LM3S_SC_RESC_SW BIT_(4)
+#define CYGHWR_HAL_LM3S_SC_RESC_LDO BIT_(5)
+
+// RCC bits
+#define CYGHWR_HAL_LM3S_SC_RCC_MOSCDIS BIT_(0)
+#define CYGHWR_HAL_LM3S_SC_RCC_IOSCDIS BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_RCC_MOSCVER BIT_(2)
+#define CYGHWR_HAL_LM3S_SC_RCC_IOSCVER BIT_(3)
+#define CYGHWR_HAL_LM3S_SC_RCC_OSCSRC_MOSC VALUE_(4,0)
+#define CYGHWR_HAL_LM3S_SC_RCC_OSCSRC_IOSC VALUE_(4,1)
+#define CYGHWR_HAL_LM3S_SC_RCC_OSCSRC_IOSC_DIV4 VALUE_(4,2)
+#define CYGHWR_HAL_LM3S_SC_RCC_OSCSRC_MASK 0x00000030
+#define CYGHWR_HAL_LM3S_SC_RCC_XTAL(__x) VALUE_(6,__x)
+#define CYGHWR_HAL_LM3S_SC_RCC_XTAL_MASK 0x000003C0
+#define CYGHWR_HAL_LM3S_SC_RCC_PLLVER BIT_(10)
+#define CYGHWR_HAL_LM3S_SC_RCC_BYPASS BIT_(11)
+#define CYGHWR_HAL_LM3S_SC_RCC_OEN BIT_(12)
+#define CYGHWR_HAL_LM3S_SC_RCC_PWRDN BIT_(13)
+#define CYGHWR_HAL_LM3S_SC_RCC_PWMDIV_DIV2 VALUE_(14, 0x0)
+#define CYGHWR_HAL_LM3S_SC_RCC_PWMDIV_DIV4 VALUE_(14, 0x1)
+#define CYGHWR_HAL_LM3S_SC_RCC_PWMDIV_DIV8 VALUE_(14, 0x2)
+#define CYGHWR_HAL_LM3S_SC_RCC_PWMDIV_DIV16 VALUE_(14, 0x3)
+#define CYGHWR_HAL_LM3S_SC_RCC_PWMDIV_DIV32 VALUE_(14, 0x4)
+#define CYGHWR_HAL_LM3S_SC_RCC_PWMDIV_DIV64 VALUE_(14, 0x5)
+#define CYGHWR_HAL_LM3S_SC_RCC_USEPWMDIV BIT_(20)
+#define CYGHWR_HAL_LM3S_SC_RCC_USESYSDIV BIT_(22)
+#define CYGHWR_HAL_LM3S_SC_RCC_SYSDIV(__x) VALUE_(23, __x)
+#define CYGHWR_HAL_LM3S_SC_RCC_SYSDIV_MASK 0x07800000
+#define CYGHWR_HAL_LM3S_SC_RCC_ACG BIT_(27)
+
+// DSLPCLKCFG bits
+#define CYGHWR_HAL_LM3S_SC_DSLPCLKCFG_IOSC BIT_(0)
+
+// CLKVCLR bits
+#define CYGHWR_HAL_LM3S_SC_CLKVCLR_VERCLR BIT_(0)
+
+// LDOARST bits
+#define CYGHWR_HAL_LM3S_SC_LDOARST_BIT BIT_(0)
+
+// RCGC0 bits
+#define CYGHWR_HAL_LM3S_SC_RCGC0_WDT0 BIT_(3)
+#define CYGHWR_HAL_LM3S_SC_RCGC0_MAXADCSPD_125K VALUE_(8, 0x0)
+#define CYGHWR_HAL_LM3S_SC_RCGC0_MAXADCSPD_250K VALUE_(8, 0x1)
+#define CYGHWR_HAL_LM3S_SC_RCGC0_MAXADCSPD_500K VALUE_(8, 0x2)
+#define CYGHWR_HAL_LM3S_SC_RCGC0_ADC0 BIT_(16)
+#define CYGHWR_HAL_LM3S_SC_RCGC0_PWM0 BIT_(20)
+
+// SCGC0 bits
+#define CYGHWR_HAL_LM3S_SC_SCGC0_WDT0 BIT_(3)
+#define CYGHWR_HAL_LM3S_SC_SCGC0_MAXADCSPD_125K VALUE_(8, 0x0)
+#define CYGHWR_HAL_LM3S_SC_SCGC0_MAXADCSPD_250K VALUE_(8, 0x1)
+#define CYGHWR_HAL_LM3S_SC_SCGC0_MAXADCSPD_500K VALUE_(8, 0x2)
+#define CYGHWR_HAL_LM3S_SC_SCGC0_ADC0 BIT_(16)
+#define CYGHWR_HAL_LM3S_SC_SCGC0_PWM0 BIT_(20)
+
+// DCGC0 bits
+#define CYGHWR_HAL_LM3S_SC_DCGC0_WDT0 BIT_(3)
+#define CYGHWR_HAL_LM3S_SC_DCGC0_ADC0 BIT_(16)
+#define CYGHWR_HAL_LM3S_SC_DCGC0_PWM0 BIT_(20)
+
+// RCGC1 bits
+#define CYGHWR_HAL_LM3S_SC_RCGC1_UART0 BIT_(0)
+#define CYGHWR_HAL_LM3S_SC_RCGC1_UART1 BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_RCGC1_SSI0 BIT_(4)
+#define CYGHWR_HAL_LM3S_SC_RCGC1_I2C0 BIT_(12)
+#define CYGHWR_HAL_LM3S_SC_RCGC1_TIMER0 BIT_(16)
+#define CYGHWR_HAL_LM3S_SC_RCGC1_TIMER1 BIT_(17)
+#define CYGHWR_HAL_LM3S_SC_RCGC1_TIMER2 BIT_(18)
+#define CYGHWR_HAL_LM3S_SC_RCGC1_COMP0 BIT_(24)
+
+// SCSG1 bits
+#define CYGHWR_HAL_LM3S_SC_SCGC1_UART0 BIT_(0)
+#define CYGHWR_HAL_LM3S_SC_SCGC1_UART1 BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_SCGC1_SSI0 BIT_(4)
+#define CYGHWR_HAL_LM3S_SC_SCGC1_I2C0 BIT_(12)
+#define CYGHWR_HAL_LM3S_SC_SCGC1_TIMER0 BIT_(16)
+#define CYGHWR_HAL_LM3S_SC_SCGC1_TIMER1 BIT_(17)
+#define CYGHWR_HAL_LM3S_SC_SCGC1_TIMER2 BIT_(18)
+#define CYGHWR_HAL_LM3S_SC_SCGC1_COMP0 BIT_(24)
+
+// DCSG1 bits
+#define CYGHWR_HAL_LM3S_SC_DCGC1_UART0 BIT_(0)
+#define CYGHWR_HAL_LM3S_SC_DCGC1_UART1 BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_DCGC1_SSI0 BIT_(4)
+#define CYGHWR_HAL_LM3S_SC_DCGC1_I2C0 BIT_(12)
+#define CYGHWR_HAL_LM3S_SC_DCGC1_TIMER0 BIT_(16)
+#define CYGHWR_HAL_LM3S_SC_DCGC1_TIMER1 BIT_(17)
+#define CYGHWR_HAL_LM3S_SC_DCGC1_TIMER2 BIT_(18)
+#define CYGHWR_HAL_LM3S_SC_DCGC1_COMP0 BIT_(24)
+
+// RCGC2 bits
+#define CYGHWR_HAL_LM3S_SC_RCGC2_GPIOA BIT_(0)
+#define CYGHWR_HAL_LM3S_SC_RCGC2_GPIOB BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_RCGC2_GPIOC BIT_(2)
+#define CYGHWR_HAL_LM3S_SC_RCGC2_GPIOD BIT_(3)
+#define CYGHWR_HAL_LM3S_SC_RCGC2_GPIOE BIT_(4)
+
+// SCSG2 bits
+#define CYGHWR_HAL_LM3S_SC_SCGC2_GPIOA BIT_(0)
+#define CYGHWR_HAL_LM3S_SC_SCGC2_GPIOB BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_SCGC2_GPIOC BIT_(2)
+#define CYGHWR_HAL_LM3S_SC_SCGC2_GPIOD BIT_(3)
+#define CYGHWR_HAL_LM3S_SC_SCGC2_GPIOE BIT_(4)
+
+// DCSG2 bits
+#define CYGHWR_HAL_LM3S_SC_DCGC2_GPIOA BIT_(0)
+#define CYGHWR_HAL_LM3S_SC_DCGC2_GPIOB BIT_(1)
+#define CYGHWR_HAL_LM3S_SC_DCGC2_GPIOC BIT_(2)
+#define CYGHWR_HAL_LM3S_SC_DCGC2_GPIOD BIT_(3)
+#define CYGHWR_HAL_LM3S_SC_DCGC2_GPIOE BIT_(4)
+
+// Define peripheral
+#define CYGHWR_HAL_LM3S_PERIPH_GC0 BIT_(31)
+#define CYGHWR_HAL_LM3S_P_WDT0 ( BIT_(31) | CYGHWR_HAL_LM3S_SC_SCGC0_WDT0 )
+#define CYGHWR_HAL_LM3S_P_ADC0 ( BIT_(31) | CYGHWR_HAL_LM3S_SC_SCGC0_ADC0 )
+#define CYGHWR_HAL_LM3S_P_PWM ( BIT_(31) | CYGHWR_HAL_LM3S_SC_SCGC0_PWM0 )
+#define CYGHWR_HAL_LM3S_PERIPH_GC1 BIT_(30)
+#define CYGHWR_HAL_LM3S_P_UART0 ( BIT_(30) | CYGHWR_HAL_LM3S_SC_SCGC1_UART0 )
+#define CYGHWR_HAL_LM3S_P_UART1 ( BIT_(30) | CYGHWR_HAL_LM3S_SC_SCGC1_UART1 )
+#define CYGHWR_HAL_LM3S_P_SSI0 ( BIT_(30) | CYGHWR_HAL_LM3S_SC_SCGC1_SSI0 )
+#define CYGHWR_HAL_LM3S_P_I2C0 ( BIT_(30) | CYGHWR_HAL_LM3S_SC_SCGC1_I2C0 )
+#define CYGHWR_HAL_LM3S_P_TIMER0 ( BIT_(30) | CYGHWR_HAL_LM3S_SC_SCGC1_TIMER0 )
+#define CYGHWR_HAL_LM3S_P_TIMER1 ( BIT_(30) | CYGHWR_HAL_LM3S_SC_SCGC1_TIMER1 )
+#define CYGHWR_HAL_LM3S_P_TIMER2 ( BIT_(30) | CYGHWR_HAL_LM3S_SC_SCGC1_TIMER2 )
+#define CYGHWR_HAL_LM3S_P_COMP0 ( BIT_(30) | CYGHWR_HAL_LM3S_SC_SCGC1_COMP0 )
+#define CYGHWR_HAL_LM3S_PERIPH_GC2 BIT_(29)
+#define CYGHWR_HAL_LM3S_P_GPIOA ( BIT_(29) | CYGHWR_HAL_LM3S_SC_RCGC2_GPIOA )
+#define CYGHWR_HAL_LM3S_P_GPIOB ( BIT_(29) | CYGHWR_HAL_LM3S_SC_RCGC2_GPIOB )
+#define CYGHWR_HAL_LM3S_P_GPIOC ( BIT_(29) | CYGHWR_HAL_LM3S_SC_RCGC2_GPIOC )
+#define CYGHWR_HAL_LM3S_P_GPIOD ( BIT_(29) | CYGHWR_HAL_LM3S_SC_RCGC2_GPIOD )
+#define CYGHWR_HAL_LM3S_P_GPIOE ( BIT_(29) | CYGHWR_HAL_LM3S_SC_RCGC2_GPIOE )
+
+__externC void hal_lm3s_periph_set( cyg_uint32 periph, cyg_uint32 on_off );
+
+#define CYGHWR_HAL_LM3S_PERIPH_SET(__periph, __on_off ) hal_lm3s_periph_set( __periph, __on_off )
+
+//=============================================================================
+// Watchdog
+
+#define CYGHWR_HAL_LM3S_WDT_LOAD 0x000
+#define CYGHWR_HAL_LM3S_WDT_VALUE 0x004
+#define CYGHWR_HAL_LM3S_WDT_CTL 0x008
+#define CYGHWR_HAL_LM3S_WDT_ICR 0x00c
+#define CYGHWR_HAL_LM3S_WDT_RIS 0x010
+#define CYGHWR_HAL_LM3S_WDT_MIS 0x014
+#define CYGHWR_HAL_LM3S_WDT_TEST 0x418
+#define CYGHWR_HAL_LM3S_WDT_LOCK 0xc00
+#define CYGHWR_HAL_LM3S_WDT_PID4 0xfd0
+#define CYGHWR_HAL_LM3S_WDT_PID5 0xfd4
+#define CYGHWR_HAL_LM3S_WDT_PID6 0xfd8
+#define CYGHWR_HAL_LM3S_WDT_PID7 0xfdc
+#define CYGHWR_HAL_LM3S_WDT_PID0 0xfe0
+#define CYGHWR_HAL_LM3S_WDT_PID1 0xfe4
+#define CYGHWR_HAL_LM3S_WDT_PID2 0xfe8
+#define CYGHWR_HAL_LM3S_WDT_PID3 0xfec
+#define CYGHWR_HAL_LM3S_WDT_PCID0 0xff0
+#define CYGHWR_HAL_LM3S_WDT_PCID1 0xff4
+#define CYGHWR_HAL_LM3S_WDT_PCID2 0xff8
+#define CYGHWR_HAL_LM3S_WDT_PCID3 0xffc
+
+
+#define CYGHWR_HAL_LM3S_WDT_CTL_INTEN BIT_(0)
+#define CYGHWR_HAL_LM3S_WDT_CTL_RESEN BIT_(1)
+
+#define CYGHWR_HAL_LM3S_WDT_RIS_RIS BIT_(0)
+
+#define CYGHWR_HAL_LM3S_WDT_MIS_MIS BIT_(0)
+
+#define CYGHWR_HAL_LM3S_WDT_TEST_STALL BIT_(8)
+
+#define CYGHWR_HAL_LM3S_WDT_PID(__x) ((__x)&0xFF)
+#define CYGHWR_HAL_LM3S_WDT_PCID(__x) ((__x)&0xFF)
+
+
+//=============================================================================
+// GPIO ports
+
+#define CYGHWR_HAL_LM3S_GPIO_DATA 0x000
+#define CYGHWR_HAL_LM3S_GPIO_DIR 0x400
+#define CYGHWR_HAL_LM3S_GPIO_IS 0x404
+#define CYGHWR_HAL_LM3S_GPIO_IBE 0x408
+#define CYGHWR_HAL_LM3S_GPIO_IEV 0x40c
+#define CYGHWR_HAL_LM3S_GPIO_IM 0x410
+#define CYGHWR_HAL_LM3S_GPIO_RIS 0x414
+#define CYGHWR_HAL_LM3S_GPIO_MIS 0x418
+#define CYGHWR_HAL_LM3S_GPIO_ICR 0x41c
+#define CYGHWR_HAL_LM3S_GPIO_AFSEL 0x420
+#define CYGHWR_HAL_LM3S_GPIO_DR2R 0x500
+#define CYGHWR_HAL_LM3S_GPIO_DR4R 0x504
+#define CYGHWR_HAL_LM3S_GPIO_DR8R 0x508
+#define CYGHWR_HAL_LM3S_GPIO_ODR 0x50c
+#define CYGHWR_HAL_LM3S_GPIO_PUR 0x510
+#define CYGHWR_HAL_LM3S_GPIO_PDR 0x514
+#define CYGHWR_HAL_LM3S_GPIO_SLR 0x518
+#define CYGHWR_HAL_LM3S_GPIO_DEN 0x51c
+#define CYGHWR_HAL_LM3S_GPIO_PID4 0xfd0
+#define CYGHWR_HAL_LM3S_GPIO_PID5 0xfd4
+#define CYGHWR_HAL_LM3S_GPIO_PID6 0xfd8
+#define CYGHWR_HAL_LM3S_GPIO_PID7 0xfdc
+#define CYGHWR_HAL_LM3S_GPIO_PID0 0xfe0
+#define CYGHWR_HAL_LM3S_GPIO_PID1 0xfe4
+#define CYGHWR_HAL_LM3S_GPIO_PID2 0xfe8
+#define CYGHWR_HAL_LM3S_GPIO_PID3 0xfec
+#define CYGHWR_HAL_LM3S_GPIO_PCID0 0xff0
+#define CYGHWR_HAL_LM3S_GPIO_PCID1 0xff4
+#define CYGHWR_HAL_LM3S_GPIO_PCID2 0xff8
+#define CYGHWR_HAL_LM3S_GPIO_PCID3 0xffc
+
+#define CYGHWR_HAL_LM3S_GPIO_DIR_IN VALUE_(0,0) // Input mode
+#define CYGHWR_HAL_LM3S_GPIO_DIR_OUT VALUE_(0,1) // Output mode
+
+#define CYGHWR_HAL_LM3S_GPIO_IS_EDGE_SENSE VALUE_(0,0) // Interrupt edge sensitive
+#define CYGHWR_HAL_LM3S_GPIO_IS_LEV_SENSE VALUE_(0,1) // Interrupt level sensitive
+
+#define CYGHWR_HAL_LM3S_GPIO_IBE_GPIOIEV VALUE_(0,0) // Interrupt control from GPIOIEV
+#define CYGHWR_HAL_LM3S_GPIO_IBE_BOTH_EDGE VALUE_(0,1) // Both edges can trigger interrupt
+
+#define CYGHWR_HAL_LM3S_GPIO_IEV_LOW VALUE_(0,0) // Falling edge or low triggers interrupt
+#define CYGHWR_HAL_LM3S_GPIO_IEV_HIGH VALUE_(0,1) // Rising edge or low triggers interrupt
+
+#define CYGHWR_HAL_LM3S_GPIO_IM_MASK VALUE_(0,0) // Interrupt is masked
+#define CYGHWR_HAL_LM3S_GPIO_IM_UMASK VALUE_(0,1)
+
+// HAL definitions
+#define CYGHWR_HAL_LM3S_GPIO_MODE_IN VALUE_(0,0) // Input mode
+#define CYGHWR_HAL_LM3S_GPIO_MODE_OUT VALUE_(0,1) // Output mode
+#define CYGHWR_HAL_LM3S_GPIO_MODE_PERIPH VALUE_(0,2) // Peripheral function mode
+
+#define CYGHWR_HAL_LM3S_GPIO_STRENGTH_NONE VALUE_(2,0) // Strength not specified
+#define CYGHWR_HAL_LM3S_GPIO_STRENGTH_2_MA VALUE_(2,1) // Strength 2 mA
+#define CYGHWR_HAL_LM3S_GPIO_STRENGTH_4_MA VALUE_(2,2) // Strength 4 mA
+#define CYGHWR_HAL_LM3S_GPIO_STRENGTH_8_MA VALUE_(2,3) // Strength 8 mA
+
+#define CYGHWR_HAL_LM3S_GPIO_CNF_NONE VALUE_(4,0) // Configuration not specified
+#define CYGHWR_HAL_LM3S_GPIO_CNF_PULLUP VALUE_(4,1) // Pull-up
+#define CYGHWR_HAL_LM3S_GPIO_CNF_PULLDOWN VALUE_(4,2) // Pull-down
+#define CYGHWR_HAL_LM3S_GPIO_CNF_OP VALUE_(4,3) // Open-drain
+#define CYGHWR_HAL_LM3S_GPIO_CNF_OP_PULLUP VALUE_(4,4) // Open-drain / Pull-up
+#define CYGHWR_HAL_LM3S_GPIO_CNF_OP_PULLDOWN VALUE_(4,5) // Open-drain / Pull-down
+#define CYGHWR_HAL_LM3S_GPIO_CNF_AIN VALUE_(4,6) // Analog
+
+#define CYGHWR_HAL_LM3S_GPIO_IRQ_DISABLE VALUE_(9,0) // Interrupt disable
+#define CYGHWR_HAL_LM3S_GPIO_IRQ_FALLING_EDGE VALUE_(9,1) // Interrupt on falling edge
+#define CYGHWR_HAL_LM3S_GPIO_IRQ_RISING_EDGE VALUE_(9,2) // Interrupt on rising edge
+#define CYGHWR_HAL_LM3S_GPIO_IRQ_BOTH_EDGES VALUE_(9,3) // Interrupt on both edges
+#define CYGHWR_HAL_LM3S_GPIO_IRQ_LOW_LEVEL VALUE_(9,4) // Interrupt on low level
+#define CYGHWR_HAL_LM3S_GPIO_IRQ_HIGH_LEVEL VALUE_(9,5) // Interrupt on high level
+
+// This macro packs the port number, bit number, mode, strength, irq and
+// configuration for a GPIO pin into a single word.
+// The packing puts:
+
+#define CYGHWR_HAL_LM3S_GPIO( \
+ __port, \
+ __bit, \
+ __mode, \
+ __strength, \
+ __cnf, \
+ __irq) \
+( \
+ (CYGHWR_HAL_LM3S_GPIO ## __port - CYGHWR_HAL_LM3S_GPIOA) | \
+ (__bit << 24) | \
+ (CYGHWR_HAL_LM3S_GPIO_MODE_ ## __mode) | \
+ (CYGHWR_HAL_LM3S_GPIO_STRENGTH_ ## __strength) | \
+ (CYGHWR_HAL_LM3S_GPIO_IRQ_ ## __irq) | \
+ (CYGHWR_HAL_LM3S_GPIO_CNF_ ## __cnf) \
+)
+
+// Macros to extract encoded values
+#define CYGHWR_HAL_LM3S_GPIO_PORT(__pin) (CYGHWR_HAL_LM3S_GPIOA+((__pin)&0x000FF000))
+#define CYGHWR_HAL_LM3S_GPIO_BIT(__pin) (((__pin)>>24)&0x07)
+#define CYGHWR_HAL_LM3S_GPIO_MODE(__pin) ((__pin)&0x0003)
+#define CYGHWR_HAL_LM3S_GPIO_STRENGTH(__pin) ((__pin)&VALUE_(2,3))
+#define CYGHWR_HAL_LM3S_GPIO_CFG(__pin) ((__pin)&VALUE_(4,7))
+#define CYGHWR_HAL_LM3S_GPIO_IRQ(__pin) ((__pin)&VALUE_(9,7))
+
+#define CYGHWR_HAL_LM3S_GPIO_NONE (0xFFFFFFFF)
+
+
+// Functions and macros to configure GPIO ports.
+
+__externC void hal_lm3s_gpio_set( cyg_uint32 pin );
+__externC void hal_lm3s_gpio_out( cyg_uint32 pin, int val );
+__externC void hal_lm3s_gpio_in ( cyg_uint32 pin, int *val );
+
+#define CYGHWR_HAL_LM3S_GPIO_SET(__pin ) hal_lm3s_gpio_set( __pin )
+#define CYGHWR_HAL_LM3S_GPIO_OUT(__pin, __val ) hal_lm3s_gpio_out( __pin, __val )
+#define CYGHWR_HAL_LM3S_GPIO_IN(__pin, __val ) hal_lm3s_gpio_in( __pin, __val )
+
+
+//=============================================================================
+// UARTs
+
+#define CYGHWR_HAL_LM3S_UART_DR 0x000
+#define CYGHWR_HAL_LM3S_UART_SR 0x004
+#define CYGHWR_HAL_LM3S_UART_FR 0x018
+#define CYGHWR_HAL_LM3S_UART_IBRD 0x024
+#define CYGHWR_HAL_LM3S_UART_FBRD 0x028
+#define CYGHWR_HAL_LM3S_UART_LCRH 0x02c
+#define CYGHWR_HAL_LM3S_UART_CTL 0x030
+#define CYGHWR_HAL_LM3S_UART_IFLS 0x034
+#define CYGHWR_HAL_LM3S_UART_IM 0x038
+#define CYGHWR_HAL_LM3S_UART_RIS 0x03c
+#define CYGHWR_HAL_LM3S_UART_MIS 0x040
+#define CYGHWR_HAL_LM3S_UART_ICR 0x044
+#define CYGHWR_HAL_LM3S_UART_PID4 0xfd0
+#define CYGHWR_HAL_LM3S_UART_PID5 0xfd4
+#define CYGHWR_HAL_LM3S_UART_PID6 0xfd8
+#define CYGHWR_HAL_LM3S_UART_PID7 0xfdc
+#define CYGHWR_HAL_LM3S_UART_PID0 0xfe0
+#define CYGHWR_HAL_LM3S_UART_PID1 0xfe4
+#define CYGHWR_HAL_LM3S_UART_PID2 0xfe8
+#define CYGHWR_HAL_LM3S_UART_PID3 0xfec
+#define CYGHWR_HAL_LM3S_UART_PCID0 0xff0
+#define CYGHWR_HAL_LM3S_UART_PCID1 0xff4
+#define CYGHWR_HAL_LM3S_UART_PCID2 0xff8
+#define CYGHWR_HAL_LM3S_UART_PCID3 0xffc
+
+
+// DR Bits
+#define CYGHWR_HAL_LM3S_UART_DR_FE BIT_(8)
+#define CYGHWR_HAL_LM3S_UART_DR_PE BIT_(9)
+#define CYGHWR_HAL_LM3S_UART_DR_BE BIT_(10)
+#define CYGHWR_HAL_LM3S_UART_DR_OE BIT_(11)
+
+// SR Bits
+#define CYGHWR_HAL_LM3S_UART_SR_FE BIT_(0)
+#define CYGHWR_HAL_LM3S_UART_SR_PE BIT_(1)
+#define CYGHWR_HAL_LM3S_UART_SR_BE BIT_(2)
+#define CYGHWR_HAL_LM3S_UART_SR_OE BIT_(3)
+
+// FR bits
+#define CYGHWR_HAL_LM3S_UART_FR_BUSY BIT_(3)
+#define CYGHWR_HAL_LM3S_UART_FR_RXFE BIT_(4)
+#define CYGHWR_HAL_LM3S_UART_FR_TXFF BIT_(5)
+#define CYGHWR_HAL_LM3S_UART_FR_RXFF BIT_(6)
+#define CYGHWR_HAL_LM3S_UART_FR_TXFE BIT_(7)
+
+// LCRH bits
+#define CYGHWR_HAL_LM3S_UART_LCRH_BRK BIT_(0)
+#define CYGHWR_HAL_LM3S_UART_LCRH_PEN BIT_(1)
+#define CYGHWR_HAL_LM3S_UART_LCRH_EPS BIT_(2)
+#define CYGHWR_HAL_LM3S_UART_LCRH_STP2 BIT_(3)
+#define CYGHWR_HAL_LM3S_UART_LCRH_FEN BIT_(4)
+#define CYGHWR_HAL_LM3S_UART_LCRH_WLEN(__x) VALUE_(5,__x)
+#define CYGHWR_HAL_LM3S_UART_LCRH_WLEN_MASK 0x00000060
+#define CYGHWR_HAL_LM3S_UART_LCRH_SPS BIT_(7)
+
+// CTL bits
+#define CYGHWR_HAL_LM3S_UART_CTL_UARTEN BIT_(0)
+#define CYGHWR_HAL_LM3S_UART_CTL_LBE BIT_(7)
+#define CYGHWR_HAL_LM3S_UART_CTL_TXE BIT_(8)
+#define CYGHWR_HAL_LM3S_UART_CTL_RXE BIT_(9)
+
+// IFLS bits
+#define CYGHWR_HAL_LM3S_UART_IFLS_RXIFLSEL(__x) VALUE_(0,__x)
+#define CYGHWR_HAL_LM3S_UART_IFLS_RXIFLSEL_MASK 0x00000007
+#define CYGHWR_HAL_LM3S_UART_IFLS_TXIFLSEL(__x) VALUE_(3,__x)
+#define CYGHWR_HAL_LM3S_UART_IFLS_TXIFLSEL_MASK 0x00000038
+
+// IM bits
+#define CYGHWR_HAL_LM3S_UART_IM_RXIM BIT_(4)
+#define CYGHWR_HAL_LM3S_UART_IM_TXIM BIT_(5)
+#define CYGHWR_HAL_LM3S_UART_IM_RTIM BIT_(6)
+#define CYGHWR_HAL_LM3S_UART_IM_FEIM BIT_(7)
+#define CYGHWR_HAL_LM3S_UART_IM_PEIM BIT_(8)
+#define CYGHWR_HAL_LM3S_UART_IM_BEIM BIT_(9)
+#define CYGHWR_HAL_LM3S_UART_IM_OEIM BIT_(10)
+
+// RIS bits
+#define CYGHWR_HAL_LM3S_UART_RIS_RXRIS BIT_(4)
+#define CYGHWR_HAL_LM3S_UART_RIS_TXRIS BIT_(5)
+#define CYGHWR_HAL_LM3S_UART_RIS_RTRIS BIT_(6)
+#define CYGHWR_HAL_LM3S_UART_RIS_FERIS BIT_(7)
+#define CYGHWR_HAL_LM3S_UART_RIS_PERIS BIT_(8)
+#define CYGHWR_HAL_LM3S_UART_RIS_BERIS BIT_(9)
+#define CYGHWR_HAL_LM3S_UART_RIS_OERIS BIT_(10)
+
+// MIS bits
+#define CYGHWR_HAL_LM3S_UART_MIS_RXMIS BIT_(4)
+#define CYGHWR_HAL_LM3S_UART_MIS_TXMIS BIT_(5)
+#define CYGHWR_HAL_LM3S_UART_MIS_RTMIS BIT_(6)
+#define CYGHWR_HAL_LM3S_UART_MIS_FEMIS BIT_(7)
+#define CYGHWR_HAL_LM3S_UART_MIS_PEMIS BIT_(8)
+#define CYGHWR_HAL_LM3S_UART_MIS_BEMIS BIT_(9)
+#define CYGHWR_HAL_LM3S_UART_MIS_OEMIS BIT_(10)
+
+// ICR bits
+#define CYGHWR_HAL_LM3S_UART_ICR_RXIC BIT_(4)
+#define CYGHWR_HAL_LM3S_UART_ICR_TXIC BIT_(5)
+#define CYGHWR_HAL_LM3S_UART_ICR_RTIC BIT_(6)
+#define CYGHWR_HAL_LM3S_UART_ICR_FEIC BIT_(7)
+#define CYGHWR_HAL_LM3S_UART_ICR_PEIC BIT_(8)
+#define CYGHWR_HAL_LM3S_UART_ICR_BEIC BIT_(9)
+#define CYGHWR_HAL_LM3S_UART_ICR_OEIC BIT_(10)
+
+// UARTO shall be connected to PortA 0/1 on all device
+#ifndef CYGHWR_HAL_LM3S_UART0_TX
+# define CYGHWR_HAL_LM3S_UART0_TX CYGHWR_HAL_LM3S_GPIO( A, 0, PERIPH, NONE, NONE, DISABLE )
+#endif
+#ifndef CYGHWR_HAL_LM3S_UART0_RX
+# define CYGHWR_HAL_LM3S_UART0_RX CYGHWR_HAL_LM3S_GPIO( A, 1, PERIPH, NONE, NONE, DISABLE )
+#endif
+#ifndef CYGHWR_HAL_LM3S_P_UART0_GPIO
+# define CYGHWR_HAL_LM3S_P_UART0_GPIO CYGHWR_HAL_LM3S_P_GPIOA
+#endif
+
+#ifndef __ASSEMBLER__
+
+__externC void hal_lm3s_uart_setbaud( CYG_ADDRESS uart, cyg_uint32 baud );
+
+#endif
+
+//=============================================================================
+// ADCs
+
+#ifdef CYGHWR_HAL_LM3S_ADC0_CHAN
+
+#define CYGHWR_HAL_LM3S_ADC_ACTSS 0x0
+#define CYGHWR_HAL_LM3S_ADC_RIS 0x4
+#define CYGHWR_HAL_LM3S_ADC_IMR 0x8
+#define CYGHWR_HAL_LM3S_ADC_ISCR 0xc
+#define CYGHWR_HAL_LM3S_ADC_OSR 0x10
+#define CYGHWR_HAL_LM3S_ADC_EMUX 0x14
+#define CYGHWR_HAL_LM3S_ADC_USR 0x18
+#define CYGHWR_HAL_LM3S_ADC_SSPRI 0x20
+#define CYGHWR_HAL_LM3S_ADC_PSSI 0x28
+#define CYGHWR_HAL_LM3S_ADC_SAC 0x30
+#define CYGHWR_HAL_LM3S_ADC_SS_MUX0 0x40
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0 0x44
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO0 0x48
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO0_SR 0x4c
+#define CYGHWR_HAL_LM3S_ADC_SS_MUX1 0x60
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL1 0x64
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO1 0x68
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO1_SR 0x6c
+#define CYGHWR_HAL_LM3S_ADC_SS_MUX2 0x80
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL2 0x84
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO2 0x88
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO2_SR 0x8c
+#define CYGHWR_HAL_LM3S_ADC_SS_MUX3 0xa0
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL3 0xa4
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO3 0xa8
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO3_SR 0xac
+#define CYGHWR_HAL_LM3S_ADC_TMLB 0x100
+
+#define CYGHWR_HAL_LM3S_ADC_SAMPLE_SIZE 10
+
+// Active Sample Sequencer
+#define CYGHWR_HAL_LM3S_ADC_ACTSS_ASEN(__x) VALUE_(((__x)&3),1)
+
+// Raw Interrupt Status
+#define CYGHWR_HAL_LM3S_ADC_RIS_INR(__x) VALUE_(((__x)&3),1)
+
+// Interrupt Mask Register
+#define CYGHWR_HAL_LM3S_ADC_IMR_MASK(__x) VALUE_(((__x)&3),1)
+
+// Interrupt Status and Clear Register
+#define CYGHWR_HAL_LM3S_ADC_ISCR_IN(__x) VALUE_(((__x)&3),1)
+
+// Overflow Status Register
+#define CYGHWR_HAL_LM3S_ADC_OSR_OV(__x) VALUE_(((__x)&3),1)
+
+// Event Multiplexer Select
+#define CYGHWR_HAL_LM3S_ADC_EMUX_EM_CTRL(__x) VALUE_((((__x)&3)<<2),0)
+#define CYGHWR_HAL_LM3S_ADC_EMUX_EM_AC0(__x) VALUE_((((__x)&3)<<2),1)
+#define CYGHWR_HAL_LM3S_ADC_EMUX_EM_EXT(__x) VALUE_((((__x)&3)<<2),4)
+#define CYGHWR_HAL_LM3S_ADC_EMUX_EM_TIMER(__x) VALUE_((((__x)&3)<<2),5)
+#define CYGHWR_HAL_LM3S_ADC_EMUX_EM_PWM0(__x) VALUE_((((__x)&3)<<2),6)
+#define CYGHWR_HAL_LM3S_ADC_EMUX_EM_PWM1(__x) VALUE_((((__x)&3)<<2),7)
+#define CYGHWR_HAL_LM3S_ADC_EMUX_EM_PWM2(__x) VALUE_((((__x)&3)<<2),8)
+#define CYGHWR_HAL_LM3S_ADC_EMUX_EM_ALWS(__x) VALUE_((((__x)&3)<<2),15)
+
+// Underflow Status
+#define CYGHWR_HAL_LM3S_ADC_USR_UV(__x) VALUE_(((__x)&3),1)
+
+// Sample Sequence Priority
+#define CYGHWR_HAL_LM3S_ADC_SSPRI_SS(__x, __y) VALUE_((((__x)&3)<<2),(__y)&3)
+
+// Processor Sample Sequence Initiate
+#define CYGHWR_HAL_LM3S_ADC_PSSI_SS(__x) VALUE_(((__x)&3),1)
+
+// Sample Averaging Control
+#define CYGHWR_HAL_LM3S_ADC_SAC_NO_OVER 0x0
+#define CYGHWR_HAL_LM3S_ADC_SAC_2X 0x1
+#define CYGHWR_HAL_LM3S_ADC_SAC_4X 0x2
+#define CYGHWR_HAL_LM3S_ADC_SAC_8X 0x3
+#define CYGHWR_HAL_LM3S_ADC_SAC_16X 0x4
+#define CYGHWR_HAL_LM3S_ADC_SAC_32X 0x5
+#define CYGHWR_HAL_LM3S_ADC_SAC_64X 0x6
+
+// Sample Sequence Input Multiplexer Select 0
+#define CYGHWR_HAL_LM3S_ADC_SS_MUX0_V(_p_, _x_) VALUE_((((_x_)&3)<<2),_p_)
+#define CYGHWR_HAL_LM3S_ADC_SS_MUX0_M(_x_) VALUE_((((_x_)&3)<<2), 0x3)
+
+// Sample Sequence Control 0
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_D0 BIT_(0)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_END0 BIT_(1)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_IE0 BIT_(2)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_TS0 BIT_(3)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_D1 BIT_(4)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_END1 BIT_(5)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_IE1 BIT_(6)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_TS1 BIT_(7)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_D2 BIT_(8)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_END2 BIT_(9)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_IE2 BIT_(10)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_TS2 BIT_(11)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_D3 BIT_(12)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_END3 BIT_(13)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_IE3 BIT_(14)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_TS3 BIT_(15)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_D4 BIT_(16)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_END4 BIT_(17)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_IE4 BIT_(18)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_TS4 BIT_(19)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_D5 BIT_(20)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_END5 BIT_(21)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_IE5 BIT_(22)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_TS5 BIT_(23)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_D6 BIT_(24)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_END6 BIT_(25)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_IE6 BIT_(26)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_TS6 BIT_(27)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_D7 BIT_(28)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_END7 BIT_(29)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_IE7 BIT_(30)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_TS7 BIT_(31)
+
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_MASK(_x_) VALUE_((((_x_)&3)<<2), 0x15)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_D(_x_) VALUE_((((_x_)&3)<<2), 0x1)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_END(_x_) VALUE_((((_x_)&3)<<2), 0x2)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_IE(_x_) VALUE_((((_x_)&3)<<2), 0x4)
+#define CYGHWR_HAL_LM3S_ADC_SS_CTL0_TS(_x_) VALUE_((((_x_)&3)<<2), 0x8)
+
+// Sequence FIFO Status
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO_SR_TPTR 0x0
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO_SR_HPTR 0x0
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO_SR_EMPTY BIT_(8)
+#define CYGHWR_HAL_LM3S_ADC_SS_FIFO_SR_FULL BIT_(12)
+
+#endif // CYGHWR_HAL_LM3S_ADC0_CHAN
+
+
+//=============================================================================
+// SSI interface register definitions.
+
+#ifdef CYGHWR_HAL_LM3S_SSI_CHAN
+
+#define CYGHWR_HAL_LM3S_SSI_CR0 0x000
+#define CYGHWR_HAL_LM3S_SSI_CR1 0x004
+#define CYGHWR_HAL_LM3S_SSI_DR 0x008
+#define CYGHWR_HAL_LM3S_SSI_SR 0x00C
+#define CYGHWR_HAL_LM3S_SSI_CPSR 0x010
+#define CYGHWR_HAL_LM3S_SSI_IM 0x014
+#define CYGHWR_HAL_LM3S_SSI_RIS 0x018
+#define CYGHWR_HAL_LM3S_SSI_MIS 0x01c
+#define CYGHWR_HAL_LM3S_SSI_ICR 0x020
+#define CYGHWR_HAL_LM3S_SSI_PID4 0xfd0
+#define CYGHWR_HAL_LM3S_SSI_PID5 0xfd4
+#define CYGHWR_HAL_LM3S_SSI_PID6 0xfd8
+#define CYGHWR_HAL_LM3S_SSI_PID7 0xfdc
+#define CYGHWR_HAL_LM3S_SSI_PID0 0xfe0
+#define CYGHWR_HAL_LM3S_SSI_PID1 0xfe4
+#define CYGHWR_HAL_LM3S_SSI_PID2 0xfe8
+#define CYGHWR_HAL_LM3S_SSI_PID3 0xfec
+#define CYGHWR_HAL_LM3S_SSI_PCID0 0xff0
+#define CYGHWR_HAL_LM3S_SSI_PCID1 0xff4
+#define CYGHWR_HAL_LM3S_SSI_PCID2 0xff8
+#define CYGHWR_HAL_LM3S_SSI_PCID3 0xffc
+
+
+// CR0 bits
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_4BIT VALUE_(0, 0x3)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_5BIT VALUE_(0, 0x4)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_6BIT VALUE_(0, 0x5)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_7BIT VALUE_(0, 0x6)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_8BIT VALUE_(0, 0x7)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_9BIT VALUE_(0, 0x8)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_10BIT VALUE_(0, 0x9)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_11BIT VALUE_(0, 0xa)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_12BIT VALUE_(0, 0xb)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_13BIT VALUE_(0, 0xc)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_14BIT VALUE_(0, 0xd)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_15BIT VALUE_(0, 0xe)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_16BIT VALUE_(0, 0xf)
+#define CYGHWR_HAL_LM3S_SSI_CR0_DSS_MASK 0x0000000f
+#define CYGHWR_HAL_LM3S_SSI_CR0_FRF_FSPIFF VALUE_(4, 0x0)
+#define CYGHWR_HAL_LM3S_SSI_CR0_FRF_TISSFF VALUE_(4, 0x1)
+#define CYGHWR_HAL_LM3S_SSI_CR0_FRF_MFF VALUE_(4, 0x2)
+#define CYGHWR_HAL_LM3S_SSI_CR0_FRF_MASK 0x00000030
+#define CYGHWR_HAL_LM3S_SSI_CR0_SPO BIT_(6)
+#define CYGHWR_HAL_LM3S_SSI_CR0_SPH BIT_(7)
+#define CYGHWR_HAL_LM3S_SSI_CR0_SCR(__x) VALUE_(8, ((__x)&0xff))
+
+// CR1 bits
+#define CYGHWR_HAL_LM3S_SSI_CR1_LBM BIT_(0)
+#define CYGHWR_HAL_LM3S_SSI_CR1_SSE BIT_(1)
+#define CYGHWR_HAL_LM3S_SSI_CR1_MS BIT_(2)
+#define CYGHWR_HAL_LM3S_SSI_CR1_SOD BIT_(3)
+
+// SR bits
+#define CYGHWR_HAL_LM3S_SSI_SR_TFE BIT_(0)
+#define CYGHWR_HAL_LM3S_SSI_SR_TNF BIT_(1)
+#define CYGHWR_HAL_LM3S_SSI_SR_RNE BIT_(2)
+#define CYGHWR_HAL_LM3S_SSI_SR_RFF BIT_(3)
+#define CYGHWR_HAL_LM3S_SSI_SR_BSY BIT_(4)
+
+// IM bits
+#define CYGHWR_HAL_LM3S_SSI_IM_RORIM BIT_(0)
+#define CYGHWR_HAL_LM3S_SSI_IM_RTIM BIT_(1)
+#define CYGHWR_HAL_LM3S_SSI_IM_RXIM BIT_(2)
+#define CYGHWR_HAL_LM3S_SSI_IM_TXIM BIT_(3)
+
+// RIS bits
+#define CYGHWR_HAL_LM3S_SSI_RIS_RORRIS BIT_(0)
+#define CYGHWR_HAL_LM3S_SSI_RIS_RTRIS BIT_(1)
+#define CYGHWR_HAL_LM3S_SSI_RIS_RXRIS BIT_(2)
+#define CYGHWR_HAL_LM3S_SSI_RIS_TXRIS BIT_(3)
+
+// MIS bits
+#define CYGHWR_HAL_LM3S_SSI_MIS_RORMIS BIT_(0)
+#define CYGHWR_HAL_LM3S_SSI_MIS_RTMIS BIT_(1)
+#define CYGHWR_HAL_LM3S_SSI_MIS_RXMIS BIT_(2)
+#define CYGHWR_HAL_LM3S_SSI_MIS_TXMIS BIT_(3)
+
+// ICR bits
+#define CYGHWR_HAL_LM3S_SSI_ICR_RORIC BIT_(0)
+#define CYGHWR_HAL_LM3S_SSI_ICR_RTIC BIT_(1)
+
+#endif // CYGHWR_HAL_LM3S_SSI_CHAN
+
+//=============================================================================
+// PWM register definitions.
+
+#ifdef CYGHWR_HAL_LM3S_PWM_CHAN
+
+#define CYGHWR_HAL_LM3S_PWM_CTL 0x000
+#define CYGHWR_HAL_LM3S_PWM_SYNC 0x004
+#define CYGHWR_HAL_LM3S_PWM_ENABLE 0x008
+#define CYGHWR_HAL_LM3S_PWM_INVERT 0x00c
+#define CYGHWR_HAL_LM3S_PWM_FAULT 0x010
+#define CYGHWR_HAL_LM3S_PWM_INTEN 0x014
+#define CYGHWR_HAL_LM3S_PWM_RIS 0x018
+#define CYGHWR_HAL_LM3S_PWM_ISC 0x01c
+#define CYGHWR_HAL_LM3S_PWM_STATUS 0x020
+
+#define CYGHWR_HAL_LM3S_PWM0_CTL 0x040
+#define CYGHWR_HAL_LM3S_PWM0_INTEN 0x044
+#define CYGHWR_HAL_LM3S_PWM0_RIS 0x048
+#define CYGHWR_HAL_LM3S_PWM0_ISC 0x04c
+#define CYGHWR_HAL_LM3S_PWM0_LOAD 0x050
+#define CYGHWR_HAL_LM3S_PWM0_COUNT 0x054
+#define CYGHWR_HAL_LM3S_PWM0_CMPA 0x058
+#define CYGHWR_HAL_LM3S_PWM0_CMPB 0x05c
+#define CYGHWR_HAL_LM3S_PWM0_GENA 0x060
+#define CYGHWR_HAL_LM3S_PWM0_GENB 0x064
+#define CYGHWR_HAL_LM3S_PWM0_DBCTL 0x068
+#define CYGHWR_HAL_LM3S_PWM0_DBRISE 0x06c
+#define CYGHWR_HAL_LM3S_PWM0_DBFALL 0x070
+
+#define CYGHWR_HAL_LM3S_PWM1_CTL 0x080
+#define CYGHWR_HAL_LM3S_PWM1_INTEN 0x084
+#define CYGHWR_HAL_LM3S_PWM1_RIS 0x088
+#define CYGHWR_HAL_LM3S_PWM1_ISC 0x08c
+#define CYGHWR_HAL_LM3S_PWM1_LOAD 0x090
+#define CYGHWR_HAL_LM3S_PWM1_COUNT 0x094
+#define CYGHWR_HAL_LM3S_PWM1_CMPA 0x098
+#define CYGHWR_HAL_LM3S_PWM1_CMPB 0x09c
+#define CYGHWR_HAL_LM3S_PWM1_GENA 0x0a0
+#define CYGHWR_HAL_LM3S_PWM1_GENB 0x0a4
+#define CYGHWR_HAL_LM3S_PWM1_DBCTL 0x0a8
+#define CYGHWR_HAL_LM3S_PWM1_DBRISE 0x0ac
+#define CYGHWR_HAL_LM3S_PWM1_DBFALL 0x0b0
+
+#define CYGHWR_HAL_LM3S_PWM2_CTL 0x0c0
+#define CYGHWR_HAL_LM3S_PWM2_INTEN 0x0c4
+#define CYGHWR_HAL_LM3S_PWM2_RIS 0x0c8
+#define CYGHWR_HAL_LM3S_PWM2_ISC 0x0cc
+#define CYGHWR_HAL_LM3S_PWM2_LOAD 0x0d0
+#define CYGHWR_HAL_LM3S_PWM2_COUNT 0x0d4
+#define CYGHWR_HAL_LM3S_PWM2_CMPA 0x0d8
+#define CYGHWR_HAL_LM3S_PWM2_CMPB 0x0dc
+#define CYGHWR_HAL_LM3S_PWM2_GENA 0x0e0
+#define CYGHWR_HAL_LM3S_PWM2_GENB 0x0e4
+#define CYGHWR_HAL_LM3S_PWM2_DBCTL 0x0e8
+#define CYGHWR_HAL_LM3S_PWM2_DBRISE 0x0ec
+#define CYGHWR_HAL_LM3S_PWM2_DBFALL 0x0f0
+
+
+// CTL bits
+#define CYGHWR_HAL_LM3S_PWM_CTL_GSYNC0 BIT_(0)
+#define CYGHWR_HAL_LM3S_PWM_CTL_GSYNC1 BIT_(1)
+#define CYGHWR_HAL_LM3S_PWM_CTL_GSYNC2 BIT_(2)
+
+// SYNC bits
+#define CYGHWR_HAL_LM3S_PWM_SYNC_SYNC0 BIT_(0)
+#define CYGHWR_HAL_LM3S_PWM_SYNC_SYNC1 BIT_(1)
+#define CYGHWR_HAL_LM3S_PWM_SYNC_SYNC2 BIT_(2)
+
+// ENABLE bits
+#define CYGHWR_HAL_LM3S_PWM_ENABLE_PWM0 BIT_(0)
+#define CYGHWR_HAL_LM3S_PWM_ENABLE_PWM1 BIT_(1)
+#define CYGHWR_HAL_LM3S_PWM_ENABLE_PWM2 BIT_(2)
+#define CYGHWR_HAL_LM3S_PWM_ENABLE_PWM3 BIT_(3)
+#define CYGHWR_HAL_LM3S_PWM_ENABLE_PWM4 BIT_(4)
+#define CYGHWR_HAL_LM3S_PWM_ENABLE_PWM5 BIT_(5)
+
+// INVERT bits
+#define CYGHWR_HAL_LM3S_PWM_INVERT_PWM0 BIT_(0)
+#define CYGHWR_HAL_LM3S_PWM_INVERT_PWM1 BIT_(1)
+#define CYGHWR_HAL_LM3S_PWM_INVERT_PWM2 BIT_(2)
+#define CYGHWR_HAL_LM3S_PWM_INVERT_PWM3 BIT_(3)
+#define CYGHWR_HAL_LM3S_PWM_INVERT_PWM4 BIT_(4)
+#define CYGHWR_HAL_LM3S_PWM_INVERT_PWM5 BIT_(5)
+
+// FAULT bits
+#define CYGHWR_HAL_LM3S_PWM_FAULT_PWM0 BIT_(0)
+#define CYGHWR_HAL_LM3S_PWM_FAULT_PWM1 BIT_(1)
+#define CYGHWR_HAL_LM3S_PWM_FAULT_PWM2 BIT_(2)
+#define CYGHWR_HAL_LM3S_PWM_FAULT_PWM3 BIT_(3)
+#define CYGHWR_HAL_LM3S_PWM_FAULT_PWM4 BIT_(4)
+#define CYGHWR_HAL_LM3S_PWM_FAULT_PWM5 BIT_(5)
+
+// INTEN bits
+#define CYGHWR_HAL_LM3S_PWM_INTEN_PWM0 BIT_(0)
+#define CYGHWR_HAL_LM3S_PWM_INTEN_PWM1 BIT_(1)
+#define CYGHWR_HAL_LM3S_PWM_INTEN_PWM2 BIT_(2)
+#define CYGHWR_HAL_LM3S_PWM_INTEN_FAULT BIT_(16)
+
+// RIS bits
+#define CYGHWR_HAL_LM3S_PWM_RIS_PWM0 BIT_(0)
+#define CYGHWR_HAL_LM3S_PWM_RIS_PWM1 BIT_(1)
+#define CYGHWR_HAL_LM3S_PWM_RIS_PWM2 BIT_(2)
+#define CYGHWR_HAL_LM3S_PWM_RIS_FAULT BIT_(16)
+
+// ISC bits
+#define CYGHWR_HAL_LM3S_PWM_ISC_PWM0 BIT_(0)
+#define CYGHWR_HAL_LM3S_PWM_ISC_PWM1 BIT_(1)
+#define CYGHWR_HAL_LM3S_PWM_ISC_PWM2 BIT_(2)
+#define CYGHWR_HAL_LM3S_PWM_ISC_FAULT BIT_(16)
+
+// STATUS bits
+#define CYGHWR_HAL_LM3S_PWM_STATUS_FAULT BIT_(0)
+
+// PWMx CTL Bits
+#define CYGHWR_HAL_LM3S_PWMx_CTL_ENABLE BIT_(0)
+#define CYGHWR_HAL_LM3S_PWMx_CTL_MODE BIT_(1)
+#define CYGHWR_HAL_LM3S_PWMx_CTL_DEBUG BIT_(2)
+#define CYGHWR_HAL_LM3S_PWMx_CTL_LOAD_UPD BIT_(3)
+#define CYGHWR_HAL_LM3S_PWMx_CTL_CMPA_UPD BIT_(4)
+#define CYGHWR_HAL_LM3S_PWMx_CTL_CMPB_UPD BIT_(5)
+
+// PWMx INTEN Bits
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_CNT_ZERO BIT_(0)
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_CNT_LOAD BIT_(1)
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_CMPA_UP BIT_(2)
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_CMPA_DOWN BIT_(3)
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_CMPB_UP BIT_(4)
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_CMPB_DOWN BIT_(5)
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_TRIG_CNT_ZERO BIT_(8)
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_TRIG_CNT_LOAD BIT_(9)
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_TRIG_CMPA_UP BIT_(10)
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_TRIG_CMPA_DOWN BIT_(11)
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_TRIG_CMPB_UP BIT_(12)
+#define CYGHWR_HAL_LM3S_PWMx_INTEN_TRIG_CMPB_DOWN BIT_(13)
+
+// PWMx RIS Bits
+#define CYGHWR_HAL_LM3S_PWMx_RIS_CNT_ZERO BIT_(0)
+#define CYGHWR_HAL_LM3S_PWMx_RIS_CNT_LOAD BIT_(1)
+#define CYGHWR_HAL_LM3S_PWMx_RIS_CMPA_UP BIT_(2)
+#define CYGHWR_HAL_LM3S_PWMx_RIS_CMPA_DOWN BIT_(3)
+#define CYGHWR_HAL_LM3S_PWMx_RIS_CMPB_UP BIT_(4)
+#define CYGHWR_HAL_LM3S_PWMx_RIS_CMPB_DOWN BIT_(5)
+
+// PWMx ISC Bits
+#define CYGHWR_HAL_LM3S_PWMx_ISC_CNT_ZERO BIT_(0)
+#define CYGHWR_HAL_LM3S_PWMx_ISC_CNT_LOAD BIT_(1)
+#define CYGHWR_HAL_LM3S_PWMx_ISC_CMPA_UP BIT_(2)
+#define CYGHWR_HAL_LM3S_PWMx_ISC_CMPA_DOWN BIT_(3)
+#define CYGHWR_HAL_LM3S_PWMx_ISC_CMPB_UP BIT_(4)
+#define CYGHWR_HAL_LM3S_PWMx_ISC_CMPB_DOWN BIT_(5)
+
+// PWMx GENA Bits
+#define CYGHWR_HAL_LM3S_PWMx_GENA_ACT_ZERO_NONE VALUE_(0, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_ACT_ZERO_INVS VALUE_(0, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_ACT_ZERO_SET0 VALUE_(0, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_ACT_ZERO_SET1 VALUE_(0, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_ACT_ZERO_MASK 0x00000003
+#define CYGHWR_HAL_LM3S_PWMx_GENA_ACT_LOAD_NONE VALUE_(2, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_ACT_LOAD_INVS VALUE_(2, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_ACT_LOAD_SET0 VALUE_(2, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_ACT_LOAD_SET1 VALUE_(2, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_ACT_LOAD_MASK 0x0000000c
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPA_UP_NONE VALUE_(4, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPA_UP_INVS VALUE_(4, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPA_UP_SET0 VALUE_(4, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPA_UP_SET1 VALUE_(4, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPA_UP_MASK 0x00000030
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPA_DOWN_NONE VALUE_(6, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPA_DOWN_INVS VALUE_(6, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPA_DOWN_SET0 VALUE_(6, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPA_DOWN_SET1 VALUE_(6, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPA_DOWN_MASK 0x000000c0
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPB_UP_NONE VALUE_(8, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPB_UP_INVS VALUE_(8, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPB_UP_SET0 VALUE_(8, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPB_UP_SET1 VALUE_(8, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPB_UP_MASK 0x00000300
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPB_DOWN_NONE VALUE_(10, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPB_DOWN_INVS VALUE_(10, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPB_DOWN_SET0 VALUE_(10, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPB_DOWN_SET1 VALUE_(10, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENA_CMPB_DOWN_MASK 0x00000c00
+
+// PWMx GENB Bits
+#define CYGHWR_HAL_LM3S_PWMx_GENB_ACT_ZERO_NONE VALUE_(0, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_ACT_ZERO_INVS VALUE_(0, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_ACT_ZERO_SET0 VALUE_(0, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_ACT_ZERO_SET1 VALUE_(0, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_ACT_ZERO_MASK 0x00000003
+#define CYGHWR_HAL_LM3S_PWMx_GENB_ACT_LOAD_NONE VALUE_(2, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_ACT_LOAD_INVS VALUE_(2, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_ACT_LOAD_SET0 VALUE_(2, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_ACT_LOAD_SET1 VALUE_(2, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_ACT_LOAD_MASK 0x0000000c
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPA_UP_NONE VALUE_(4, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPA_UP_INVS VALUE_(4, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPA_UP_SET0 VALUE_(4, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPA_UP_SET1 VALUE_(4, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPA_UP_MASK 0x00000030
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPA_DOWN_NONE VALUE_(6, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPA_DOWN_INVS VALUE_(6, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPA_DOWN_SET0 VALUE_(6, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPA_DOWN_SET1 VALUE_(6, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPA_DOWN_MASK 0x000000c0
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPB_UP_NONE VALUE_(8, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPB_UP_INVS VALUE_(8, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPB_UP_SET0 VALUE_(8, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPB_UP_SET1 VALUE_(8, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPB_UP_MASK 0x00000300
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPB_DOWN_NONE VALUE_(10, 0x0)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPB_DOWN_INVS VALUE_(10, 0x1)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPB_DOWN_SET0 VALUE_(10, 0x2)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPB_DOWN_SET1 VALUE_(10, 0x3)
+#define CYGHWR_HAL_LM3S_PWMx_GENB_CMPB_DOWN_MASK 0x00000c00
+
+// PWMx DBCTL Bits
+#define CYGHWR_HAL_LM3S_PWMx_DBCTL_ENABLE BIT_(0)
+
+#endif // CYGHWR_HAL_LM3S_PWM_CHAN
+
+
+//=============================================================================
+// Global Timers register definitions.
+
+#define CYGHWR_HAL_LM3S_GPTIM_CFG 0x000
+#define CYGHWR_HAL_LM3S_GPTIM_TAMR 0x004
+#define CYGHWR_HAL_LM3S_GPTIM_TBMR 0x008
+#define CYGHWR_HAL_LM3S_GPTIM_CTL 0x00c
+#define CYGHWR_HAL_LM3S_GPTIM_IMR 0x018
+#define CYGHWR_HAL_LM3S_GPTIM_RIS 0x01C
+#define CYGHWR_HAL_LM3S_GPTIM_MIS 0x020
+#define CYGHWR_HAL_LM3S_GPTIM_ICR 0x024
+#define CYGHWR_HAL_LM3S_GPTIM_TAILR 0x028
+#define CYGHWR_HAL_LM3S_GPTIM_TBILR 0x02c
+#define CYGHWR_HAL_LM3S_GPTIM_TAMATCHR 0x030
+#define CYGHWR_HAL_LM3S_GPTIM_TBMATCHR 0x034
+#define CYGHWR_HAL_LM3S_GPTIM_TAPR 0x038
+#define CYGHWR_HAL_LM3S_GPTIM_TBPR 0x03c
+#define CYGHWR_HAL_LM3S_GPTIM_TAPMR 0x040
+#define CYGHWR_HAL_LM3S_GPTIM_TBPMR 0x044
+#define CYGHWR_HAL_LM3S_GPTIM_TAR 0x048
+#define CYGHWR_HAL_LM3S_GPTIM_TBR 0x04c
+
+// CFG bits
+#define CYGHWR_HAL_LM3S_GPTIM_CFG_32BIT VALUE_(0, 0x0)
+#define CYGHWR_HAL_LM3S_GPTIM_CFG_32BIT_RTC VALUE_(0, 0x1)
+#define CYGHWR_HAL_LM3S_GPTIM_CFG_16BIT VALUE_(0, 0x4)
+#define CYGHWR_HAL_LM3S_GPTIM_CFG_MASK 0x00000007
+
+// TAMR bits
+#define CYGHWR_HAL_LM3S_GPTIM_TAMR_ONE_SHOT VALUE_(0, 0x1)
+#define CYGHWR_HAL_LM3S_GPTIM_TAMR_PERIODIC VALUE_(0, 0x2)
+#define CYGHWR_HAL_LM3S_GPTIM_TAMR_CAPTURE VALUE_(0, 0x3)
+#define CYGHWR_HAL_LM3S_GPTIM_TAMR_MASK 0x00000003
+#define CYGHWR_HAL_LM3S_GPTIM_TAMR_TACMR BIT_(2)
+#define CYGHWR_HAL_LM3S_GPTIM_TAMR_TAAMS BIT_(3)
+
+// TBMR bits
+#define CYGHWR_HAL_LM3S_GPTIM_TBMR_ONE_SHOT VALUE_(0, 0x1)
+#define CYGHWR_HAL_LM3S_GPTIM_TBMR_PERIODIC VALUE_(0, 0x2)
+#define CYGHWR_HAL_LM3S_GPTIM_TBMR_CAPTURE VALUE_(0, 0x3)
+#define CYGHWR_HAL_LM3S_GPTIM_TBMR_MASK 0x00000003
+#define CYGHWR_HAL_LM3S_GPTIM_TBMR_TBCMR BIT_(2)
+#define CYGHWR_HAL_LM3S_GPTIM_TBMR_TBAMS BIT_(3)
+
+// CTL bits
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TAEN BIT_(0)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TASTALL BIT_(1)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TAEVENT_POS VALUE_(2, 0x0)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TAEVENT_NEG VALUE_(2, 0x1)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TAEVENT_BOTH VALUE_(2, 0x3)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_RTCEN BIT_(4)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TAOTE BIT_(5)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TAPWML BIT_(6)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TBEN BIT_(8)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TBSTALL BIT_(9)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TBEVENT_POS VALUE_(10, 0x0)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TBEVENT_NEG VALUE_(10, 0x1)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TBEVENT_BOTH VALUE_(10, 0x3)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TBOTE BIT_(13)
+#define CYGHWR_HAL_LM3S_GPTIM_CTL_TBPWML BIT_(14)
+
+// IMR bits
+#define CYGHWR_HAL_LM3S_GPTIM_IMR_TATOIM BIT_(0)
+#define CYGHWR_HAL_LM3S_GPTIM_IMR_CAMIM BIT_(1)
+#define CYGHWR_HAL_LM3S_GPTIM_IMR_CAEIM BIT_(2)
+#define CYGHWR_HAL_LM3S_GPTIM_IMR_RTCIM BIT_(3)
+#define CYGHWR_HAL_LM3S_GPTIM_IMR_TBTOIM BIT_(8)
+#define CYGHWR_HAL_LM3S_GPTIM_IMR_CBMIM BIT_(9)
+#define CYGHWR_HAL_LM3S_GPTIM_IMR_CBEIM BIT_(10)
+
+// RIS bits
+#define CYGHWR_HAL_LM3S_GPTIM_RIS_TATORIS BIT_(0)
+#define CYGHWR_HAL_LM3S_GPTIM_RIS_CAMRIS BIT_(1)
+#define CYGHWR_HAL_LM3S_GPTIM_RIS_CAERIS BIT_(2)
+#define CYGHWR_HAL_LM3S_GPTIM_RIS_RTCRIS BIT_(3)
+#define CYGHWR_HAL_LM3S_GPTIM_RIS_TBTORIS BIT_(8)
+#define CYGHWR_HAL_LM3S_GPTIM_RIS_CBMRIS BIT_(9)
+#define CYGHWR_HAL_LM3S_GPTIM_RIS_CBERIS BIT_(10)
+
+// MIS bits
+#define CYGHWR_HAL_LM3S_GPTIM_MIS_TATOMIS BIT_(0)
+#define CYGHWR_HAL_LM3S_GPTIM_MIS_CAMMIS BIT_(1)
+#define CYGHWR_HAL_LM3S_GPTIM_MIS_CAEMIS BIT_(2)
+#define CYGHWR_HAL_LM3S_GPTIM_MIS_RTCMIS BIT_(3)
+#define CYGHWR_HAL_LM3S_GPTIM_MIS_TBTOMIS BIT_(8)
+#define CYGHWR_HAL_LM3S_GPTIM_MIS_CBMMIS BIT_(9)
+#define CYGHWR_HAL_LM3S_GPTIM_MIS_CBEMIS BIT_(10)
+
+// ICR bits
+#define CYGHWR_HAL_LM3S_GPTIM_ICR_TATOCINT BIT_(0)
+#define CYGHWR_HAL_LM3S_GPTIM_ICR_CAMCINT BIT_(1)
+#define CYGHWR_HAL_LM3S_GPTIM_ICR_CAECINT BIT_(2)
+#define CYGHWR_HAL_LM3S_GPTIM_ICR_RTCCINT BIT_(3)
+#define CYGHWR_HAL_LM3S_GPTIM_ICR_TBTOCINT BIT_(8)
+#define CYGHWR_HAL_LM3S_GPTIM_ICR_CBMCINT BIT_(9)
+#define CYGHWR_HAL_LM3S_GPTIM_ICR_CBECINT BIT_(10)
+
+cyg_uint32 hal_lm3s_timer_clock( void );
+
+#ifndef __ASSEMBLER__
+
+__externC cyg_uint32 hal_stellaris_lm3s_timer_clock( CYG_ADDRESS base );
+
+#endif
+
+
+//=============================================================================
+// I2C register definitions.
+
+#ifdef CYGHWR_HAL_LM3S_I2C_CHAN
+
+#define CYGHWR_HAL_LM3S_I2C_MSA 0x000
+#define CYGHWR_HAL_LM3S_I2C_MCS 0x004
+#define CYGHWR_HAL_LM3S_I2C_MDR 0x008
+#define CYGHWR_HAL_LM3S_I2C_MTPR 0x00c
+#define CYGHWR_HAL_LM3S_I2C_MIMR 0x010
+#define CYGHWR_HAL_LM3S_I2C_MRIS 0x014
+#define CYGHWR_HAL_LM3S_I2C_MMIS 0x018
+#define CYGHWR_HAL_LM3S_I2C_MICR 0x01c
+#define CYGHWR_HAL_LM3S_I2C_MCR 0x020
+
+#define CYGHWR_HAL_LM3S_I2C_SOAR 0x000
+#define CYGHWR_HAL_LM3S_I2C_SCSR 0x004
+#define CYGHWR_HAL_LM3S_I2C_SDR 0x008
+#define CYGHWR_HAL_LM3S_I2C_SIMR 0x00c
+#define CYGHWR_HAL_LM3S_I2C_SRIS 0x010
+#define CYGHWR_HAL_LM3S_I2C_SMIS 0x014
+#define CYGHWR_HAL_LM3S_I2C_SICR 0x018
+
+// MSA bits
+#define CYGHWR_HAL_LM3S_I2C_MSA_RS BIT_(0)
+#define CYGHWR_HAL_LM3S_I2C_MSA_SA(__x) VALUE_(1, __x)
+
+// MCS bits
+#define CYGHWR_HAL_LM3S_I2C_MCS_BUSY BIT_(0)
+#define CYGHWR_HAL_LM3S_I2C_MCS_ERR BIT_(1)
+#define CYGHWR_HAL_LM3S_I2C_MCS_ADRACK BIT_(2)
+#define CYGHWR_HAL_LM3S_I2C_MCS_DATACK BIT_(3)
+#define CYGHWR_HAL_LM3S_I2C_MCS_ARBLST BIT_(4)
+#define CYGHWR_HAL_LM3S_I2C_MCS_IDLE BIT_(5)
+#define CYGHWR_HAL_LM3S_I2C_MCS_BUSBSY BIT_(6)
+
+#define CYGHWR_HAL_LM3S_I2C_MCS_RUN BIT_(0)
+#define CYGHWR_HAL_LM3S_I2C_MCS_START BIT_(1)
+#define CYGHWR_HAL_LM3S_I2C_MCS_STOP BIT_(2)
+#define CYGHWR_HAL_LM3S_I2C_MCS_ACK BIT_(3)
+
+// MIMR bits
+#define CYGHWR_HAL_LM3S_I2C_MIMR_IM BIT_(0)
+
+// MRIS bits
+#define CYGHWR_HAL_LM3S_I2C_MRIS_RIS BIT_(0)
+
+// MMIS bits
+#define CYGHWR_HAL_LM3S_I2C_MMIS_MIS BIT_(0)
+
+// MICR bits
+#define CYGHWR_HAL_LM3S_I2C_MICR_IC BIT_(0)
+
+// MCR bits
+#define CYGHWR_HAL_LM3S_I2C_MCR_LPBK BIT_(0)
+#define CYGHWR_HAL_LM3S_I2C_MCR_MFE BIT_(4)
+#define CYGHWR_HAL_LM3S_I2C_MCR_SFE BIT_(5)
+
+// SCSR bits
+#define CYGHWR_HAL_LM3S_I2C_SCSR_READ_RREQ BIT_(0)
+#define CYGHWR_HAL_LM3S_I2C_SCSR_READ_TREQ BIT_(1)
+#define CYGHWR_HAL_LM3S_I2C_SCSR_READ_FBR BIT_(2)
+
+#define CYGHWR_HAL_LM3S_I2C_SCSR_WRITE_DA BIT_(0)
+
+// SIMR bits
+#define CYGHWR_HAL_LM3S_I2C_SIMR_DATAIM BIT_(0)
+
+// SRIS bits
+#define CYGHWR_HAL_LM3S_I2C_SRIS_DATARIS BIT_(0)
+
+// SMIS bits
+#define CYGHWR_HAL_LM3S_I2C_SMIS_DATAMIS BIT_(0)
+
+// SICR bits
+#define CYGHWR_HAL_LM3S_I2C_SICR_DATAMIC BIT_(0)
+
+__externC cyg_uint32 hal_lm3s_i2c_clock( void );
+
+#endif // CYGHWR_HAL_LM3S_I2C_CHAN
+
+
+//=============================================================================
+// AC register definitions.
+
+#ifdef CYGHWR_HAL_LM3S_AC_CHAN
+
+#define CYGHWR_HAL_LM3S_AC_MIS 0x000
+#define CYGHWR_HAL_LM3S_AC_RIS 0x004
+#define CYGHWR_HAL_LM3S_AC_INTEN 0x008
+#define CYGHWR_HAL_LM3S_AC_REFCTL 0x010
+#define CYGHWR_HAL_LM3S_AC_STAT0 0x020
+#define CYGHWR_HAL_LM3S_AC_CTL0 0x024
+#define CYGHWR_HAL_LM3S_AC_STAT1 0x040
+#define CYGHWR_HAL_LM3S_AC_CTL1 0x044
+#define CYGHWR_HAL_LM3S_AC_STAT2 0x060
+#define CYGHWR_HAL_LM3S_AC_CTL2 0x064
+
+// MIS bits
+#define CYGHWR_HAL_LM3S_AC_MIS_IN0 BIT_(0)
+#define CYGHWR_HAL_LM3S_AC_MIS_IN1 BIT_(1)
+#define CYGHWR_HAL_LM3S_AC_MIS_IN2 BIT_(2)
+
+// RIS bits
+#define CYGHWR_HAL_LM3S_AC_RIS_IN0 BIT_(0)
+#define CYGHWR_HAL_LM3S_AC_RIS_IN1 BIT_(1)
+#define CYGHWR_HAL_LM3S_AC_RIS_IN2 BIT_(2)
+
+// INTEN bits
+#define CYGHWR_HAL_LM3S_AC_INTEN_IN0 BIT_(0)
+#define CYGHWR_HAL_LM3S_AC_INTEN_IN1 BIT_(1)
+#define CYGHWR_HAL_LM3S_AC_INTEN_IN2 BIT_(2)
+
+// REFCTL bits
+#define CYGHWR_HAL_LM3S_AC_REFCTL_RNG BIT_(8)
+#define CYGHWR_HAL_LM3S_AC_REFCTL_EN BIT_(9)
+
+// STAT0, STAT1 and STAT2 bits
+#define CYGHWR_HAL_LM3S_AC_STATx_OVAL BIT_(1)
+
+// CTL0, CTL1 anf CTL2 bits
+#define CYGHWR_HAL_LM3S_AC_CTLx_CINV BIT_(1)
+#define CYGHWR_HAL_LM3S_AC_CTLx_ISEN_LEV_SENSE VALUE_(2, 0x0)
+#define CYGHWR_HAL_LM3S_AC_CTLx_ISEN_FALL_EDGE VALUE_(2, 0x1)
+#define CYGHWR_HAL_LM3S_AC_CTLx_ISEN_RISE_EDGE VALUE_(2, 0x2)
+#define CYGHWR_HAL_LM3S_AC_CTLx_ISEN_BOTH_EDGE VALUE_(2, 0x3)
+#define CYGHWR_HAL_LM3S_AC_CTLx_ISLVAL BIT_(4)
+#define CYGHWR_HAL_LM3S_AC_CTLx_ASRCP_PIN_VAL VALUE_(9, 0x0)
+#define CYGHWR_HAL_LM3S_AC_CTLx_ASRCP_PIN_VAL_C0 VALUE_(9, 0x1)
+#define CYGHWR_HAL_LM3S_AC_CTLx_ASRCP_IVOLTREF VALUE_(9, 0x2)
+
+#endif // CYGHWR_HAL_LM3S_AC_CHAN
+
+
+//=============================================================================
+// QEI register definitions.
+
+#ifdef CYGHWR_HAL_LM3S_QEI_CHAN
+
+#define CYGHWR_HAL_LM3S_QEI_CTL 0x000
+#define CYGHWR_HAL_LM3S_QEI_STAT 0x004
+#define CYGHWR_HAL_LM3S_QEI_POS 0x008
+#define CYGHWR_HAL_LM3S_QEI_MAXPOS 0x00c
+#define CYGHWR_HAL_LM3S_QEI_LOAD 0x010
+#define CYGHWR_HAL_LM3S_QEI_TIME 0x014
+#define CYGHWR_HAL_LM3S_QEI_COUNT 0x018
+#define CYGHWR_HAL_LM3S_QEI_SPEED 0x01c
+#define CYGHWR_HAL_LM3S_QEI_INTEN 0x020
+#define CYGHWR_HAL_LM3S_QEI_RIS 0x024
+#define CYGHWR_HAL_LM3S_QEI_ISC 0x028
+
+// CTL bits
+#define CYGHWR_HAL_LM3S_QEI_CTL_EN BIT_(0)
+#define CYGHWR_HAL_LM3S_QEI_CTL_SWAP BIT_(1)
+#define CYGHWR_HAL_LM3S_QEI_CTL_SIGMODE BIT_(2)
+#define CYGHWR_HAL_LM3S_QEI_CTL_CAPMODE BIT_(3)
+#define CYGHWR_HAL_LM3S_QEI_CTL_RESMODE BIT_(4)
+#define CYGHWR_HAL_LM3S_QEI_CTL_VELEN BIT_(5)
+#define CYGHWR_HAL_LM3S_QEI_CTL_VELDIV_1 VALUE_(6, 0x0)
+#define CYGHWR_HAL_LM3S_QEI_CTL_VELDIV_2 VALUE_(6, 0x1)
+#define CYGHWR_HAL_LM3S_QEI_CTL_VELDIV_4 VALUE_(6, 0x2)
+#define CYGHWR_HAL_LM3S_QEI_CTL_VELDIV_8 VALUE_(6, 0x3)
+#define CYGHWR_HAL_LM3S_QEI_CTL_VELDIV_16 VALUE_(6, 0x4)
+#define CYGHWR_HAL_LM3S_QEI_CTL_VELDIV_32 VALUE_(6, 0x5)
+#define CYGHWR_HAL_LM3S_QEI_CTL_VELDIV_64 VALUE_(6, 0x6)
+#define CYGHWR_HAL_LM3S_QEI_CTL_VELDIV_128 VALUE_(6, 0x7)
+#define CYGHWR_HAL_LM3S_QEI_CTL_INVA BIT_(9)
+#define CYGHWR_HAL_LM3S_QEI_CTL_INVB BIT_(10)
+#define CYGHWR_HAL_LM3S_QEI_CTL_INVI BIT_(11)
+#define CYGHWR_HAL_LM3S_QEI_CTL_SATLLEN BIT_(12)
+
+// STAT bits
+#define CYGHWR_HAL_LM3S_QEI_STAT_ERR BIT_(0)
+#define CYGHWR_HAL_LM3S_QEI_STAT_DIR BIT_(1)
+
+// INTEN bits
+#define CYGHWR_HAL_LM3S_QEI_INTEN_INTINDEX BIT_(0)
+#define CYGHWR_HAL_LM3S_QEI_INTEN_INTTIMER BIT_(1)
+#define CYGHWR_HAL_LM3S_QEI_INTEN_INTDIR BIT_(2)
+#define CYGHWR_HAL_LM3S_QEI_INTEN_INTERROR BIT_(3)
+
+// RIS bits
+#define CYGHWR_HAL_LM3S_QEI_RIS_INTINDEX BIT_(0)
+#define CYGHWR_HAL_LM3S_QEI_RIS_INTTIMER BIT_(1)
+#define CYGHWR_HAL_LM3S_QEI_RIS_INTDIR BIT_(2)
+#define CYGHWR_HAL_LM3S_QEI_RIS_INTERROR BIT_(3)
+
+// ISC bits
+#define CYGHWR_HAL_LM3S_QEI_ISC_INTINDEX BIT_(0)
+#define CYGHWR_HAL_LM3S_QEI_ISC_INTTIMER BIT_(1)
+#define CYGHWR_HAL_LM3S_QEI_ISC_INTDIR BIT_(2)
+#define CYGHWR_HAL_LM3S_QEI_ISC_INTERROR BIT_(3)
+
+#endif // CYGHWR_HAL_LM3S_QEI_CHAN
+
+
+//=============================================================================
+// Flash controller
+
+#define CYGHWR_HAL_LM3S_FMC_FMA 0x000
+#define CYGHWR_HAL_LM3S_FMC_FMD 0x004
+#define CYGHWR_HAL_LM3S_FMC_FMC 0x008
+#define CYGHWR_HAL_LM3S_FMC_FCRIS 0x00c
+#define CYGHWR_HAL_LM3S_FMC_FCIM 0x010
+#define CYGHWR_HAL_LM3S_FMC_FCMISC 0x014
+
+// Key value
+#define CYGHWR_HAL_LM3S_FMC_WRKEY 0xA4420000
+
+// FMC bits
+#define CYGHWR_HAL_LM3S_FMC_FMC_WRITE BIT_(0)
+#define CYGHWR_HAL_LM3S_FMC_FMC_ERASE BIT_(1)
+#define CYGHWR_HAL_LM3S_FMC_FMC_MERASE BIT_(2)
+#define CYGHWR_HAL_LM3S_FMC_FMC_COMT BIT_(3)
+
+// RIS bits
+#define CYGHWR_HAL_LM3S_FMC_FCRIS_ARIS BIT_(0)
+#define CYGHWR_HAL_LM3S_FMC_FCRIS_PRIS BIT_(1)
+
+// IM bits
+#define CYGHWR_HAL_LM3S_FMC_FCIM_AMASK BIT_(0)
+#define CYGHWR_HAL_LM3S_FMC_FCIM_PMASK BIT_(1)
+
+// MISC bits
+#define CYGHWR_HAL_LM3S_FMC_FCMISC_AMASK BIT_(0)
+#define CYGHWR_HAL_LM3S_FMC_FCMISC_PMASK BIT_(0)
+
+
+//-----------------------------------------------------------------------------
+#endif // CYGONCE_HAL_VAR_IO_H
+// EOF of var_io.h
diff --git a/ecos/packages/hal/cortexm/lm3s/var/current/include/variant.inc b/ecos/packages/hal/cortexm/lm3s/var/current/include/variant.inc
new file mode 100644
index 0000000..415ebf5
--- /dev/null
+++ b/ecos/packages/hal/cortexm/lm3s/var/current/include/variant.inc
@@ -0,0 +1,54 @@
+/*==========================================================================
+//
+// variant.inc
+//
+// Variant specific asm definitions
+//
+//==========================================================================
+// ####ECOSGPLCOPYRIGHTBEGIN####
+// -------------------------------------------
+// This file is part of eCos, the Embedded Configurable Operating System.
+// Copyright (C) 2010 Free Software Foundation, Inc.
+//
+// eCos is free software; you can redistribute it and/or modify it under
+// the terms of the GNU General Public License as published by the Free
+// Software Foundation; either version 2 or (at your option) any later
+// version.
+//
+// eCos is distributed in the hope that it will be useful, but WITHOUT
+// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+// for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with eCos; if not, write to the Free Software Foundation, Inc.,
+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+//
+// As a special exception, if other files instantiate templates or use
+// macros or inline functions from this file, or you compile this file
+// and link it with other works to produce a work based on this file,
+// this file does not by itself cause the resulting work to be covered by
+// the GNU General Public License. However the source code for this file
+// must still be made available in accordance with section (3) of the GNU
+// General Public License v2.
+//
+// This exception does not invalidate any other reasons why a work based
+// on this file might be covered by the GNU General Public License.
+// -------------------------------------------
+// ####ECOSGPLCOPYRIGHTEND####
+//==========================================================================
+//#####DESCRIPTIONBEGIN####
+//
+// Author(s): ccoutand
+// Date: 2010-11-23
+// Description:
+//
+//####DESCRIPTIONEND####
+//
+//========================================================================*/
+
+#include <pkgconf/hal_cortexm_lm3s.h>
+
+//==========================================================================
+// EOF variant.inc
+