//
// Copyright 2014 Ettus Research LLC
//
// This program 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 3 of the License, or
// (at your option) any later version.
//
// This program 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 this program. If not, see .
//
#ifndef INCLUDED_N230_FW_DEFS_H
#define INCLUDED_N230_FW_DEFS_H
#include
/*!
* Constants specific to N230 firmware.
* This header is shared by the firmware and host code.
* Therefore, this header may only contain valid C code.
* However, if it is included from within the host code,
* it will be namespaced appropriately
*/
#ifdef __cplusplus
namespace uhd {
namespace usrp {
namespace n230 {
namespace fw {
#endif
static inline uint32_t reg_addr(uint32_t base, uint32_t offset) {
return ((base) + (offset)*4);
}
/*******************************************************************
* Global
*******************************************************************/
static const uint32_t CPU_CLOCK_FREQ = 80000000;
static const uint32_t PER_MILLISEC_CRON_JOBID = 0;
static const uint32_t PER_SECOND_CRON_JOBID = 1;
/*******************************************************************
* Wishbone slave addresses
*******************************************************************/
static const uint32_t WB_MAIN_RAM_BASE = 0x0000;
static const uint32_t WB_PKT_RAM_BASE = 0x8000;
static const uint32_t WB_SBRB_BASE = 0xa000;
static const uint32_t WB_SPI_FLASH_BASE = 0xb000;
static const uint32_t WB_ETH0_MAC_BASE = 0xc000;
static const uint32_t WB_ETH1_MAC_BASE = 0xd000;
static const uint32_t WB_XB_SBRB_BASE = 0xe000;
static const uint32_t WB_ETH0_I2C_BASE = 0xf600;
static const uint32_t WB_ETH1_I2C_BASE = 0xf700;
static const uint32_t WB_DBG_UART_BASE = 0xf900;
/*******************************************************************
* Seting Register Base addresses
*******************************************************************/
static const uint32_t SR_ZPU_SW_RST = 0;
static const uint32_t SR_ZPU_BOOT_DONE = 1;
static const uint32_t SR_ZPU_LEDS = 2;
static const uint32_t SR_ZPU_XB_LOCAL = 4;
static const uint32_t SR_ZPU_SFP_CTRL0 = 16;
static const uint32_t SR_ZPU_SFP_CTRL1 = 17;
static const uint32_t SR_ZPU_ETHINT0 = 64;
static const uint32_t SR_ZPU_ETHINT1 = 80;
static const uint32_t SR_ZPU_SW_RST_NONE = 0x0;
static const uint32_t SR_ZPU_SW_RST_PHY = 0x1;
static const uint32_t SR_ZPU_SW_RST_RADIO = 0x2;
/*******************************************************************
* Readback addresses
*******************************************************************/
static const uint32_t RB_ZPU_COMPAT = 0;
static const uint32_t RB_ZPU_COUNTER = 1;
static const uint32_t RB_ZPU_SFP_STATUS0 = 2;
static const uint32_t RB_ZPU_SFP_STATUS1 = 3;
static const uint32_t RB_ZPU_ETH0_PKT_CNT = 6;
static const uint32_t RB_ZPU_ETH1_PKT_CNT = 7;
/*******************************************************************
* Ethernet
*******************************************************************/
static const uint32_t WB_PKT_RAM_CTRL_OFFSET = 0x1FFC;
static const uint32_t SR_ZPU_ETHINT_FRAMER_BASE = 0;
static const uint32_t SR_ZPU_ETHINT_DISPATCHER_BASE = 8;
//Eth framer constants
static const uint32_t ETH_FRAMER_SRC_MAC_HI = 0;
static const uint32_t ETH_FRAMER_SRC_MAC_LO = 1;
static const uint32_t ETH_FRAMER_SRC_IP_ADDR = 2;
static const uint32_t ETH_FRAMER_SRC_UDP_PORT = 3;
static const uint32_t ETH_FRAMER_DST_RAM_ADDR = 4;
static const uint32_t ETH_FRAMER_DST_IP_ADDR = 5;
static const uint32_t ETH_FRAMER_DST_UDP_MAC = 6;
static const uint32_t ETH_FRAMER_DST_MAC_LO = 7;
/*******************************************************************
* CODEC
*******************************************************************/
static const uint32_t CODEC_SPI_CLOCK_FREQ = 4000000; //4MHz
static const uint32_t ADF4001_SPI_CLOCK_FREQ = 200000; //200kHz
/*******************************************************************
* UART
*******************************************************************/
static const uint32_t DBG_UART_BAUD = 115200;
/*******************************************************************
* Build Compatability Numbers
*******************************************************************/
static const uint8_t PRODUCT_NUM = 0x01;
static const uint8_t COMPAT_MAJOR = 0x00;
static const uint16_t COMPAT_MINOR = 0x0000;
static inline uint8_t get_prod_num(uint32_t compat_reg) {
return (compat_reg >> 24) & 0xFF;
}
static inline uint8_t get_compat_major(uint32_t compat_reg) {
return (compat_reg >> 16) & 0xFF;
}
static inline uint8_t get_compat_minor(uint32_t compat_reg) {
return compat_reg & 0xFFFF;
}
#ifdef __cplusplus
}}}} //namespace
#endif
#endif /* INCLUDED_N230_FW_DEFS_H */