From e12866f81ef482d05c2bf2526184cbc8e08d9020 Mon Sep 17 00:00:00 2001 From: Dominic Spill Date: Mon, 11 Feb 2019 16:38:07 -0700 Subject: [PATCH 01/10] Remove PLL1 low speed settings (it's out of spec) --- firmware/common/hackrf_core.c | 161 ++++++++++++------------------- firmware/common/hackrf_core.h | 2 - firmware/hackrf_usb/hackrf_usb.c | 2 - 3 files changed, 62 insertions(+), 103 deletions(-) diff --git a/firmware/common/hackrf_core.c b/firmware/common/hackrf_core.c index 5ca74b7dc..acda4280d 100644 --- a/firmware/common/hackrf_core.c +++ b/firmware/common/hackrf_core.c @@ -146,9 +146,9 @@ i2c_bus_t i2c1 = { .transfer = i2c_lpc_transfer, }; -const i2c_lpc_config_t i2c_config_si5351c_slow_clock = { - .duty_cycle_count = 15, -}; +// const i2c_lpc_config_t i2c_config_si5351c_slow_clock = { +// .duty_cycle_count = 15, +// }; const i2c_lpc_config_t i2c_config_si5351c_fast_clock = { .duty_cycle_count = 255, @@ -463,6 +463,63 @@ bool baseband_filter_bandwidth_set(const uint32_t bandwidth_hz) { return bandwidth_hz_real != 0; } +/* +Configure PLL1 (Main MCU Clock) to max speed (204MHz). +Note: PLL1 clock is used by M4/M0 core, Peripheral, APB1. +This function shall be called after cpu_clock_init(). +*/ +static void cpu_clock_pll1_max_speed(void) +{ + uint32_t pll_reg; + + /* Configure PLL1 to Intermediate Clock (between 90 MHz and 110 MHz) */ + /* Integer mode: + FCLKOUT = M*(FCLKIN/N) + FCCO = 2*P*FCLKOUT = 2*P*M*(FCLKIN/N) + */ + pll_reg = CGU_PLL1_CTRL; + /* Clear PLL1 bits */ + pll_reg &= ~( CGU_PLL1_CTRL_CLK_SEL_MASK | CGU_PLL1_CTRL_PD_MASK | CGU_PLL1_CTRL_FBSEL_MASK | /* CLK SEL, PowerDown , FBSEL */ + CGU_PLL1_CTRL_BYPASS_MASK | /* BYPASS */ + CGU_PLL1_CTRL_DIRECT_MASK | /* DIRECT */ + CGU_PLL1_CTRL_PSEL_MASK | CGU_PLL1_CTRL_MSEL_MASK | CGU_PLL1_CTRL_NSEL_MASK ); /* PSEL, MSEL, NSEL- divider ratios */ + /* Set PLL1 up to 12MHz * 8 = 96MHz. */ + pll_reg |= CGU_PLL1_CTRL_CLK_SEL(CGU_SRC_XTAL) + | CGU_PLL1_CTRL_PSEL(0) + | CGU_PLL1_CTRL_NSEL(0) + | CGU_PLL1_CTRL_MSEL(7) + | CGU_PLL1_CTRL_FBSEL(1); + CGU_PLL1_CTRL = pll_reg; + /* wait until stable */ + while (!(CGU_PLL1_STAT & CGU_PLL1_STAT_LOCK_MASK)); + + /* use PLL1 as clock source for BASE_M4_CLK (CPU) */ + CGU_BASE_M4_CLK = (CGU_BASE_M4_CLK_CLK_SEL(CGU_SRC_PLL1) | CGU_BASE_M4_CLK_AUTOBLOCK(1)); + + /* Wait before to switch to max speed */ + delay(WAIT_CPU_CLOCK_INIT_DELAY); + + /* Configure PLL1 Max Speed */ + /* Direct mode: FCLKOUT = FCCO = M*(FCLKIN/N) */ + pll_reg = CGU_PLL1_CTRL; + /* Clear PLL1 bits */ + pll_reg &= ~( CGU_PLL1_CTRL_CLK_SEL_MASK | CGU_PLL1_CTRL_PD_MASK | CGU_PLL1_CTRL_FBSEL_MASK | /* CLK SEL, PowerDown , FBSEL */ + CGU_PLL1_CTRL_BYPASS_MASK | /* BYPASS */ + CGU_PLL1_CTRL_DIRECT_MASK | /* DIRECT */ + CGU_PLL1_CTRL_PSEL_MASK | CGU_PLL1_CTRL_MSEL_MASK | CGU_PLL1_CTRL_NSEL_MASK ); /* PSEL, MSEL, NSEL- divider ratios */ + /* Set PLL1 up to 12MHz * 17 = 204MHz. */ + pll_reg |= CGU_PLL1_CTRL_CLK_SEL(CGU_SRC_XTAL) + | CGU_PLL1_CTRL_PSEL(0) + | CGU_PLL1_CTRL_NSEL(0) + | CGU_PLL1_CTRL_MSEL(16) + | CGU_PLL1_CTRL_FBSEL(1) + | CGU_PLL1_CTRL_DIRECT(1); + CGU_PLL1_CTRL = pll_reg; + /* wait until stable */ + while (!(CGU_PLL1_STAT & CGU_PLL1_STAT_LOCK_MASK)); + +} + /* clock startup for LPC4320 configure PLL1 to max speed (204MHz). Note: PLL1 clock is used by M4/M0 core, Peripheral, APB1. */ void cpu_clock_init(void) @@ -473,7 +530,7 @@ void cpu_clock_init(void) /* use IRC as clock source for APB3 */ CGU_BASE_APB3_CLK = CGU_BASE_APB3_CLK_CLK_SEL(CGU_SRC_IRC); - i2c_bus_start(clock_gen.bus, &i2c_config_si5351c_slow_clock); + i2c_bus_start(clock_gen.bus, &i2c_config_si5351c_fast_clock); si5351c_disable_all_outputs(&clock_gen); si5351c_disable_oeb_pin_control(&clock_gen); @@ -543,10 +600,7 @@ void cpu_clock_init(void) CGU_BASE_APB3_CLK = CGU_BASE_APB3_CLK_AUTOBLOCK(1) | CGU_BASE_APB3_CLK_CLK_SEL(CGU_SRC_XTAL); - cpu_clock_pll1_low_speed(); - - /* use PLL1 as clock source for BASE_M4_CLK (CPU) */ - CGU_BASE_M4_CLK = (CGU_BASE_M4_CLK_CLK_SEL(CGU_SRC_PLL1) | CGU_BASE_M4_CLK_AUTOBLOCK(1)); + cpu_clock_pll1_max_speed(); /* use XTAL_OSC as clock source for PLL0USB */ CGU_PLL0USB_CTRL = CGU_PLL0USB_CTRL_PD(1) @@ -658,97 +712,6 @@ void cpu_clock_init(void) #endif } - -/* -Configure PLL1 to low speed (48MHz). -Note: PLL1 clock is used by M4/M0 core, Peripheral, APB1. -This function shall be called after cpu_clock_init(). -This function is mainly used to lower power consumption. -*/ -void cpu_clock_pll1_low_speed(void) -{ - uint32_t pll_reg; - - /* Configure PLL1 Clock (48MHz) */ - /* Integer mode: - FCLKOUT = M*(FCLKIN/N) - FCCO = 2*P*FCLKOUT = 2*P*M*(FCLKIN/N) - */ - pll_reg = CGU_PLL1_CTRL; - /* Clear PLL1 bits */ - pll_reg &= ~( CGU_PLL1_CTRL_CLK_SEL_MASK | CGU_PLL1_CTRL_PD_MASK | CGU_PLL1_CTRL_FBSEL_MASK | /* CLK SEL, PowerDown , FBSEL */ - CGU_PLL1_CTRL_BYPASS_MASK | /* BYPASS */ - CGU_PLL1_CTRL_DIRECT_MASK | /* DIRECT */ - CGU_PLL1_CTRL_PSEL_MASK | CGU_PLL1_CTRL_MSEL_MASK | CGU_PLL1_CTRL_NSEL_MASK ); /* PSEL, MSEL, NSEL- divider ratios */ - /* Set PLL1 up to 12MHz * 4 = 48MHz. */ - pll_reg |= CGU_PLL1_CTRL_CLK_SEL(CGU_SRC_XTAL) - | CGU_PLL1_CTRL_PSEL(0) - | CGU_PLL1_CTRL_NSEL(0) - | CGU_PLL1_CTRL_MSEL(3) - | CGU_PLL1_CTRL_FBSEL(1) - | CGU_PLL1_CTRL_DIRECT(1); - CGU_PLL1_CTRL = pll_reg; - /* wait until stable */ - while (!(CGU_PLL1_STAT & CGU_PLL1_STAT_LOCK_MASK)); - - /* Wait a delay after switch to new frequency with Direct mode */ - delay(WAIT_CPU_CLOCK_INIT_DELAY); -} - -/* -Configure PLL1 (Main MCU Clock) to max speed (204MHz). -Note: PLL1 clock is used by M4/M0 core, Peripheral, APB1. -This function shall be called after cpu_clock_init(). -*/ -void cpu_clock_pll1_max_speed(void) -{ - uint32_t pll_reg; - - /* Configure PLL1 to Intermediate Clock (between 90 MHz and 110 MHz) */ - /* Integer mode: - FCLKOUT = M*(FCLKIN/N) - FCCO = 2*P*FCLKOUT = 2*P*M*(FCLKIN/N) - */ - pll_reg = CGU_PLL1_CTRL; - /* Clear PLL1 bits */ - pll_reg &= ~( CGU_PLL1_CTRL_CLK_SEL_MASK | CGU_PLL1_CTRL_PD_MASK | CGU_PLL1_CTRL_FBSEL_MASK | /* CLK SEL, PowerDown , FBSEL */ - CGU_PLL1_CTRL_BYPASS_MASK | /* BYPASS */ - CGU_PLL1_CTRL_DIRECT_MASK | /* DIRECT */ - CGU_PLL1_CTRL_PSEL_MASK | CGU_PLL1_CTRL_MSEL_MASK | CGU_PLL1_CTRL_NSEL_MASK ); /* PSEL, MSEL, NSEL- divider ratios */ - /* Set PLL1 up to 12MHz * 8 = 96MHz. */ - pll_reg |= CGU_PLL1_CTRL_CLK_SEL(CGU_SRC_XTAL) - | CGU_PLL1_CTRL_PSEL(0) - | CGU_PLL1_CTRL_NSEL(0) - | CGU_PLL1_CTRL_MSEL(7) - | CGU_PLL1_CTRL_FBSEL(1); - CGU_PLL1_CTRL = pll_reg; - /* wait until stable */ - while (!(CGU_PLL1_STAT & CGU_PLL1_STAT_LOCK_MASK)); - - /* Wait before to switch to max speed */ - delay(WAIT_CPU_CLOCK_INIT_DELAY); - - /* Configure PLL1 Max Speed */ - /* Direct mode: FCLKOUT = FCCO = M*(FCLKIN/N) */ - pll_reg = CGU_PLL1_CTRL; - /* Clear PLL1 bits */ - pll_reg &= ~( CGU_PLL1_CTRL_CLK_SEL_MASK | CGU_PLL1_CTRL_PD_MASK | CGU_PLL1_CTRL_FBSEL_MASK | /* CLK SEL, PowerDown , FBSEL */ - CGU_PLL1_CTRL_BYPASS_MASK | /* BYPASS */ - CGU_PLL1_CTRL_DIRECT_MASK | /* DIRECT */ - CGU_PLL1_CTRL_PSEL_MASK | CGU_PLL1_CTRL_MSEL_MASK | CGU_PLL1_CTRL_NSEL_MASK ); /* PSEL, MSEL, NSEL- divider ratios */ - /* Set PLL1 up to 12MHz * 17 = 204MHz. */ - pll_reg |= CGU_PLL1_CTRL_CLK_SEL(CGU_SRC_XTAL) - | CGU_PLL1_CTRL_PSEL(0) - | CGU_PLL1_CTRL_NSEL(0) - | CGU_PLL1_CTRL_MSEL(16) - | CGU_PLL1_CTRL_FBSEL(1) - | CGU_PLL1_CTRL_DIRECT(1); - CGU_PLL1_CTRL = pll_reg; - /* wait until stable */ - while (!(CGU_PLL1_STAT & CGU_PLL1_STAT_LOCK_MASK)); - -} - void ssp1_set_mode_max2837(void) { spi_bus_start(max2837.bus, &ssp_config_max2837); diff --git a/firmware/common/hackrf_core.h b/firmware/common/hackrf_core.h index b30cfdff9..3abded20e 100644 --- a/firmware/common/hackrf_core.h +++ b/firmware/common/hackrf_core.h @@ -283,8 +283,6 @@ extern jtag_t jtag_cpld; extern i2c_bus_t i2c0; void cpu_clock_init(void); -void cpu_clock_pll1_low_speed(void); -void cpu_clock_pll1_max_speed(void); void ssp1_set_mode_max2837(void); void ssp1_set_mode_max5864(void); diff --git a/firmware/hackrf_usb/hackrf_usb.c b/firmware/hackrf_usb/hackrf_usb.c index 8bb8b4170..cc1022057 100644 --- a/firmware/hackrf_usb/hackrf_usb.c +++ b/firmware/hackrf_usb/hackrf_usb.c @@ -175,11 +175,9 @@ void usb_configuration_changed( set_transceiver_mode(TRANSCEIVER_MODE_OFF); if( device->configuration->number == 1 ) { // transceiver configuration - cpu_clock_pll1_max_speed(); led_on(LED1); } else { /* Configuration number equal 0 means usb bus reset. */ - cpu_clock_pll1_low_speed(); led_off(LED1); } } From 65e3d6f09995df79dd5bdb8e12e67fb7b2149c31 Mon Sep 17 00:00:00 2001 From: Jared Boone Date: Fri, 1 Mar 2019 15:58:19 -0800 Subject: [PATCH 02/10] Travis-CI: Use environment variables so others can maintain nightly builds. --- tools/deploy-nightly.sh | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/tools/deploy-nightly.sh b/tools/deploy-nightly.sh index 4a0ded5a9..0bdf4f1bb 100644 --- a/tools/deploy-nightly.sh +++ b/tools/deploy-nightly.sh @@ -1,10 +1,9 @@ #!/bin/bash -REPO=greatscottgadgets/hackrf-nightly PUBLICATION_BRANCH=master # set -x cd $HOME # Checkout the branch -git clone --branch=$PUBLICATION_BRANCH https://${GITHUB_TOKEN}@github.com/$REPO.git publish +git clone --branch=$PUBLICATION_BRANCH https://${GITHUB_TOKEN}@github.com/${REPO}.git publish cd publish # Update pages cp $ARTEFACT_BASE/$BUILD_NAME.tar.xz . @@ -22,13 +21,11 @@ echo "

HackRF Nightly Builds

" > index.html -URL=https://greatscottgadgets.github.io/hackrf-nightly - for commit in $COMMITS; do FILENAME=`find . -maxdepth 1 -name "*-$commit.tar.xz"` if [ "$FILENAME" != "" ]; then FN=${FILENAME:2} - echo "$FN
" >> index.html + echo "$FN
" >> index.html fi done From 21c26d19e365c179eb6129dbca980e55c6ffc9d5 Mon Sep 17 00:00:00 2001 From: Jared Boone Date: Sat, 2 Mar 2019 13:44:58 -0800 Subject: [PATCH 03/10] deploy-nightly: rename REPO and URL with ARTEFACT_ prefix. --- tools/deploy-nightly.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tools/deploy-nightly.sh b/tools/deploy-nightly.sh index 0bdf4f1bb..802169584 100644 --- a/tools/deploy-nightly.sh +++ b/tools/deploy-nightly.sh @@ -3,7 +3,7 @@ PUBLICATION_BRANCH=master # set -x cd $HOME # Checkout the branch -git clone --branch=$PUBLICATION_BRANCH https://${GITHUB_TOKEN}@github.com/${REPO}.git publish +git clone --branch=$PUBLICATION_BRANCH https://${GITHUB_TOKEN}@github.com/${ARTEFACT_REPO}.git publish cd publish # Update pages cp $ARTEFACT_BASE/$BUILD_NAME.tar.xz . @@ -25,7 +25,7 @@ for commit in $COMMITS; do FILENAME=`find . -maxdepth 1 -name "*-$commit.tar.xz"` if [ "$FILENAME" != "" ]; then FN=${FILENAME:2} - echo "$FN
" >> index.html + echo "$FN
" >> index.html fi done From 36cca31260d526b899af7876eb0bcbf2b85360e4 Mon Sep 17 00:00:00 2001 From: Jared Boone Date: Fri, 1 Feb 2019 09:57:09 +0000 Subject: [PATCH 04/10] UI: Move ui_portapack.* to common. Otherwise blinky won't build. TODO: Tried to tease apart all the dependencies to get blinky to build without, but it's such a twisted knot... --- firmware/{hackrf_usb => common}/ui_portapack.c | 0 firmware/{hackrf_usb => common}/ui_portapack.h | 0 firmware/hackrf_usb/CMakeLists.txt | 2 +- 3 files changed, 1 insertion(+), 1 deletion(-) rename firmware/{hackrf_usb => common}/ui_portapack.c (100%) rename firmware/{hackrf_usb => common}/ui_portapack.h (100%) diff --git a/firmware/hackrf_usb/ui_portapack.c b/firmware/common/ui_portapack.c similarity index 100% rename from firmware/hackrf_usb/ui_portapack.c rename to firmware/common/ui_portapack.c diff --git a/firmware/hackrf_usb/ui_portapack.h b/firmware/common/ui_portapack.h similarity index 100% rename from firmware/hackrf_usb/ui_portapack.h rename to firmware/common/ui_portapack.h diff --git a/firmware/hackrf_usb/CMakeLists.txt b/firmware/hackrf_usb/CMakeLists.txt index e6c827c19..67ddb20ab 100644 --- a/firmware/hackrf_usb/CMakeLists.txt +++ b/firmware/hackrf_usb/CMakeLists.txt @@ -59,7 +59,7 @@ set(SRC_M4 if(USER_INTERFACE STREQUAL "PORTAPACK") SET(SRC_M4 ${SRC_M4} - ui_portapack.c + "${PATH_HACKRF_FIRMWARE_COMMON}/ui_portapack.c" ) endif() From c32d57158a3aec6472c774a4df1ccfdead0f319d Mon Sep 17 00:00:00 2001 From: Jared Boone Date: Fri, 1 Feb 2019 21:32:19 +0000 Subject: [PATCH 05/10] PortaPack: Remove weak UI functions, detect and return UI function table. TODO: Side effect was that now blinky has a lot of unreasonable dependencies. TODO: rad1o breakage is likely... --- firmware/common/hackrf-ui.c | 74 +++++++++++++++++++++++ firmware/common/hackrf-ui.h | 37 +++++++----- firmware/common/hackrf_core.c | 4 +- firmware/common/rf_path.c | 8 +-- firmware/common/tuning.c | 2 +- firmware/common/ui_portapack.c | 57 ----------------- firmware/common/ui_portapack.h | 2 + firmware/hackrf-common.cmake | 6 ++ firmware/hackrf_usb/CMakeLists.txt | 11 ---- firmware/hackrf_usb/hackrf_usb.c | 2 +- firmware/hackrf_usb/usb_api_transceiver.c | 6 +- 11 files changed, 115 insertions(+), 94 deletions(-) create mode 100644 firmware/common/hackrf-ui.c diff --git a/firmware/common/hackrf-ui.c b/firmware/common/hackrf-ui.c new file mode 100644 index 000000000..0b85e7777 --- /dev/null +++ b/firmware/common/hackrf-ui.c @@ -0,0 +1,74 @@ +/* + * Copyright (C) 2019 Jared Boone, ShareBrained Technology, Inc. + * + * This file is part of HackRF. + * + * 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 2, 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; see the file COPYING. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, + * Boston, MA 02110-1301, USA. + */ + +#include "hackrf-ui.h" + +#include "ui_portapack.h" + +#include + +#define UNUSED(x) (void)(x) + +/* Stub functions for null UI function table */ +void hackrf_ui_init_null(void) { } +void hackrf_ui_set_frequency_null(uint64_t frequency) { UNUSED(frequency); } +void hackrf_ui_set_sample_rate_null(uint32_t sample_rate) { UNUSED(sample_rate); } +void hackrf_ui_set_direction_null(const rf_path_direction_t direction) { UNUSED(direction); } +void hackrf_ui_set_filter_bw_null(uint32_t bandwidth) { UNUSED(bandwidth); } +void hackrf_ui_set_lna_power_null(bool lna_on) { UNUSED(lna_on); } +void hackrf_ui_set_bb_lna_gain_null(const uint32_t gain_db) { UNUSED(gain_db); } +void hackrf_ui_set_bb_vga_gain_null(const uint32_t gain_db) { UNUSED(gain_db); } +void hackrf_ui_set_bb_tx_vga_gain_null(const uint32_t gain_db) { UNUSED(gain_db); } +void hackrf_ui_set_first_if_frequency_null(const uint64_t frequency) { UNUSED(frequency); } +void hackrf_ui_set_filter_null(const rf_path_filter_t filter) { UNUSED(filter); } +void hackrf_ui_set_antenna_bias_null(bool antenna_bias) { UNUSED(antenna_bias); } + +/* Null UI function table, used if there's no hardware UI detected. Eliminates the + * need to check for null UI before calling a function in the table. + */ +static const hackrf_ui_t hackrf_ui_null = { + &hackrf_ui_init_null, + &hackrf_ui_set_frequency_null, + &hackrf_ui_set_sample_rate_null, + &hackrf_ui_set_direction_null, + &hackrf_ui_set_filter_bw_null, + &hackrf_ui_set_lna_power_null, + &hackrf_ui_set_bb_lna_gain_null, + &hackrf_ui_set_bb_vga_gain_null, + &hackrf_ui_set_bb_tx_vga_gain_null, + &hackrf_ui_set_first_if_frequency_null, + &hackrf_ui_set_filter_null, + &hackrf_ui_set_antenna_bias_null, +}; + +static const hackrf_ui_t* ui = NULL; + +const hackrf_ui_t* hackrf_ui(void) { + /* Detect on first use. If no UI hardware is detected, use a stub function table. */ + if( ui == NULL ) { + ui = portapack_detect(); + if( ui == NULL ) { + ui = &hackrf_ui_null; + } + } + + return ui; +} diff --git a/firmware/common/hackrf-ui.h b/firmware/common/hackrf-ui.h index ad295d783..a18f9d744 100644 --- a/firmware/common/hackrf-ui.h +++ b/firmware/common/hackrf-ui.h @@ -1,3 +1,24 @@ +/* + * Copyright (C) 2018 Jared Boone, ShareBrained Technology, Inc. + * + * This file is part of HackRF. + * + * 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 2, 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; see the file COPYING. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, + * Boston, MA 02110-1301, USA. + */ + #ifndef HACKRF_UI_H #define HACKRF_UI_H @@ -36,20 +57,6 @@ typedef struct { * In the future, whatever UI was detected will be returned here, * or NULL if no UI was detected. */ -const hackrf_ui_t* hackrf_ui(void) __attribute__((weak)); - -void hackrf_ui_init(void) __attribute__((weak)); -void hackrf_ui_setFrequency(uint64_t _freq) __attribute__((weak)); -void hackrf_ui_setSampleRate(uint32_t _sample_rate) __attribute__((weak)); -void hackrf_ui_setDirection(const rf_path_direction_t _direction) __attribute__((weak)); -void hackrf_ui_setFilterBW(uint32_t bw) __attribute__((weak)); -void hackrf_ui_setLNAPower(bool _lna_on) __attribute__((weak)); -void hackrf_ui_setBBLNAGain(const uint32_t gain_db) __attribute__((weak)); -void hackrf_ui_setBBVGAGain(const uint32_t gain_db) __attribute__((weak)); -void hackrf_ui_setBBTXVGAGain(const uint32_t gain_db) __attribute__((weak)); - -void hackrf_ui_setFirstIFFrequency(const uint64_t freq) __attribute__((weak)); -void hackrf_ui_setFilter(const rf_path_filter_t filter) __attribute__((weak)); -void hackrf_ui_setAntennaBias(bool antenna_bias) __attribute__((weak)); +const hackrf_ui_t* hackrf_ui(void); #endif diff --git a/firmware/common/hackrf_core.c b/firmware/common/hackrf_core.c index 5ca74b7dc..68ddf161f 100644 --- a/firmware/common/hackrf_core.c +++ b/firmware/common/hackrf_core.c @@ -337,7 +337,7 @@ bool sample_rate_frac_set(uint32_t rate_num, uint32_t rate_denom) uint32_t a, b, c; uint32_t rem; - hackrf_ui_setSampleRate(rate_num/2); + hackrf_ui()->set_sample_rate(rate_num/2); /* Find best config */ a = (VCO_FREQ * rate_denom) / rate_num; @@ -458,7 +458,7 @@ bool sample_rate_set(const uint32_t sample_rate_hz) { bool baseband_filter_bandwidth_set(const uint32_t bandwidth_hz) { uint32_t bandwidth_hz_real = max2837_set_lpf_bandwidth(&max2837, bandwidth_hz); - if(bandwidth_hz_real) hackrf_ui_setFilterBW(bandwidth_hz_real); + if(bandwidth_hz_real) hackrf_ui()->set_filter_bw(bandwidth_hz_real); return bandwidth_hz_real != 0; } diff --git a/firmware/common/rf_path.c b/firmware/common/rf_path.c index a854367ca..0e7bb42fd 100644 --- a/firmware/common/rf_path.c +++ b/firmware/common/rf_path.c @@ -391,7 +391,7 @@ void rf_path_set_direction(rf_path_t* const rf_path, const rf_path_direction_t d switchctrl_set(rf_path, rf_path->switchctrl); - hackrf_ui_setDirection(direction); + hackrf_ui()->set_direction(direction); } void rf_path_set_filter(rf_path_t* const rf_path, const rf_path_filter_t filter) { @@ -416,7 +416,7 @@ void rf_path_set_filter(rf_path_t* const rf_path, const rf_path_filter_t filter) switchctrl_set(rf_path, rf_path->switchctrl); - hackrf_ui_setFilter(filter); + hackrf_ui()->set_filter(filter); } void rf_path_set_lna(rf_path_t* const rf_path, const uint_fast8_t enable) { @@ -437,7 +437,7 @@ void rf_path_set_lna(rf_path_t* const rf_path, const uint_fast8_t enable) { switchctrl_set(rf_path, rf_path->switchctrl); - hackrf_ui_setLNAPower(enable); + hackrf_ui()->set_lna_power(enable); } /* antenna port power control */ @@ -450,5 +450,5 @@ void rf_path_set_antenna(rf_path_t* const rf_path, const uint_fast8_t enable) { switchctrl_set(rf_path, rf_path->switchctrl); - hackrf_ui_setAntennaBias(enable); + hackrf_ui()->set_antenna_bias(enable); } diff --git a/firmware/common/tuning.c b/firmware/common/tuning.c index 95ff7ed87..cfe09140d 100644 --- a/firmware/common/tuning.c +++ b/firmware/common/tuning.c @@ -115,7 +115,7 @@ bool set_freq(const uint64_t freq) max2837_set_mode(&max2837, prior_max2837_mode); if( success ) { freq_cache = freq; - hackrf_ui_setFrequency(freq); + hackrf_ui()->set_frequency(freq); #ifndef USER_INTERFACE_PORTAPACK operacake_set_range(freq_mhz); #endif diff --git a/firmware/common/ui_portapack.c b/firmware/common/ui_portapack.c index 0539f80f1..e88b131f8 100644 --- a/firmware/common/ui_portapack.c +++ b/firmware/common/ui_portapack.c @@ -1044,61 +1044,4 @@ const hackrf_ui_t* portapack_detect(void) { } } -static const hackrf_ui_t* ui = NULL; - -const hackrf_ui_t* hackrf_ui(void) { - return ui; -} - -void hackrf_ui_init(void) { - ui = portapack_detect(); - if( ui != NULL ) { - ui->init(); - } -} - -void hackrf_ui_setFrequency(uint64_t frequency) { - if( ui != NULL ) ui->set_frequency(frequency); -} - -void hackrf_ui_setSampleRate(uint32_t sample_rate) { - if( ui != NULL ) ui->set_sample_rate(sample_rate); -} - -void hackrf_ui_setDirection(const rf_path_direction_t direction) { - if( ui != NULL ) ui->set_direction(direction); -} - -void hackrf_ui_setFilterBW(uint32_t bw) { - if( ui != NULL ) ui->set_filter_bw(bw); -} - -void hackrf_ui_setLNAPower(bool lna_on) { - if( ui != NULL ) ui->set_lna_power(lna_on); -} - -void hackrf_ui_setBBLNAGain(const uint32_t gain_db) { - if( ui != NULL ) ui->set_bb_lna_gain(gain_db); -} - -void hackrf_ui_setBBVGAGain(const uint32_t gain_db) { - if( ui != NULL ) ui->set_bb_vga_gain(gain_db); -} - -void hackrf_ui_setBBTXVGAGain(const uint32_t gain_db) { - if( ui != NULL ) ui->set_bb_tx_vga_gain(gain_db); -} - -void hackrf_ui_setFirstIFFrequency(const uint64_t frequency) { - if( ui != NULL ) ui->set_first_if_frequency(frequency); -} - -void hackrf_ui_setFilter(const rf_path_filter_t filter) { - if( ui != NULL ) ui->set_filter(filter); -} - -void hackrf_ui_setAntennaBias(bool antenna_bias) { - if( ui != NULL ) ui->set_antenna_bias(antenna_bias); -} - #endif diff --git a/firmware/common/ui_portapack.h b/firmware/common/ui_portapack.h index d4ddda18d..0d2fc58eb 100644 --- a/firmware/common/ui_portapack.h +++ b/firmware/common/ui_portapack.h @@ -56,4 +56,6 @@ typedef struct ui_font_t { size_t data_stride; } ui_font_t; +const hackrf_ui_t* portapack_detect(void); + #endif/*__UI_PORTAPACK_H__*/ diff --git a/firmware/hackrf-common.cmake b/firmware/hackrf-common.cmake index 5604ad8b9..d2d2eded0 100644 --- a/firmware/hackrf-common.cmake +++ b/firmware/hackrf-common.cmake @@ -151,6 +151,12 @@ macro(DeclareTargets) ${SRC_M4} ${PATH_HACKRF_FIRMWARE_COMMON}/rffc5071.c ${PATH_HACKRF_FIRMWARE_COMMON}/rffc5071_spi.c + ${PATH_HACKRF_FIRMWARE_COMMON}/cpld_jtag.c + ${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/lenval.c + ${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/micro.c + ${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/ports.c + ${PATH_HACKRF_FIRMWARE_COMMON}/hackrf-ui.c + ${PATH_HACKRF_FIRMWARE_COMMON}/ui_portapack.c ) endif() diff --git a/firmware/hackrf_usb/CMakeLists.txt b/firmware/hackrf_usb/CMakeLists.txt index 67ddb20ab..b8fb35773 100644 --- a/firmware/hackrf_usb/CMakeLists.txt +++ b/firmware/hackrf_usb/CMakeLists.txt @@ -46,21 +46,10 @@ set(SRC_M4 usb_api_sweep.c "${PATH_HACKRF_FIRMWARE_COMMON}/usb_queue.c" "${PATH_HACKRF_FIRMWARE_COMMON}/fault_handler.c" - "${PATH_HACKRF_FIRMWARE_COMMON}/cpld_jtag.c" "${PATH_HACKRF_FIRMWARE_COMMON}/cpld_xc2c.c" "${PATH_HACKRF_FIRMWARE_COMMON}/crc.c" - "${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/lenval.c" - "${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/micro.c" - "${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/ports.c" "${PATH_HACKRF_FIRMWARE_COMMON}/rom_iap.c" "${PATH_HACKRF_FIRMWARE_COMMON}/operacake.c" ) -if(USER_INTERFACE STREQUAL "PORTAPACK") - SET(SRC_M4 - ${SRC_M4} - "${PATH_HACKRF_FIRMWARE_COMMON}/ui_portapack.c" - ) -endif() - DeclareTargets() diff --git a/firmware/hackrf_usb/hackrf_usb.c b/firmware/hackrf_usb/hackrf_usb.c index 8bb8b4170..957f58d8a 100644 --- a/firmware/hackrf_usb/hackrf_usb.c +++ b/firmware/hackrf_usb/hackrf_usb.c @@ -239,7 +239,7 @@ int main(void) { nvic_set_priority(NVIC_USB0_IRQ, 255); - hackrf_ui_init(); + hackrf_ui()->init(); usb_run(&usb_device); diff --git a/firmware/hackrf_usb/usb_api_transceiver.c b/firmware/hackrf_usb/usb_api_transceiver.c index c2e17518b..fda9b6a96 100644 --- a/firmware/hackrf_usb/usb_api_transceiver.c +++ b/firmware/hackrf_usb/usb_api_transceiver.c @@ -153,7 +153,7 @@ usb_request_status_t usb_vendor_request_set_lna_gain( if( stage == USB_TRANSFER_STAGE_SETUP ) { const uint8_t value = max2837_set_lna_gain(&max2837, endpoint->setup.index); endpoint->buffer[0] = value; - if(value) hackrf_ui_setBBLNAGain(endpoint->setup.index); + if(value) hackrf_ui()->set_bb_lna_gain(endpoint->setup.index); usb_transfer_schedule_block(endpoint->in, &endpoint->buffer, 1, NULL, NULL); usb_transfer_schedule_ack(endpoint->out); @@ -168,7 +168,7 @@ usb_request_status_t usb_vendor_request_set_vga_gain( if( stage == USB_TRANSFER_STAGE_SETUP ) { const uint8_t value = max2837_set_vga_gain(&max2837, endpoint->setup.index); endpoint->buffer[0] = value; - if(value) hackrf_ui_setBBVGAGain(endpoint->setup.index); + if(value) hackrf_ui()->set_bb_vga_gain(endpoint->setup.index); usb_transfer_schedule_block(endpoint->in, &endpoint->buffer, 1, NULL, NULL); usb_transfer_schedule_ack(endpoint->out); @@ -183,7 +183,7 @@ usb_request_status_t usb_vendor_request_set_txvga_gain( if( stage == USB_TRANSFER_STAGE_SETUP ) { const uint8_t value = max2837_set_txvga_gain(&max2837, endpoint->setup.index); endpoint->buffer[0] = value; - if(value) hackrf_ui_setBBTXVGAGain(endpoint->setup.index); + if(value) hackrf_ui()->set_bb_tx_vga_gain(endpoint->setup.index); usb_transfer_schedule_block(endpoint->in, &endpoint->buffer, 1, NULL, NULL); usb_transfer_schedule_ack(endpoint->out); From 8bc8bc13f0bc3193a26de80a19cb1a879afcdfb8 Mon Sep 17 00:00:00 2001 From: Jared Boone Date: Fri, 1 Feb 2019 21:37:54 +0000 Subject: [PATCH 06/10] PortaPack: Remove conditional PortaPack code. TODO: DFU mode returns. I fear HackRF mode in PortaPack/HAVOC will not work. --- firmware/README | 5 ----- firmware/common/cpld_jtag.c | 6 ------ firmware/common/cpld_jtag.h | 2 -- firmware/common/hackrf_core.c | 8 -------- firmware/common/hackrf_core.h | 7 ++----- firmware/common/tuning.c | 2 -- firmware/common/ui_portapack.c | 4 ---- firmware/hackrf-common.cmake | 15 ++------------- 8 files changed, 4 insertions(+), 45 deletions(-) diff --git a/firmware/README b/firmware/README index fc398a6bb..55ee089f3 100644 --- a/firmware/README +++ b/firmware/README @@ -31,11 +31,6 @@ $ hackrf_spiflash -w hackrf_usb.bin If you have a Jawbreaker, add -DBOARD=JAWBREAKER to the cmake command. If you have a rad1o, use -DBOARD=RAD1O instead. -If you have a HackRF One and want to build optional PortaPack display support, -also specify -DUSER_INTERFACE=PORTAPACK. If PortaPack hardware is not detected -by hardware probing at start-up, the HackRF firmware will run without UI -support. - It is possible to use a USB Device Firmware Upgrade (DFU) method to load firmware into RAM. This is normally only required to recover a device that has had faulty firmware loaded, but it can also be useful for firmware developers. diff --git a/firmware/common/cpld_jtag.c b/firmware/common/cpld_jtag.c index 5edcc67a6..b07d9b54c 100644 --- a/firmware/common/cpld_jtag.c +++ b/firmware/common/cpld_jtag.c @@ -35,18 +35,14 @@ void cpld_jtag_take(jtag_t* const jtag) { /* Set initial GPIO state to the voltages of the internal or external pull-ups/downs, * to avoid any glitches. */ -#ifdef USER_INTERFACE_PORTAPACK gpio_set(gpio->gpio_pp_tms); -#endif gpio_set(gpio->gpio_tms); gpio_set(gpio->gpio_tdi); gpio_clear(gpio->gpio_tck); -#ifdef USER_INTERFACE_PORTAPACK /* Do not drive PortaPack-specific TMS pin initially, just to be cautious. */ gpio_input(gpio->gpio_pp_tms); gpio_input(gpio->gpio_pp_tdo); -#endif gpio_output(gpio->gpio_tms); gpio_output(gpio->gpio_tdi); gpio_output(gpio->gpio_tck); @@ -59,11 +55,9 @@ void cpld_jtag_release(jtag_t* const jtag) { /* Make all pins inputs when JTAG interface not active. * Let the pull-ups/downs do the work. */ -#ifdef USER_INTERFACE_PORTAPACK /* Do not drive PortaPack-specific pins, initially, just to be cautious. */ gpio_input(gpio->gpio_pp_tms); gpio_input(gpio->gpio_pp_tdo); -#endif gpio_input(gpio->gpio_tms); gpio_input(gpio->gpio_tdi); gpio_input(gpio->gpio_tck); diff --git a/firmware/common/cpld_jtag.h b/firmware/common/cpld_jtag.h index 14500824f..1b62b4749 100644 --- a/firmware/common/cpld_jtag.h +++ b/firmware/common/cpld_jtag.h @@ -31,10 +31,8 @@ typedef struct jtag_gpio_t { gpio_t gpio_tck; gpio_t gpio_tdi; gpio_t gpio_tdo; -#ifdef USER_INTERFACE_PORTAPACK gpio_t gpio_pp_tms; gpio_t gpio_pp_tdo; -#endif } jtag_gpio_t; typedef struct jtag_t { diff --git a/firmware/common/hackrf_core.c b/firmware/common/hackrf_core.c index 68ddf161f..fbc2191ec 100644 --- a/firmware/common/hackrf_core.c +++ b/firmware/common/hackrf_core.c @@ -124,10 +124,8 @@ static struct gpio_t gpio_cpld_tms = GPIO(3, 1); static struct gpio_t gpio_cpld_tdi = GPIO(3, 4); #endif -#ifdef USER_INTERFACE_PORTAPACK static struct gpio_t gpio_cpld_pp_tms = GPIO(1, 1); static struct gpio_t gpio_cpld_pp_tdo = GPIO(1, 8); -#endif static struct gpio_t gpio_hw_sync_enable = GPIO(5,12); static struct gpio_t gpio_rx_q_invert = GPIO(0, 13); @@ -276,10 +274,8 @@ jtag_gpio_t jtag_gpio_cpld = { .gpio_tck = &gpio_cpld_tck, .gpio_tdi = &gpio_cpld_tdi, .gpio_tdo = &gpio_cpld_tdo, -#ifdef USER_INTERFACE_PORTAPACK .gpio_pp_tms = &gpio_cpld_pp_tms, .gpio_pp_tdo = &gpio_cpld_pp_tdo, -#endif }; jtag_t jtag_cpld = { @@ -777,10 +773,8 @@ void pin_setup(void) { * * LPC43xx pull-up and pull-down resistors are approximately 53K. */ -#ifdef USER_INTERFACE_PORTAPACK scu_pinmux(SCU_PINMUX_PP_TMS, SCU_GPIO_PUP | SCU_CONF_FUNCTION0); scu_pinmux(SCU_PINMUX_PP_TDO, SCU_GPIO_PDN | SCU_CONF_FUNCTION0); -#endif scu_pinmux(SCU_PINMUX_CPLD_TMS, SCU_GPIO_NOPULL | SCU_CONF_FUNCTION0); scu_pinmux(SCU_PINMUX_CPLD_TDI, SCU_GPIO_NOPULL | SCU_CONF_FUNCTION0); scu_pinmux(SCU_PINMUX_CPLD_TDO, SCU_GPIO_PDN | SCU_CONF_FUNCTION4); @@ -818,12 +812,10 @@ void pin_setup(void) { /* Configure RF power supply (VAA) switch control signal as output */ gpio_output(&gpio_vaa_disable); -#ifndef USER_INTERFACE_PORTAPACK /* Not sure why this is necessary for stock HackRF. Just "rhyming" with the RAD1O code? */ scu_pinmux(SCU_PINMUX_GPIO3_10, SCU_GPIO_PDN | SCU_CONF_FUNCTION0); scu_pinmux(SCU_PINMUX_GPIO3_11, SCU_GPIO_PDN | SCU_CONF_FUNCTION0); #endif -#endif #ifdef RAD1O /* Safe state: start with VAA turned off: */ diff --git a/firmware/common/hackrf_core.h b/firmware/common/hackrf_core.h index b30cfdff9..6ce543cc1 100644 --- a/firmware/common/hackrf_core.h +++ b/firmware/common/hackrf_core.h @@ -77,16 +77,13 @@ extern "C" /* GPIO Input PinMux */ #define SCU_PINMUX_BOOT0 (P1_1) /* GPIO0[8] on P1_1 */ #define SCU_PINMUX_BOOT1 (P1_2) /* GPIO0[9] on P1_2 */ -#ifdef USER_INTERFACE_PORTAPACK +#define SCU_PINMUX_BOOT2 (P2_8) /* GPIO5[7] on P2_8 */ +#define SCU_PINMUX_BOOT3 (P2_9) /* GPIO1[10] on P2_9 */ #define SCU_PINMUX_PP_LCD_TE (P2_3) /* GPIO5[3] on P2_3 */ #define SCU_PINMUX_PP_LCD_RDX (P2_4) /* GPIO5[4] on P2_4 */ #define SCU_PINMUX_PP_UNUSED (P2_8) /* GPIO5[7] on P2_8 */ #define SCU_PINMUX_PP_LCD_WRX (P2_9) /* GPIO1[10] on P2_9 */ #define SCU_PINMUX_PP_DIR (P2_13) /* GPIO1[13] on P2_13 */ -#else -#define SCU_PINMUX_BOOT2 (P2_8) /* GPIO5[7] on P2_8 */ -#define SCU_PINMUX_BOOT3 (P2_9) /* GPIO1[10] on P2_9 */ -#endif /* USB peripheral */ #ifdef JAWBREAKER diff --git a/firmware/common/tuning.c b/firmware/common/tuning.c index cfe09140d..e584eaad3 100644 --- a/firmware/common/tuning.c +++ b/firmware/common/tuning.c @@ -116,9 +116,7 @@ bool set_freq(const uint64_t freq) if( success ) { freq_cache = freq; hackrf_ui()->set_frequency(freq); -#ifndef USER_INTERFACE_PORTAPACK operacake_set_range(freq_mhz); -#endif } return success; } diff --git a/firmware/common/ui_portapack.c b/firmware/common/ui_portapack.c index e88b131f8..e8430af1f 100644 --- a/firmware/common/ui_portapack.c +++ b/firmware/common/ui_portapack.c @@ -30,8 +30,6 @@ #include -#ifdef USER_INTERFACE_PORTAPACK - /* Pixel data within a font or bitmap byte is "reversed": LSB is left-most pixel. */ static const uint8_t font_fixed_8x16_glyph_data[] = { @@ -1043,5 +1041,3 @@ const hackrf_ui_t* portapack_detect(void) { return NULL; } } - -#endif diff --git a/firmware/hackrf-common.cmake b/firmware/hackrf-common.cmake index d2d2eded0..0d577251e 100644 --- a/firmware/hackrf-common.cmake +++ b/firmware/hackrf-common.cmake @@ -71,19 +71,11 @@ else() set(MCU_PARTNO LPC4330) endif() -if(BOARD STREQUAL "RAD1O") - set(USER_INTERFACE RAD1O) -endif() - -if(NOT DEFINED USER_INTERFACE) - set(USER_INTERFACE NONE) -endif() - if(NOT DEFINED SRC_M0) set(SRC_M0 "${PATH_HACKRF_FIRMWARE_COMMON}/m0_sleep.c") endif() -SET(HACKRF_OPTS "-D${BOARD} -DUSER_INTERFACE_${USER_INTERFACE} -DLPC43XX -D${MCU_PARTNO} -DTX_ENABLE -D'VERSION_STRING=\"${VERSION}\"'") +SET(HACKRF_OPTS "-D${BOARD} -DLPC43XX -D${MCU_PARTNO} -DTX_ENABLE -D'VERSION_STRING=\"${VERSION}\"'") SET(LDSCRIPT_M4 "-T${PATH_HACKRF_FIRMWARE_COMMON}/${MCU_PARTNO}_M4_memory.ld -Tlibopencm3_lpc43xx_rom_to_ram.ld -T${PATH_HACKRF_FIRMWARE_COMMON}/LPC43xx_M4_M0_image_from_text.ld") @@ -108,10 +100,7 @@ SET(CFLAGS_M4 "-std=gnu99 ${CFLAGS_COMMON} ${CPUFLAGS_M4} -DLPC43XX_M4") SET(CXXFLAGS_M4 "-std=gnu++0x ${CFLAGS_COMMON} ${CPUFLAGS_M4} -DLPC43XX_M4") SET(LDFLAGS_M4 "${LDFLAGS_COMMON} ${CPUFLAGS_M4} ${LDSCRIPT_M4} -Xlinker -Map=m4.map") -SET(CFLAGS_M4_DFU "-std=gnu99 ${CFLAGS_COMMON} ${CPUFLAGS_M4} -DLPC43XX_M4") -if(NOT USER_INTERFACE STREQUAL "PORTAPACK") - SET(CFLAGS_M4_DFU "${CFLAGS_M4_DFU} -DDFU_MODE") -endif() +SET(CFLAGS_M4_DFU "-std=gnu99 ${CFLAGS_COMMON} ${CPUFLAGS_M4} -DLPC43XX_M4 -DDFU_MODE") SET(LDFLAGS_M4_DFU "${LDFLAGS_COMMON} ${CPUFLAGS_M4} ${LDSCRIPT_M4_DFU} -Xlinker -Map=m4.map") set(BUILD_SHARED_LIBS OFF) From 4fefd829ba02f42f81e2d0c52369158f01965fd5 Mon Sep 17 00:00:00 2001 From: Jared Boone Date: Fri, 1 Mar 2019 17:16:46 -0800 Subject: [PATCH 07/10] CMake: Fix blinky and rad1o dependencies and PortaPack-related breakage. --- firmware/common/hackrf-ui.c | 6 +++++- firmware/hackrf-common.cmake | 7 +------ firmware/hackrf_usb/CMakeLists.txt | 11 +++++++++++ 3 files changed, 17 insertions(+), 7 deletions(-) diff --git a/firmware/common/hackrf-ui.c b/firmware/common/hackrf-ui.c index 0b85e7777..079cfd9e7 100644 --- a/firmware/common/hackrf-ui.c +++ b/firmware/common/hackrf-ui.c @@ -59,12 +59,16 @@ static const hackrf_ui_t hackrf_ui_null = { &hackrf_ui_set_antenna_bias_null, }; +const hackrf_ui_t* portapack_detect(void) __attribute__((weak)); + static const hackrf_ui_t* ui = NULL; const hackrf_ui_t* hackrf_ui(void) { /* Detect on first use. If no UI hardware is detected, use a stub function table. */ if( ui == NULL ) { - ui = portapack_detect(); + if( portapack_detect ) { + ui = portapack_detect(); + } if( ui == NULL ) { ui = &hackrf_ui_null; } diff --git a/firmware/hackrf-common.cmake b/firmware/hackrf-common.cmake index 0d577251e..88b83b770 100644 --- a/firmware/hackrf-common.cmake +++ b/firmware/hackrf-common.cmake @@ -127,6 +127,7 @@ macro(DeclareTargets) ${PATH_HACKRF_FIRMWARE_COMMON}/spi_bus.c ${PATH_HACKRF_FIRMWARE_COMMON}/spi_ssp.c ${PATH_HACKRF_FIRMWARE_COMMON}/gpio_lpc.c + ${PATH_HACKRF_FIRMWARE_COMMON}/hackrf-ui.c ) if(BOARD STREQUAL "RAD1O") @@ -140,12 +141,6 @@ macro(DeclareTargets) ${SRC_M4} ${PATH_HACKRF_FIRMWARE_COMMON}/rffc5071.c ${PATH_HACKRF_FIRMWARE_COMMON}/rffc5071_spi.c - ${PATH_HACKRF_FIRMWARE_COMMON}/cpld_jtag.c - ${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/lenval.c - ${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/micro.c - ${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/ports.c - ${PATH_HACKRF_FIRMWARE_COMMON}/hackrf-ui.c - ${PATH_HACKRF_FIRMWARE_COMMON}/ui_portapack.c ) endif() diff --git a/firmware/hackrf_usb/CMakeLists.txt b/firmware/hackrf_usb/CMakeLists.txt index b8fb35773..5c9e39351 100644 --- a/firmware/hackrf_usb/CMakeLists.txt +++ b/firmware/hackrf_usb/CMakeLists.txt @@ -46,10 +46,21 @@ set(SRC_M4 usb_api_sweep.c "${PATH_HACKRF_FIRMWARE_COMMON}/usb_queue.c" "${PATH_HACKRF_FIRMWARE_COMMON}/fault_handler.c" + "${PATH_HACKRF_FIRMWARE_COMMON}/cpld_jtag.c" "${PATH_HACKRF_FIRMWARE_COMMON}/cpld_xc2c.c" + "${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/lenval.c" + "${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/micro.c" + "${PATH_HACKRF_FIRMWARE_COMMON}/xapp058/ports.c" "${PATH_HACKRF_FIRMWARE_COMMON}/crc.c" "${PATH_HACKRF_FIRMWARE_COMMON}/rom_iap.c" "${PATH_HACKRF_FIRMWARE_COMMON}/operacake.c" ) +if(NOT BOARD STREQUAL "RAD1O") + SET(SRC_M4 + ${SRC_M4} + "${PATH_HACKRF_FIRMWARE_COMMON}/ui_portapack.c" + ) +endif() + DeclareTargets() From f259c9aad6b410d17604e223eccf91f5f1394f5a Mon Sep 17 00:00:00 2001 From: Jared Boone Date: Sat, 2 Mar 2019 20:43:19 -0800 Subject: [PATCH 08/10] PortaPack: Add HackRF One gates for PortaPack JTAG and OperaCake code. I think these #defines might finally be the right shape... --- firmware/common/cpld_jtag.c | 6 ++++++ firmware/common/cpld_jtag.h | 2 ++ firmware/common/hackrf_core.c | 6 ++++++ firmware/common/hackrf_core.h | 2 ++ firmware/common/tuning.c | 2 ++ 5 files changed, 18 insertions(+) diff --git a/firmware/common/cpld_jtag.c b/firmware/common/cpld_jtag.c index b07d9b54c..f5a6cdb29 100644 --- a/firmware/common/cpld_jtag.c +++ b/firmware/common/cpld_jtag.c @@ -35,14 +35,18 @@ void cpld_jtag_take(jtag_t* const jtag) { /* Set initial GPIO state to the voltages of the internal or external pull-ups/downs, * to avoid any glitches. */ +#ifdef HACKRF_ONE gpio_set(gpio->gpio_pp_tms); +#endif gpio_set(gpio->gpio_tms); gpio_set(gpio->gpio_tdi); gpio_clear(gpio->gpio_tck); +#ifdef HACKRF_ONE /* Do not drive PortaPack-specific TMS pin initially, just to be cautious. */ gpio_input(gpio->gpio_pp_tms); gpio_input(gpio->gpio_pp_tdo); +#endif gpio_output(gpio->gpio_tms); gpio_output(gpio->gpio_tdi); gpio_output(gpio->gpio_tck); @@ -55,9 +59,11 @@ void cpld_jtag_release(jtag_t* const jtag) { /* Make all pins inputs when JTAG interface not active. * Let the pull-ups/downs do the work. */ +#ifdef HACKRF_ONE /* Do not drive PortaPack-specific pins, initially, just to be cautious. */ gpio_input(gpio->gpio_pp_tms); gpio_input(gpio->gpio_pp_tdo); +#endif gpio_input(gpio->gpio_tms); gpio_input(gpio->gpio_tdi); gpio_input(gpio->gpio_tck); diff --git a/firmware/common/cpld_jtag.h b/firmware/common/cpld_jtag.h index 1b62b4749..e0a303642 100644 --- a/firmware/common/cpld_jtag.h +++ b/firmware/common/cpld_jtag.h @@ -31,8 +31,10 @@ typedef struct jtag_gpio_t { gpio_t gpio_tck; gpio_t gpio_tdi; gpio_t gpio_tdo; +#ifdef HACKRF_ONE gpio_t gpio_pp_tms; gpio_t gpio_pp_tdo; +#endif } jtag_gpio_t; typedef struct jtag_t { diff --git a/firmware/common/hackrf_core.c b/firmware/common/hackrf_core.c index fbc2191ec..f55fdc2f3 100644 --- a/firmware/common/hackrf_core.c +++ b/firmware/common/hackrf_core.c @@ -124,8 +124,10 @@ static struct gpio_t gpio_cpld_tms = GPIO(3, 1); static struct gpio_t gpio_cpld_tdi = GPIO(3, 4); #endif +#ifdef HACKRF_ONE static struct gpio_t gpio_cpld_pp_tms = GPIO(1, 1); static struct gpio_t gpio_cpld_pp_tdo = GPIO(1, 8); +#endif static struct gpio_t gpio_hw_sync_enable = GPIO(5,12); static struct gpio_t gpio_rx_q_invert = GPIO(0, 13); @@ -274,8 +276,10 @@ jtag_gpio_t jtag_gpio_cpld = { .gpio_tck = &gpio_cpld_tck, .gpio_tdi = &gpio_cpld_tdi, .gpio_tdo = &gpio_cpld_tdo, +#ifdef HACKRF_ONE .gpio_pp_tms = &gpio_cpld_pp_tms, .gpio_pp_tdo = &gpio_cpld_pp_tdo, +#endif }; jtag_t jtag_cpld = { @@ -773,8 +777,10 @@ void pin_setup(void) { * * LPC43xx pull-up and pull-down resistors are approximately 53K. */ +#ifdef HACKRF_ONE scu_pinmux(SCU_PINMUX_PP_TMS, SCU_GPIO_PUP | SCU_CONF_FUNCTION0); scu_pinmux(SCU_PINMUX_PP_TDO, SCU_GPIO_PDN | SCU_CONF_FUNCTION0); +#endif scu_pinmux(SCU_PINMUX_CPLD_TMS, SCU_GPIO_NOPULL | SCU_CONF_FUNCTION0); scu_pinmux(SCU_PINMUX_CPLD_TDI, SCU_GPIO_NOPULL | SCU_CONF_FUNCTION0); scu_pinmux(SCU_PINMUX_CPLD_TDO, SCU_GPIO_PDN | SCU_CONF_FUNCTION4); diff --git a/firmware/common/hackrf_core.h b/firmware/common/hackrf_core.h index 6ce543cc1..90f20ad3e 100644 --- a/firmware/common/hackrf_core.h +++ b/firmware/common/hackrf_core.h @@ -77,8 +77,10 @@ extern "C" /* GPIO Input PinMux */ #define SCU_PINMUX_BOOT0 (P1_1) /* GPIO0[8] on P1_1 */ #define SCU_PINMUX_BOOT1 (P1_2) /* GPIO0[9] on P1_2 */ +#ifndef HACKRF_ONE #define SCU_PINMUX_BOOT2 (P2_8) /* GPIO5[7] on P2_8 */ #define SCU_PINMUX_BOOT3 (P2_9) /* GPIO1[10] on P2_9 */ +#endif #define SCU_PINMUX_PP_LCD_TE (P2_3) /* GPIO5[3] on P2_3 */ #define SCU_PINMUX_PP_LCD_RDX (P2_4) /* GPIO5[4] on P2_4 */ #define SCU_PINMUX_PP_UNUSED (P2_8) /* GPIO5[7] on P2_8 */ diff --git a/firmware/common/tuning.c b/firmware/common/tuning.c index e584eaad3..3c500eec7 100644 --- a/firmware/common/tuning.c +++ b/firmware/common/tuning.c @@ -116,7 +116,9 @@ bool set_freq(const uint64_t freq) if( success ) { freq_cache = freq; hackrf_ui()->set_frequency(freq); +#ifdef HACKRF_ONE operacake_set_range(freq_mhz); +#endif } return success; } From 5b5d82be562052f051136813fb3339a306a5f0fa Mon Sep 17 00:00:00 2001 From: Jared Boone Date: Sat, 2 Mar 2019 21:12:31 -0800 Subject: [PATCH 09/10] Build rad1o UI wrapper to patch the portapack one Also, fix building of blinky. --- firmware/common/hackrf-ui.c | 13 +++- firmware/common/ui_rad1o.c | 104 +++++++++++++++++++++++++++++++ firmware/common/ui_rad1o.h | 27 ++++++++ firmware/hackrf_usb/hackrf_usb.c | 4 ++ 4 files changed, 146 insertions(+), 2 deletions(-) create mode 100644 firmware/common/ui_rad1o.c create mode 100644 firmware/common/ui_rad1o.h diff --git a/firmware/common/hackrf-ui.c b/firmware/common/hackrf-ui.c index 079cfd9e7..8dd8715aa 100644 --- a/firmware/common/hackrf-ui.c +++ b/firmware/common/hackrf-ui.c @@ -22,6 +22,7 @@ #include "hackrf-ui.h" #include "ui_portapack.h" +#include "ui_rad1o.h" #include @@ -60,19 +61,27 @@ static const hackrf_ui_t hackrf_ui_null = { }; const hackrf_ui_t* portapack_detect(void) __attribute__((weak)); +const hackrf_ui_t* rad1o_ui_setup(void) __attribute__((weak)); static const hackrf_ui_t* ui = NULL; const hackrf_ui_t* hackrf_ui(void) { /* Detect on first use. If no UI hardware is detected, use a stub function table. */ if( ui == NULL ) { +#ifdef HACKRF_ONE if( portapack_detect ) { ui = portapack_detect(); } - if( ui == NULL ) { - ui = &hackrf_ui_null; +#endif +#ifdef RAD1O + if( rad1o_ui_setup ) { + ui = rad1o_ui_setup(); } +#endif } + if( ui == NULL ) { + ui = &hackrf_ui_null; + } return ui; } diff --git a/firmware/common/ui_rad1o.c b/firmware/common/ui_rad1o.c new file mode 100644 index 000000000..4d3b12544 --- /dev/null +++ b/firmware/common/ui_rad1o.c @@ -0,0 +1,104 @@ +/* + * Copyright 2019 Dominic Spill + * + * This file is part of HackRF. + * + * 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 2, 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; see the file COPYING. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, + * Boston, MA 02110-1301, USA. + */ + +#include "hackrf-ui.h" +#include "ui_rad1o.h" + +/* Weak functions from rad1o app */ +void hackrf_ui_init(void) __attribute__((weak)); +void hackrf_ui_setFrequency(uint64_t _freq) __attribute__((weak)); +void hackrf_ui_setSampleRate(uint32_t _sample_rate) __attribute__((weak)); +void hackrf_ui_setDirection(const rf_path_direction_t _direction) __attribute__((weak)); +void hackrf_ui_setFilterBW(uint32_t bw) __attribute__((weak)); +void hackrf_ui_setLNAPower(bool _lna_on) __attribute__((weak)); +void hackrf_ui_setBBLNAGain(const uint32_t gain_db) __attribute__((weak)); +void hackrf_ui_setBBVGAGain(const uint32_t gain_db) __attribute__((weak)); +void hackrf_ui_setBBTXVGAGain(const uint32_t gain_db) __attribute__((weak)); +void hackrf_ui_setFirstIFFrequency(const uint64_t freq) __attribute__((weak)); +void hackrf_ui_setFilter(const rf_path_filter_t filter) __attribute__((weak)); +void hackrf_ui_setAntennaBias(bool antenna_bias) __attribute__((weak)); + +static void rad1o_ui_init(void) { + hackrf_ui_init(); +} + +static void rad1o_ui_set_frequency(uint64_t frequency) { + hackrf_ui_setFrequency(frequency); +} + +static void rad1o_ui_set_sample_rate(uint32_t sample_rate) { + hackrf_ui_setSampleRate(sample_rate); +} + +static void rad1o_ui_set_direction(const rf_path_direction_t direction) { + hackrf_ui_setDirection(direction); +} + +static void rad1o_ui_set_filter_bw(uint32_t bandwidth) { + hackrf_ui_setFilterBW(bandwidth); +} + +static void rad1o_ui_set_lna_power(bool lna_on) { + hackrf_ui_setLNAPower(lna_on); +} + +static void rad1o_ui_set_bb_lna_gain(const uint32_t gain_db) { + hackrf_ui_setBBLNAGain(gain_db); +} + +static void rad1o_ui_set_bb_vga_gain(const uint32_t gain_db) { + hackrf_ui_setBBVGAGain(gain_db); +} + +static void rad1o_ui_set_bb_tx_vga_gain(const uint32_t gain_db) { + hackrf_ui_setBBTXVGAGain(gain_db); +} + +static void rad1o_ui_set_first_if_frequency(const uint64_t frequency) { + hackrf_ui_setFirstIFFrequency(frequency); +} + +static void rad1o_ui_set_filter(const rf_path_filter_t filter) { + hackrf_ui_setFilter(filter); +} + +static void rad1o_ui_set_antenna_bias(bool antenna_bias) { + hackrf_ui_setAntennaBias(antenna_bias); +} + +static const hackrf_ui_t rad1o_ui = { + &rad1o_ui_init, + &rad1o_ui_set_frequency, + &rad1o_ui_set_sample_rate, + &rad1o_ui_set_direction, + &rad1o_ui_set_filter_bw, + &rad1o_ui_set_lna_power, + &rad1o_ui_set_bb_lna_gain, + &rad1o_ui_set_bb_vga_gain, + &rad1o_ui_set_bb_tx_vga_gain, + &rad1o_ui_set_first_if_frequency, + &rad1o_ui_set_filter, + &rad1o_ui_set_antenna_bias, +}; + +const hackrf_ui_t* rad1o_ui_setup(void) { + return &rad1o_ui; +} diff --git a/firmware/common/ui_rad1o.h b/firmware/common/ui_rad1o.h new file mode 100644 index 000000000..6e658e5b0 --- /dev/null +++ b/firmware/common/ui_rad1o.h @@ -0,0 +1,27 @@ +/* + * Copyright 2019 Dominic Spill + * + * This file is part of HackRF. + * + * 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 2, 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; see the file COPYING. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, + * Boston, MA 02110-1301, USA. + */ + +#ifndef __UI_RAD1O_H__ +#define __UI_RAD1O_H__ + +const hackrf_ui_t* rad1o_ui_setup(void); + +#endif/*__UI_RAD1O_H__*/ diff --git a/firmware/hackrf_usb/hackrf_usb.c b/firmware/hackrf_usb/hackrf_usb.c index 957f58d8a..71f4d8ea0 100644 --- a/firmware/hackrf_usb/hackrf_usb.c +++ b/firmware/hackrf_usb/hackrf_usb.c @@ -139,7 +139,11 @@ static usb_request_handler_fn vendor_request_handler[] = { usb_vendor_request_spiflash_status, usb_vendor_request_spiflash_clear_status, usb_vendor_request_operacake_gpio_test, +#ifdef HACKRF_ONE usb_vendor_request_cpld_checksum, +#else + NULL, +#endif }; static const uint32_t vendor_request_handler_count = From 3af95903bc2fbb9bb1cd7784d79a3775740c574d Mon Sep 17 00:00:00 2001 From: Jared Boone Date: Sat, 2 Mar 2019 22:46:21 -0800 Subject: [PATCH 10/10] UI: No UI if not HackRF One or rad1o. This was breaking BOARD=JAWBREAKER builds. --- firmware/hackrf_usb/CMakeLists.txt | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/firmware/hackrf_usb/CMakeLists.txt b/firmware/hackrf_usb/CMakeLists.txt index 5c9e39351..0c34cf185 100644 --- a/firmware/hackrf_usb/CMakeLists.txt +++ b/firmware/hackrf_usb/CMakeLists.txt @@ -56,11 +56,18 @@ set(SRC_M4 "${PATH_HACKRF_FIRMWARE_COMMON}/operacake.c" ) -if(NOT BOARD STREQUAL "RAD1O") +if(BOARD STREQUAL "HACKRF_ONE") SET(SRC_M4 ${SRC_M4} "${PATH_HACKRF_FIRMWARE_COMMON}/ui_portapack.c" ) endif() +if(BOARD STREQUAL "RAD1O") + SET(SRC_M4 + ${SRC_M4} + "${PATH_HACKRF_FIRMWARE_COMMON}/ui_rad1o.c" + ) +endif() + DeclareTargets()