2022-10-19 15:03:52 +03:00
|
|
|
/*
|
|
|
|
* system.h - SOPC Builder system and BSP software package information
|
|
|
|
*
|
|
|
|
* Machine generated for CPU 'cpu' in SOPC Builder design 'niosII'
|
|
|
|
* SOPC Builder design path: ../../niosII.sopcinfo
|
|
|
|
*
|
2022-12-22 22:27:05 +03:00
|
|
|
* Generated: Thu Dec 22 22:44:18 MSK 2022
|
2022-10-19 15:03:52 +03:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* 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) 2008
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __SYSTEM_H_
|
|
|
|
#define __SYSTEM_H_
|
|
|
|
|
|
|
|
/* Include definitions from linker script generator */
|
|
|
|
#include "linker.h"
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* CPU configuration
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define ALT_CPU_ARCHITECTURE "altera_nios2_gen2"
|
|
|
|
#define ALT_CPU_BIG_ENDIAN 0
|
|
|
|
#define ALT_CPU_BREAK_ADDR 0x00020820
|
|
|
|
#define ALT_CPU_CPU_ARCH_NIOS2_R1
|
|
|
|
#define ALT_CPU_CPU_FREQ 50000000u
|
|
|
|
#define ALT_CPU_CPU_ID_SIZE 1
|
|
|
|
#define ALT_CPU_CPU_ID_VALUE 0x00000000
|
|
|
|
#define ALT_CPU_CPU_IMPLEMENTATION "tiny"
|
|
|
|
#define ALT_CPU_DATA_ADDR_WIDTH 0x12
|
|
|
|
#define ALT_CPU_DCACHE_LINE_SIZE 0
|
|
|
|
#define ALT_CPU_DCACHE_LINE_SIZE_LOG2 0
|
|
|
|
#define ALT_CPU_DCACHE_SIZE 0
|
|
|
|
#define ALT_CPU_EXCEPTION_ADDR 0x00000020
|
|
|
|
#define ALT_CPU_FLASH_ACCELERATOR_LINES 0
|
|
|
|
#define ALT_CPU_FLASH_ACCELERATOR_LINE_SIZE 0
|
|
|
|
#define ALT_CPU_FLUSHDA_SUPPORTED
|
|
|
|
#define ALT_CPU_FREQ 50000000
|
|
|
|
#define ALT_CPU_HARDWARE_DIVIDE_PRESENT 0
|
|
|
|
#define ALT_CPU_HARDWARE_MULTIPLY_PRESENT 0
|
|
|
|
#define ALT_CPU_HARDWARE_MULX_PRESENT 0
|
|
|
|
#define ALT_CPU_HAS_DEBUG_CORE 1
|
|
|
|
#define ALT_CPU_HAS_DEBUG_STUB
|
|
|
|
#define ALT_CPU_HAS_ILLEGAL_INSTRUCTION_EXCEPTION
|
|
|
|
#define ALT_CPU_HAS_JMPI_INSTRUCTION
|
|
|
|
#define ALT_CPU_ICACHE_LINE_SIZE 0
|
|
|
|
#define ALT_CPU_ICACHE_LINE_SIZE_LOG2 0
|
|
|
|
#define ALT_CPU_ICACHE_SIZE 0
|
|
|
|
#define ALT_CPU_INST_ADDR_WIDTH 0x12
|
|
|
|
#define ALT_CPU_NAME "cpu"
|
|
|
|
#define ALT_CPU_OCI_VERSION 1
|
|
|
|
#define ALT_CPU_RESET_ADDR 0x00000000
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* CPU configuration (with legacy prefix - don't use these anymore)
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define NIOS2_BIG_ENDIAN 0
|
|
|
|
#define NIOS2_BREAK_ADDR 0x00020820
|
|
|
|
#define NIOS2_CPU_ARCH_NIOS2_R1
|
|
|
|
#define NIOS2_CPU_FREQ 50000000u
|
|
|
|
#define NIOS2_CPU_ID_SIZE 1
|
|
|
|
#define NIOS2_CPU_ID_VALUE 0x00000000
|
|
|
|
#define NIOS2_CPU_IMPLEMENTATION "tiny"
|
|
|
|
#define NIOS2_DATA_ADDR_WIDTH 0x12
|
|
|
|
#define NIOS2_DCACHE_LINE_SIZE 0
|
|
|
|
#define NIOS2_DCACHE_LINE_SIZE_LOG2 0
|
|
|
|
#define NIOS2_DCACHE_SIZE 0
|
|
|
|
#define NIOS2_EXCEPTION_ADDR 0x00000020
|
|
|
|
#define NIOS2_FLASH_ACCELERATOR_LINES 0
|
|
|
|
#define NIOS2_FLASH_ACCELERATOR_LINE_SIZE 0
|
|
|
|
#define NIOS2_FLUSHDA_SUPPORTED
|
|
|
|
#define NIOS2_HARDWARE_DIVIDE_PRESENT 0
|
|
|
|
#define NIOS2_HARDWARE_MULTIPLY_PRESENT 0
|
|
|
|
#define NIOS2_HARDWARE_MULX_PRESENT 0
|
|
|
|
#define NIOS2_HAS_DEBUG_CORE 1
|
|
|
|
#define NIOS2_HAS_DEBUG_STUB
|
|
|
|
#define NIOS2_HAS_ILLEGAL_INSTRUCTION_EXCEPTION
|
|
|
|
#define NIOS2_HAS_JMPI_INSTRUCTION
|
|
|
|
#define NIOS2_ICACHE_LINE_SIZE 0
|
|
|
|
#define NIOS2_ICACHE_LINE_SIZE_LOG2 0
|
|
|
|
#define NIOS2_ICACHE_SIZE 0
|
|
|
|
#define NIOS2_INST_ADDR_WIDTH 0x12
|
|
|
|
#define NIOS2_OCI_VERSION 1
|
|
|
|
#define NIOS2_RESET_ADDR 0x00000000
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Define for each module class mastered by the CPU
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define __ALTERA_AVALON_JTAG_UART
|
|
|
|
#define __ALTERA_AVALON_ONCHIP_MEMORY2
|
|
|
|
#define __ALTERA_AVALON_TIMER
|
|
|
|
#define __ALTERA_NIOS2_GEN2
|
2022-10-24 22:35:24 +03:00
|
|
|
#define __SEM
|
2022-10-19 15:03:52 +03:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* System configuration
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define ALT_DEVICE_FAMILY "Cyclone IV E"
|
|
|
|
#define ALT_ENHANCED_INTERRUPT_API_PRESENT
|
|
|
|
#define ALT_IRQ_BASE NULL
|
|
|
|
#define ALT_LOG_PORT "/dev/null"
|
|
|
|
#define ALT_LOG_PORT_BASE 0x0
|
|
|
|
#define ALT_LOG_PORT_DEV null
|
|
|
|
#define ALT_LOG_PORT_TYPE ""
|
|
|
|
#define ALT_NUM_EXTERNAL_INTERRUPT_CONTROLLERS 0
|
|
|
|
#define ALT_NUM_INTERNAL_INTERRUPT_CONTROLLERS 1
|
|
|
|
#define ALT_NUM_INTERRUPT_CONTROLLERS 1
|
|
|
|
#define ALT_STDERR "/dev/jtag_uart"
|
2022-12-22 22:27:05 +03:00
|
|
|
#define ALT_STDERR_BASE 0x21068
|
2022-10-19 15:03:52 +03:00
|
|
|
#define ALT_STDERR_DEV jtag_uart
|
|
|
|
#define ALT_STDERR_IS_JTAG_UART
|
|
|
|
#define ALT_STDERR_PRESENT
|
|
|
|
#define ALT_STDERR_TYPE "altera_avalon_jtag_uart"
|
|
|
|
#define ALT_STDIN "/dev/jtag_uart"
|
2022-12-22 22:27:05 +03:00
|
|
|
#define ALT_STDIN_BASE 0x21068
|
2022-10-19 15:03:52 +03:00
|
|
|
#define ALT_STDIN_DEV jtag_uart
|
|
|
|
#define ALT_STDIN_IS_JTAG_UART
|
|
|
|
#define ALT_STDIN_PRESENT
|
|
|
|
#define ALT_STDIN_TYPE "altera_avalon_jtag_uart"
|
|
|
|
#define ALT_STDOUT "/dev/jtag_uart"
|
2022-12-22 22:27:05 +03:00
|
|
|
#define ALT_STDOUT_BASE 0x21068
|
2022-10-19 15:03:52 +03:00
|
|
|
#define ALT_STDOUT_DEV jtag_uart
|
|
|
|
#define ALT_STDOUT_IS_JTAG_UART
|
|
|
|
#define ALT_STDOUT_PRESENT
|
|
|
|
#define ALT_STDOUT_TYPE "altera_avalon_jtag_uart"
|
|
|
|
#define ALT_SYSTEM_NAME "niosII"
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* hal configuration
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define ALT_INCLUDE_INSTRUCTION_RELATED_EXCEPTION_API
|
|
|
|
#define ALT_MAX_FD 32
|
|
|
|
#define ALT_SYS_CLK SYS_CLK_TIMER
|
|
|
|
#define ALT_TIMESTAMP_CLK none
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* jtag_uart configuration
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define ALT_MODULE_CLASS_jtag_uart altera_avalon_jtag_uart
|
2022-12-22 22:27:05 +03:00
|
|
|
#define JTAG_UART_BASE 0x21068
|
2022-10-19 15:03:52 +03:00
|
|
|
#define JTAG_UART_IRQ 1
|
|
|
|
#define JTAG_UART_IRQ_INTERRUPT_CONTROLLER_ID 0
|
|
|
|
#define JTAG_UART_NAME "/dev/jtag_uart"
|
|
|
|
#define JTAG_UART_READ_DEPTH 64
|
|
|
|
#define JTAG_UART_READ_THRESHOLD 8
|
|
|
|
#define JTAG_UART_SPAN 8
|
|
|
|
#define JTAG_UART_TYPE "altera_avalon_jtag_uart"
|
|
|
|
#define JTAG_UART_WRITE_DEPTH 64
|
|
|
|
#define JTAG_UART_WRITE_THRESHOLD 8
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* mem configuration
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define ALT_MODULE_CLASS_mem altera_avalon_onchip_memory2
|
|
|
|
#define MEM_ALLOW_IN_SYSTEM_MEMORY_CONTENT_EDITOR 0
|
|
|
|
#define MEM_ALLOW_MRAM_SIM_CONTENTS_ONLY_FILE 0
|
|
|
|
#define MEM_BASE 0x0
|
|
|
|
#define MEM_CONTENTS_INFO ""
|
|
|
|
#define MEM_DUAL_PORT 1
|
|
|
|
#define MEM_GUI_RAM_BLOCK_TYPE "AUTO"
|
|
|
|
#define MEM_INIT_CONTENTS_FILE "niosII_mem"
|
|
|
|
#define MEM_INIT_MEM_CONTENT 1
|
|
|
|
#define MEM_INSTANCE_ID "NONE"
|
|
|
|
#define MEM_IRQ -1
|
|
|
|
#define MEM_IRQ_INTERRUPT_CONTROLLER_ID -1
|
|
|
|
#define MEM_NAME "/dev/mem"
|
|
|
|
#define MEM_NON_DEFAULT_INIT_FILE_ENABLED 0
|
|
|
|
#define MEM_RAM_BLOCK_TYPE "AUTO"
|
|
|
|
#define MEM_READ_DURING_WRITE_MODE "DONT_CARE"
|
|
|
|
#define MEM_SINGLE_CLOCK_OP 1
|
|
|
|
#define MEM_SIZE_MULTIPLE 1
|
|
|
|
#define MEM_SIZE_VALUE 131072
|
|
|
|
#define MEM_SPAN 131072
|
|
|
|
#define MEM_TYPE "altera_avalon_onchip_memory2"
|
|
|
|
#define MEM_WRITABLE 1
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* sem_ctl_slave configuration
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2022-10-24 22:35:24 +03:00
|
|
|
#define ALT_MODULE_CLASS_sem_ctl_slave sem
|
2022-12-22 22:27:05 +03:00
|
|
|
#define SEM_CTL_SLAVE_BASE 0x21060
|
2022-10-19 15:03:52 +03:00
|
|
|
#define SEM_CTL_SLAVE_IRQ -1
|
|
|
|
#define SEM_CTL_SLAVE_IRQ_INTERRUPT_CONTROLLER_ID -1
|
|
|
|
#define SEM_CTL_SLAVE_NAME "/dev/sem_ctl_slave"
|
|
|
|
#define SEM_CTL_SLAVE_SPAN 8
|
2022-10-24 22:35:24 +03:00
|
|
|
#define SEM_CTL_SLAVE_TYPE "sem"
|
2022-10-19 15:03:52 +03:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* sem_ram_slave configuration
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2022-10-24 22:35:24 +03:00
|
|
|
#define ALT_MODULE_CLASS_sem_ram_slave sem
|
2022-12-22 22:27:05 +03:00
|
|
|
#define SEM_RAM_SLAVE_BASE 0x21000
|
2022-10-19 15:03:52 +03:00
|
|
|
#define SEM_RAM_SLAVE_IRQ -1
|
|
|
|
#define SEM_RAM_SLAVE_IRQ_INTERRUPT_CONTROLLER_ID -1
|
|
|
|
#define SEM_RAM_SLAVE_NAME "/dev/sem_ram_slave"
|
2022-12-22 22:27:05 +03:00
|
|
|
#define SEM_RAM_SLAVE_SPAN 64
|
2022-10-24 22:35:24 +03:00
|
|
|
#define SEM_RAM_SLAVE_TYPE "sem"
|
2022-10-19 15:03:52 +03:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* sys_clk_timer configuration
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define ALT_MODULE_CLASS_sys_clk_timer altera_avalon_timer
|
|
|
|
#define SYS_CLK_TIMER_ALWAYS_RUN 0
|
2022-12-22 22:27:05 +03:00
|
|
|
#define SYS_CLK_TIMER_BASE 0x21040
|
2022-10-19 15:03:52 +03:00
|
|
|
#define SYS_CLK_TIMER_COUNTER_SIZE 32
|
|
|
|
#define SYS_CLK_TIMER_FIXED_PERIOD 0
|
|
|
|
#define SYS_CLK_TIMER_FREQ 50000000
|
|
|
|
#define SYS_CLK_TIMER_IRQ 0
|
|
|
|
#define SYS_CLK_TIMER_IRQ_INTERRUPT_CONTROLLER_ID 0
|
|
|
|
#define SYS_CLK_TIMER_LOAD_VALUE 49999
|
|
|
|
#define SYS_CLK_TIMER_MULT 0.001
|
|
|
|
#define SYS_CLK_TIMER_NAME "/dev/sys_clk_timer"
|
|
|
|
#define SYS_CLK_TIMER_PERIOD 1
|
|
|
|
#define SYS_CLK_TIMER_PERIOD_UNITS "ms"
|
|
|
|
#define SYS_CLK_TIMER_RESET_OUTPUT 0
|
|
|
|
#define SYS_CLK_TIMER_SNAPSHOT 1
|
|
|
|
#define SYS_CLK_TIMER_SPAN 32
|
|
|
|
#define SYS_CLK_TIMER_TICKS_PER_SEC 1000
|
|
|
|
#define SYS_CLK_TIMER_TIMEOUT_PULSE_OUTPUT 0
|
|
|
|
#define SYS_CLK_TIMER_TYPE "altera_avalon_timer"
|
|
|
|
|
|
|
|
#endif /* __SYSTEM_H_ */
|