aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2017-10-20 16:06:39 -0700
committerMartin Braun <martin.braun@ettus.com>2017-12-22 15:04:03 -0800
commit4087126476e11bae11f203f33be13c795bd67d35 (patch)
treecdfddcd770a19bd67fc6afd9ac43f74eb5cb35fe /host/lib
parent983bea69e589e619d97991a230ed96dd39b76a75 (diff)
downloaduhd-4087126476e11bae11f203f33be13c795bd67d35.tar.gz
uhd-4087126476e11bae11f203f33be13c795bd67d35.tar.bz2
uhd-4087126476e11bae11f203f33be13c795bd67d35.zip
ic_reg_maps: Add reg map for the Magnesium CPLD
Diffstat (limited to 'host/lib')
-rw-r--r--host/lib/ic_reg_maps/CMakeLists.txt5
-rw-r--r--host/lib/ic_reg_maps/gen_mgcpld_regs.py165
2 files changed, 170 insertions, 0 deletions
diff --git a/host/lib/ic_reg_maps/CMakeLists.txt b/host/lib/ic_reg_maps/CMakeLists.txt
index 50adbf58f..d6877f0d3 100644
--- a/host/lib/ic_reg_maps/CMakeLists.txt
+++ b/host/lib/ic_reg_maps/CMakeLists.txt
@@ -126,4 +126,9 @@ LIBUHD_PYTHON_GEN_SOURCE(
${CMAKE_CURRENT_BINARY_DIR}/lmk04828_regs.hpp
)
+LIBUHD_PYTHON_GEN_SOURCE(
+ ${CMAKE_CURRENT_SOURCE_DIR}/gen_mgcpld_regs.py
+ ${CMAKE_CURRENT_BINARY_DIR}/magnesium_cpld_regs.hpp
+)
+
SET(LIBUHD_PYTHON_GEN_SOURCE_DEPS)
diff --git a/host/lib/ic_reg_maps/gen_mgcpld_regs.py b/host/lib/ic_reg_maps/gen_mgcpld_regs.py
new file mode 100644
index 000000000..fd3d9673f
--- /dev/null
+++ b/host/lib/ic_reg_maps/gen_mgcpld_regs.py
@@ -0,0 +1,165 @@
+#!/usr/bin/env python
+#
+# Copyright 2017 Ettus Research, a National Instruments Company
+#
+# SPDX-License-Identifier: GPL-3.0
+#
+"""
+Register map for the Magnesium CPLD. This is controlled via SPI.
+"""
+
+########################################################################
+# Template for raw text data describing registers
+# name addr[bit range inclusive] default optional enums
+########################################################################
+REGS_TMPL="""\
+scratch 0x0040[0:15] 0
+cpld_reset 0x0041[0] 0
+ch1_idle_tx_sw1 0x0050[0:1] 0 ShutdownTxSw1,FromTxFilterLp1700MHz,FromTxFilterLp3400MHz,FromTxFilterLp0800MHz
+ch1_idle_tx_sw2 0x0050[2:5] 1 ToTxFilterLp3400MHz=1,ToTxFilterLp1700MHz=2,ToTxFilterLp0800MHz=4,ToTxFilterLp6400MHz=8
+ch1_idle_tx_sw3 0x0050[6] 0 ToTxFilterBanks,BypassPathToTrxSw
+ch1_idle_tx_lowband_mixer_path_select 0x0050[7] 0 bypass,enable
+ch1_idle_tx_mixer_en 0x0050[8] 0
+ch1_idle_tx_amp_en 0x0050[9] 0
+ch1_idle_tx_pa_en 0x0050[10] 0
+ch1_idle_sw_trx 0x0050[11:12] 0 FromLowerFilterBankTxSw1,FromTxUpperFilterBankLp6400MHz,RxChannelPath,BypassPathToTxSw3
+ch1_idle_tx_led 0x0050[13] 0
+ch1_idle_tx_myk_en 0x0050[14] 0
+ch1_idle_rx_sw1 0x0051[0:1] 3 TxRxInput,RxLoCalInput,TrxSwitchOutput,Rx2Input
+ch1_idle_rx_sw2 0x0051[2:3] 0 ShutdownSw2,LowerFilterBankToSwitch3,BypassPathToSwitch6,UpperFilterBankToSwitch4
+ch1_idle_rx_sw3 0x0051[4:6] 0 Filter2100x2850MHz=0,Filter0490LpMHz=1,Filter1600x2250MHz=2,Filter0440x0530MHz=4,Filter0650x1000MHz=5,Filter1100x1575MHz=6,ShutdownSw3=7
+ch1_idle_rx_sw4 0x0051[7:9] 1 Filter2100x2850MHzFrom=1,Filter1600x2250MHzFrom=2,Filter2700HpMHz=4
+ch1_idle_rx_sw5 0x0051[10:13] 1 Filter0440x0530MHzFrom=1,Filter1100x1575MHzFrom=2,Filter0490LpMHzFrom=4,Filter0650x1000MHzFrom=8
+ch1_idle_rx_sw6 0x0052[0:2] 1 LowerFilterBankFromSwitch5=1,UpperFilterBankFromSwitch4=2,BypassPathFromSwitch2=4
+ch1_idle_rx_loband_mixer_path_sel 0x0052[3] 0 bypass,loband
+ch1_idle_rx_mixer_en 0x0052[4] 0
+ch1_idle_rx_amp_en 0x0052[5] 0
+ch1_idle_rx_lna1_en 0x0052[6] 0
+ch1_idle_rx_lna2_en 0x0052[7] 0
+ch1_idle_rx2_led 0x0052[8] 0
+ch1_idle_rx_led 0x0052[9] 0
+ch1_idle_rx_myk_en 0x0052[10] 0
+ch1_on_tx_sw1 0x0053[0:1] 0 ShutdownTxSw1,FromTxFilterLp1700MHz,FromTxFilterLp3400MHz,FromTxFilterLp0800MHz
+ch1_on_tx_sw2 0x0053[2:5] 1 ToTxFilterLp3400MHz=1,ToTxFilterLp1700MHz=2,ToTxFilterLp0800MHz=4,ToTxFilterLp6400MHz=8
+ch1_on_tx_sw3 0x0053[6] 0 ToTxFilterBanks,BypassPathToTrxSw
+ch1_on_tx_lowband_mixer_path_select 0x0050[7] 0 bypass,enable
+ch1_on_tx_mixer_en 0x0053[8] 0
+ch1_on_tx_amp_en 0x0053[9] 0
+ch1_on_tx_pa_en 0x0053[10] 0
+ch1_on_sw_trx 0x0053[11:12] 0 FromLowerFilterBankTxSw1,FromTxUpperFilterBankLp6400MHz,RxChannelPath,BypassPathToTxSw3
+ch1_on_tx_led 0x0053[13] 0
+ch1_on_tx_myk_en 0x0053[14] 0
+ch1_on_rx_sw1 0x0054[0:1] 3 TxRxInput,RxLoCalInput,TrxSwitchOutput,Rx2Input
+ch1_on_rx_sw2 0x0054[2:3] 1 ShutdownSw2,LowerFilterBankToSwitch3,BypassPathToSwitch6,UpperFilterBankToSwitch4
+ch1_on_rx_sw3 0x0054[4:6] 0 Filter2100x2850MHz=0,Filter0490LpMHz=1,Filter1600x2250MHz=2,Filter0440x0530MHz=4,Filter0650x1000MHz=5,Filter1100x1575MHz=6,ShutdownSw3=7
+ch1_on_rx_sw4 0x0054[7:9] 1 Filter2100x2850MHzFrom=1,Filter1600x2250MHzFrom=2,Filter2700HpMHz=4
+ch1_on_rx_sw5 0x0054[10:13] 4 Filter0440x0530MHzFrom=1,Filter1100x1575MHzFrom=2,Filter0490LpMHzFrom=4,Filter0650x1000MHzFrom=8
+ch1_on_rx_sw6 0x0055[0:2] 2 LowerFilterBankFromSwitch5=1,UpperFilterBankFromSwitch4=2,BypassPathFromSwitch2=4
+ch1_on_rx_loband_mixer_path_sel 0x0055[3] 0 bypass,loband
+ch1_on_rx_mixer_en 0x0055[4] 0
+ch1_on_rx_amp_en 0x0055[5] 1
+ch1_on_rx_lna1_en 0x0055[6] 1
+ch1_on_rx_lna2_en 0x0055[7] 1
+ch1_on_rx2_led 0x0055[8] 1
+ch1_on_rx_led 0x0055[9] 0
+ch1_on_rx_myk_en 0x0055[10] 1
+ch2_idle_tx_sw1 0x0060[0:1] 0 ShutdownTxSw1,FromTxFilterLp1700MHz,FromTxFilterLp3400MHz,FromTxFilterLp0800MHz
+ch2_idle_tx_sw2 0x0060[2:5] 1 ToTxFilterLp3400MHz=1,ToTxFilterLp1700MHz=2,ToTxFilterLp0800MHz=4,ToTxFilterLp6400MHz=8
+ch2_idle_tx_sw3 0x0060[6] 0 ToTxFilterBanks,BypassPathToTrxSw
+ch2_idle_tx_lowband_mixer_path_select 0x0060[7] 0 bypass,enable
+ch2_idle_tx_mixer_en 0x0060[8] 0
+ch2_idle_tx_amp_en 0x0060[9] 0
+ch2_idle_tx_pa_en 0x0060[10] 0
+ch2_idle_sw_trx 0x0060[11:12] 0 FromLowerFilterBankTxSw1,FromTxUpperFilterBankLp6400MHz,RxChannelPath,BypassPathToTxSw3
+ch2_idle_tx_led 0x0060[13] 0
+ch2_idle_tx_myk_en 0x0060[14] 0
+ch2_idle_rx_sw1 0x0061[0:1] 3 TxRxInput,RxLoCalInput,TrxSwitchOutput,Rx2Input
+ch2_idle_rx_sw2 0x0061[2:3] 0 ShutdownSw2,LowerFilterBankToSwitch3,BypassPathToSwitch6,UpperFilterBankToSwitch4
+ch2_idle_rx_sw3 0x0061[4:6] 0 Filter2100x2850MHz=0,Filter0490LpMHz=1,Filter1600x2250MHz=2,Filter0440x0530MHz=4,Filter0650x1000MHz=5,Filter1100x1575MHz=6,ShutdownSw3=7
+ch2_idle_rx_sw4 0x0061[7:9] 1 Filter2100x2850MHzFrom=1,Filter1600x2250MHzFrom=2,Filter2700HpMHz=4
+ch2_idle_rx_sw5 0x0061[10:13] 1 Filter0440x0530MHzFrom=1,Filter1100x1575MHzFrom=2,Filter0490LpMHzFrom=4,Filter0650x1000MHzFrom=8
+ch2_idle_rx_sw6 0x0062[0:2] 1 LowerFilterBankFromSwitch5=1,UpperFilterBankFromSwitch4=2,BypassPathFromSwitch2=4
+ch2_idle_rx_loband_mixer_path_sel 0x0062[3] 0 bypass,loband
+ch2_idle_rx_mixer_en 0x0062[4] 0
+ch2_idle_rx_amp_en 0x0062[5] 0
+ch2_idle_rx_lna1_en 0x0062[6] 0
+ch2_idle_rx_lna2_en 0x0062[7] 0
+ch2_idle_rx2_led 0x0062[8] 0
+ch2_idle_rx_led 0x0062[9] 0
+ch2_idle_rx_myk_en 0x0062[10] 0
+ch2_on_tx_sw1 0x0063[0:1] 0 ShutdownTxSw1,FromTxFilterLp1700MHz,FromTxFilterLp3400MHz,FromTxFilterLp0800MHz
+ch2_on_tx_sw2 0x0063[2:5] 1 ToTxFilterLp3400MHz=1,ToTxFilterLp1700MHz=2,ToTxFilterLp0800MHz=4,ToTxFilterLp6400MHz=8
+ch2_on_tx_sw3 0x0063[6] 0 ToTxFilterBanks,BypassPathToTrxSw
+ch2_on_tx_lowband_mixer_path_select 0x0050[7] 0 bypass,enable
+ch2_on_tx_mixer_en 0x0063[8] 0
+ch2_on_tx_amp_en 0x0063[9] 0
+ch2_on_tx_pa_en 0x0063[10] 0
+ch2_on_sw_trx 0x0063[11:12] 0 FromLowerFilterBankTxSw1,FromTxUpperFilterBankLp6400MHz,RxChannelPath,BypassPathToTxSw3
+ch2_on_tx_led 0x0063[13] 0
+ch2_on_tx_myk_en 0x0063[14] 0
+ch2_on_rx_sw1 0x0064[0:1] 3 TxRxInput,RxLoCalInput,TrxSwitchOutput,Rx2Input
+ch2_on_rx_sw2 0x0064[2:3] 1 ShutdownSw2,LowerFilterBankToSwitch3,BypassPathToSwitch6,UpperFilterBankToSwitch4
+ch2_on_rx_sw3 0x0064[4:6] 0 Filter2100x2850MHz=0,Filter0490LpMHz=1,Filter1600x2250MHz=2,Filter0440x0530MHz=4,Filter0650x1000MHz=5,Filter1100x1575MHz=6,ShutdownSw3=7
+ch2_on_rx_sw4 0x0064[7:9] 1 Filter2100x2850MHzFrom=1,Filter1600x2250MHzFrom=2,Filter2700HpMHz=4
+ch2_on_rx_sw5 0x0064[10:13] 4 Filter0440x0530MHzFrom=1,Filter1100x1575MHzFrom=2,Filter0490LpMHzFrom=4,Filter0650x1000MHzFrom=8
+ch2_on_rx_sw6 0x0065[0:2] 2 LowerFilterBankFromSwitch5=1,UpperFilterBankFromSwitch4=2,BypassPathFromSwitch2=4
+ch2_on_rx_loband_mixer_path_sel 0x0065[3] 0 bypass,loband
+ch2_on_rx_mixer_en 0x0065[4] 0
+ch2_on_rx_amp_en 0x0065[5] 1
+ch2_on_rx_lna1_en 0x0065[6] 1
+ch2_on_rx_lna2_en 0x0065[7] 1
+ch2_on_rx2_led 0x0065[8] 1
+ch2_on_rx_led 0x0065[9] 0
+ch2_on_rx_myk_en 0x0065[10] 1
+"""
+
+
+# PS regs for reference:
+# signature 0[0:15] 0
+# rev 1[0:15] 0
+# oldest_compat 2[0:15] 0
+# build_code_hh 3[0:7] 0
+# build_code_dd 3[8:15] 0
+# build_code_mm 4[0:7] 0
+# build_code_yy 4[8:15] 0
+# scratch 5[0:15] 0
+# reset 16[0] 0
+# ...
+
+########################################################################
+# Template for methods in the body of the struct
+########################################################################
+BODY_TMPL="""\
+uint32_t get_reg(uint8_t addr){
+ uint32_t reg = 0;
+ switch(addr){
+ % for addr in [0x40, 0x41, 0x50, 0x51, 0x52, 0x53, 0x54, 0x55, 0x60, 0x61, 0x62, 0x63, 0x64, 0x65]:
+ case ${addr}:
+ % for reg in filter(lambda r: r.get_addr() == addr, regs):
+ reg |= (uint32_t(${reg.get_name()}) & ${reg.get_mask()}) << ${reg.get_shift()};
+ % endfor
+ break;
+ % endfor
+ }
+ return reg;
+}
+
+std::set<size_t> get_all_addrs()
+{
+ std::set<size_t> addrs;
+ % for reg in regs:
+ // Hopefully, compilers will optimize out this mess...
+ addrs.insert(${reg.get_addr()});
+ % endfor
+ return addrs;
+}
+"""
+
+if __name__ == '__main__':
+ import common; common.generate(
+ name='magnesium_cpld_regs',
+ regs_tmpl=REGS_TMPL,
+ body_tmpl=BODY_TMPL,
+ file=__file__,
+ )
+