/* system.h
 *
 * Machine generated for a CPU named "cpu" as defined in:
 * /home/user2/fall11/ar2648/CSEE_4840/Synth/uart_sopc_sys/nios_system.ptf
 *
 * Generated: 2012-05-09 22:30:38.802
 *
 */

#ifndef __SYSTEM_H_
#define __SYSTEM_H_

/*

DO NOT MODIFY THIS FILE

   Changing this file will have subtle consequences
   which will almost certainly lead to a nonfunctioning
   system. If you do modify this file, be aware that your
   changes will be overwritten and lost when this file
   is generated again.

DO NOT MODIFY THIS FILE

*/

/******************************************************************************
*                                                                             *
* License Agreement                                                           *
*                                                                             *
* Copyright (c) 2003 Altera Corporation, San Jose, California, USA.           *
* All rights reserved.                                                        *
*                                                                             *
* Permission is hereby granted, free of charge, to any person obtaining a     *
* copy of this software and associated documentation files (the "Software"),  *
* to deal in the Software without restriction, including without limitation   *
* the rights to use, copy, modify, merge, publish, distribute, sublicense,    *
* and/or sell copies of the Software, and to permit persons to whom the       *
* Software is furnished to do so, subject to the following conditions:        *
*                                                                             *
* The above copyright notice and this permission notice shall be included in  *
* all copies or substantial portions of the Software.                         *
*                                                                             *
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR  *
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,    *
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER      *
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING     *
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER         *
* DEALINGS IN THE SOFTWARE.                                                   *
*                                                                             *
* This agreement shall be governed in all respects by the laws of the State   *
* of California and by the laws of the United States of America.              *
*                                                                             *
******************************************************************************/

/*
 * system configuration
 *
 */

#define ALT_SYSTEM_NAME "nios_system"
#define ALT_CPU_NAME "cpu"
#define ALT_CPU_ARCHITECTURE "altera_nios2"
#define ALT_DEVICE_FAMILY "CYCLONEII"
#define ALT_STDIN "/dev/jtag_uart"
#define ALT_STDIN_TYPE "altera_avalon_jtag_uart"
#define ALT_STDIN_BASE 0x00101070
#define ALT_STDIN_DEV jtag_uart
#define ALT_STDIN_PRESENT
#define ALT_STDOUT "/dev/jtag_uart"
#define ALT_STDOUT_TYPE "altera_avalon_jtag_uart"
#define ALT_STDOUT_BASE 0x00101070
#define ALT_STDOUT_DEV jtag_uart
#define ALT_STDOUT_PRESENT
#define ALT_STDERR "/dev/jtag_uart"
#define ALT_STDERR_TYPE "altera_avalon_jtag_uart"
#define ALT_STDERR_BASE 0x00101070
#define ALT_STDERR_DEV jtag_uart
#define ALT_STDERR_PRESENT
#define ALT_CPU_FREQ 50000000
#define ALT_IRQ_BASE NULL

/*
 * processor configuration
 *
 */

#define NIOS2_CPU_IMPLEMENTATION "fast"
#define NIOS2_BIG_ENDIAN 0

#define NIOS2_ICACHE_SIZE 4096
#define NIOS2_DCACHE_SIZE 2048
#define NIOS2_ICACHE_LINE_SIZE 32
#define NIOS2_ICACHE_LINE_SIZE_LOG2 5
#define NIOS2_DCACHE_LINE_SIZE 32
#define NIOS2_DCACHE_LINE_SIZE_LOG2 5
#define NIOS2_FLUSHDA_SUPPORTED

#define NIOS2_EXCEPTION_ADDR 0x00080020
#define NIOS2_RESET_ADDR 0x00080000
#define NIOS2_BREAK_ADDR 0x00100820

#define NIOS2_HAS_DEBUG_STUB

#define NIOS2_CPU_ID_SIZE 1
#define NIOS2_CPU_ID_VALUE 0

/*
 * A define for each class of peripheral
 *
 */

#define __ALTERA_AVALON_JTAG_UART
#define __SRAM_CONTROLLER
#define __ALTERA_AVALON_PIO

/*
 * jtag_uart configuration
 *
 */

#define JTAG_UART_NAME "/dev/jtag_uart"
#define JTAG_UART_TYPE "altera_avalon_jtag_uart"
#define JTAG_UART_BASE 0x00101070
#define JTAG_UART_SPAN 8
#define JTAG_UART_IRQ 0
#define JTAG_UART_WRITE_DEPTH 64
#define JTAG_UART_READ_DEPTH 64
#define JTAG_UART_WRITE_THRESHOLD 8
#define JTAG_UART_READ_THRESHOLD 8
#define JTAG_UART_READ_CHAR_STREAM ""
#define JTAG_UART_SHOWASCII 1
#define JTAG_UART_READ_LE 0
#define JTAG_UART_WRITE_LE 0
#define JTAG_UART_ALTERA_SHOW_UNRELEASED_JTAG_UART_FEATURES 0
#define ALT_MODULE_CLASS_jtag_uart altera_avalon_jtag_uart

/*
 * sram configuration
 *
 */

#define SRAM_NAME "/dev/sram"
#define SRAM_TYPE "sram_controller"
#define SRAM_BASE 0x00080000
#define SRAM_SPAN 524288
#define ALT_MODULE_CLASS_sram sram_controller

/*
 * data_pio configuration
 *
 */

#define DATA_PIO_NAME "/dev/data_pio"
#define DATA_PIO_TYPE "altera_avalon_pio"
#define DATA_PIO_BASE 0x00101000
#define DATA_PIO_SPAN 16
#define DATA_PIO_DO_TEST_BENCH_WIRING 0
#define DATA_PIO_DRIVEN_SIM_VALUE 0
#define DATA_PIO_HAS_TRI 0
#define DATA_PIO_HAS_OUT 0
#define DATA_PIO_HAS_IN 1
#define DATA_PIO_CAPTURE 0
#define DATA_PIO_DATA_WIDTH 8
#define DATA_PIO_EDGE_TYPE "NONE"
#define DATA_PIO_IRQ_TYPE "NONE"
#define DATA_PIO_BIT_CLEARING_EDGE_REGISTER 0
#define DATA_PIO_FREQ 50000000
#define ALT_MODULE_CLASS_data_pio altera_avalon_pio

/*
 * status_pio configuration
 *
 */

#define STATUS_PIO_NAME "/dev/status_pio"
#define STATUS_PIO_TYPE "altera_avalon_pio"
#define STATUS_PIO_BASE 0x00101010
#define STATUS_PIO_SPAN 16
#define STATUS_PIO_DO_TEST_BENCH_WIRING 0
#define STATUS_PIO_DRIVEN_SIM_VALUE 0
#define STATUS_PIO_HAS_TRI 0
#define STATUS_PIO_HAS_OUT 1
#define STATUS_PIO_HAS_IN 1
#define STATUS_PIO_CAPTURE 0
#define STATUS_PIO_DATA_WIDTH 8
#define STATUS_PIO_EDGE_TYPE "NONE"
#define STATUS_PIO_IRQ_TYPE "NONE"
#define STATUS_PIO_BIT_CLEARING_EDGE_REGISTER 0
#define STATUS_PIO_FREQ 50000000
#define ALT_MODULE_CLASS_status_pio altera_avalon_pio

/*
 * note_1_pio configuration
 *
 */

#define NOTE_1_PIO_NAME "/dev/note_1_pio"
#define NOTE_1_PIO_TYPE "altera_avalon_pio"
#define NOTE_1_PIO_BASE 0x00101020
#define NOTE_1_PIO_SPAN 16
#define NOTE_1_PIO_DO_TEST_BENCH_WIRING 0
#define NOTE_1_PIO_DRIVEN_SIM_VALUE 0
#define NOTE_1_PIO_HAS_TRI 0
#define NOTE_1_PIO_HAS_OUT 1
#define NOTE_1_PIO_HAS_IN 0
#define NOTE_1_PIO_CAPTURE 0
#define NOTE_1_PIO_DATA_WIDTH 16
#define NOTE_1_PIO_EDGE_TYPE "NONE"
#define NOTE_1_PIO_IRQ_TYPE "NONE"
#define NOTE_1_PIO_BIT_CLEARING_EDGE_REGISTER 0
#define NOTE_1_PIO_FREQ 50000000
#define ALT_MODULE_CLASS_note_1_pio altera_avalon_pio

/*
 * note_2_pio configuration
 *
 */

#define NOTE_2_PIO_NAME "/dev/note_2_pio"
#define NOTE_2_PIO_TYPE "altera_avalon_pio"
#define NOTE_2_PIO_BASE 0x00101030
#define NOTE_2_PIO_SPAN 16
#define NOTE_2_PIO_DO_TEST_BENCH_WIRING 0
#define NOTE_2_PIO_DRIVEN_SIM_VALUE 0
#define NOTE_2_PIO_HAS_TRI 0
#define NOTE_2_PIO_HAS_OUT 1
#define NOTE_2_PIO_HAS_IN 0
#define NOTE_2_PIO_CAPTURE 0
#define NOTE_2_PIO_DATA_WIDTH 16
#define NOTE_2_PIO_EDGE_TYPE "NONE"
#define NOTE_2_PIO_IRQ_TYPE "NONE"
#define NOTE_2_PIO_BIT_CLEARING_EDGE_REGISTER 0
#define NOTE_2_PIO_FREQ 50000000
#define ALT_MODULE_CLASS_note_2_pio altera_avalon_pio

/*
 * note_3_pio configuration
 *
 */

#define NOTE_3_PIO_NAME "/dev/note_3_pio"
#define NOTE_3_PIO_TYPE "altera_avalon_pio"
#define NOTE_3_PIO_BASE 0x00101040
#define NOTE_3_PIO_SPAN 16
#define NOTE_3_PIO_DO_TEST_BENCH_WIRING 0
#define NOTE_3_PIO_DRIVEN_SIM_VALUE 0
#define NOTE_3_PIO_HAS_TRI 0
#define NOTE_3_PIO_HAS_OUT 1
#define NOTE_3_PIO_HAS_IN 0
#define NOTE_3_PIO_CAPTURE 0
#define NOTE_3_PIO_DATA_WIDTH 16
#define NOTE_3_PIO_EDGE_TYPE "NONE"
#define NOTE_3_PIO_IRQ_TYPE "NONE"
#define NOTE_3_PIO_BIT_CLEARING_EDGE_REGISTER 0
#define NOTE_3_PIO_FREQ 50000000
#define ALT_MODULE_CLASS_note_3_pio altera_avalon_pio

/*
 * note_4_pio configuration
 *
 */

#define NOTE_4_PIO_NAME "/dev/note_4_pio"
#define NOTE_4_PIO_TYPE "altera_avalon_pio"
#define NOTE_4_PIO_BASE 0x00101050
#define NOTE_4_PIO_SPAN 16
#define NOTE_4_PIO_DO_TEST_BENCH_WIRING 0
#define NOTE_4_PIO_DRIVEN_SIM_VALUE 0
#define NOTE_4_PIO_HAS_TRI 0
#define NOTE_4_PIO_HAS_OUT 1
#define NOTE_4_PIO_HAS_IN 0
#define NOTE_4_PIO_CAPTURE 0
#define NOTE_4_PIO_DATA_WIDTH 16
#define NOTE_4_PIO_EDGE_TYPE "NONE"
#define NOTE_4_PIO_IRQ_TYPE "NONE"
#define NOTE_4_PIO_BIT_CLEARING_EDGE_REGISTER 0
#define NOTE_4_PIO_FREQ 50000000
#define ALT_MODULE_CLASS_note_4_pio altera_avalon_pio

/*
 * note_5_pio configuration
 *
 */

#define NOTE_5_PIO_NAME "/dev/note_5_pio"
#define NOTE_5_PIO_TYPE "altera_avalon_pio"
#define NOTE_5_PIO_BASE 0x00101060
#define NOTE_5_PIO_SPAN 16
#define NOTE_5_PIO_DO_TEST_BENCH_WIRING 0
#define NOTE_5_PIO_DRIVEN_SIM_VALUE 0
#define NOTE_5_PIO_HAS_TRI 0
#define NOTE_5_PIO_HAS_OUT 1
#define NOTE_5_PIO_HAS_IN 0
#define NOTE_5_PIO_CAPTURE 0
#define NOTE_5_PIO_DATA_WIDTH 16
#define NOTE_5_PIO_EDGE_TYPE "NONE"
#define NOTE_5_PIO_IRQ_TYPE "NONE"
#define NOTE_5_PIO_BIT_CLEARING_EDGE_REGISTER 0
#define NOTE_5_PIO_FREQ 50000000
#define ALT_MODULE_CLASS_note_5_pio altera_avalon_pio

/*
 * system library configuration
 *
 */

#define ALT_MAX_FD 4
#define ALT_SYS_CLK none
#define ALT_TIMESTAMP_CLK none

/*
 * Devices associated with code sections.
 *
 */

#define ALT_TEXT_DEVICE       SRAM
#define ALT_RODATA_DEVICE     SRAM
#define ALT_RWDATA_DEVICE     SRAM
#define ALT_EXCEPTIONS_DEVICE SRAM
#define ALT_RESET_DEVICE      SRAM

/*
 * The text section is initialised so no bootloader will be required.
 * Set a variable to tell crt0.S to provide code at the reset address and
 * to initialise rwdata if appropriate.
 */

#define ALT_NO_BOOTLOADER


#endif /* __SYSTEM_H_ */
