mirror of
https://github.com/fairwaves/UHD-Fairwaves.git
synced 2025-11-04 14:03:19 +00:00
Compare commits
10 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
2a89674c56 | ||
|
|
77e9066bf8 | ||
|
|
1e43f04790 | ||
|
|
cbff81745b | ||
|
|
57d5ca4b51 | ||
|
|
b78ceeb9b1 | ||
|
|
fcd92d8f50 | ||
|
|
2727f62ab8 | ||
|
|
75c3380ccf | ||
|
|
80e65f35cf |
13
debian/changelog
vendored
13
debian/changelog
vendored
@@ -1,3 +1,16 @@
|
|||||||
|
umtrx (1.0.5) trusty; urgency=low
|
||||||
|
|
||||||
|
* host: disable umtrx_fifo_ctrl cache of spi config
|
||||||
|
* host: Fix getters in umtrx_property_tree.py.
|
||||||
|
* debian: added firmware to package and umtrx_firmware script to handle it
|
||||||
|
* fpga: created axi stream controled spi core
|
||||||
|
* fpga: use axi stream spi core (still single dest)
|
||||||
|
* fpga: connect both spi settings drivers
|
||||||
|
* fpga: simplify spi setting regs with generate loop
|
||||||
|
* fpga: updated 4x ddc image for spi work
|
||||||
|
|
||||||
|
-- Kirill Zakharenko <earwin@gmail.com> Mon, 23 Nov 2015 15:51:56 +0300
|
||||||
|
|
||||||
umtrx (1.0.4) unstable; urgency=low
|
umtrx (1.0.4) unstable; urgency=low
|
||||||
|
|
||||||
* Do not add 'g' to a git id when creating a version string.
|
* Do not add 'g' to a git id when creating a version string.
|
||||||
|
|||||||
1
debian/umtrx.install
vendored
1
debian/umtrx.install
vendored
@@ -1 +1,2 @@
|
|||||||
usr/bin
|
usr/bin
|
||||||
|
images/u2plus_umtrx_v2.bin images/umtrx_txrx_uhd.bin usr/share/umtrx/firmware
|
||||||
|
|||||||
@@ -58,5 +58,6 @@ gpio_atr.v \
|
|||||||
user_settings.v \
|
user_settings.v \
|
||||||
settings_fifo_ctrl.v \
|
settings_fifo_ctrl.v \
|
||||||
simple_spi_core.v \
|
simple_spi_core.v \
|
||||||
|
axis_spi_core.v \
|
||||||
simple_i2c_core.v \
|
simple_i2c_core.v \
|
||||||
))
|
))
|
||||||
|
|||||||
243
fpga/control_lib/axis_spi_core.v
Normal file
243
fpga/control_lib/axis_spi_core.v
Normal file
@@ -0,0 +1,243 @@
|
|||||||
|
//
|
||||||
|
// Copyright 2012 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 <http://www.gnu.org/licenses/>.
|
||||||
|
//
|
||||||
|
|
||||||
|
// Simple SPI core, the simplest, yet complete spi core I can think of
|
||||||
|
|
||||||
|
// Settings register controlled.
|
||||||
|
// 2 settings regs, control and data
|
||||||
|
// 1 32-bit readback and status signal
|
||||||
|
|
||||||
|
// Settings reg map:
|
||||||
|
//
|
||||||
|
// BASE+0 divider setting
|
||||||
|
// bits [15:0] spi clock divider
|
||||||
|
//
|
||||||
|
// BASE+1 configuration input
|
||||||
|
// bits [23:0] slave select, bit0 = slave0 enabled
|
||||||
|
// bits [29:24] num bits (1 through 32)
|
||||||
|
// bit [30] data input edge = in data bit latched on rising edge of clock
|
||||||
|
// bit [31] data output edge = out data bit latched on rising edge of clock
|
||||||
|
//
|
||||||
|
// BASE+2 input data
|
||||||
|
// Writing this register begins a spi transaction.
|
||||||
|
// Bits are latched out from bit 0.
|
||||||
|
// Therefore, load this register in reverse.
|
||||||
|
//
|
||||||
|
// Readback
|
||||||
|
// Bits are latched into bit 0.
|
||||||
|
// Therefore, data will be in-order.
|
||||||
|
|
||||||
|
module axis_spi_core
|
||||||
|
#(
|
||||||
|
//set to 1 for ILA
|
||||||
|
parameter DEBUG = 0,
|
||||||
|
|
||||||
|
//tdest width for number of core users
|
||||||
|
parameter DESTW = 1,
|
||||||
|
|
||||||
|
//width of serial enables (up to 24 is possible)
|
||||||
|
parameter WIDTH = 8,
|
||||||
|
|
||||||
|
//idle state of the spi clock
|
||||||
|
parameter CLK_IDLE = 0,
|
||||||
|
|
||||||
|
//idle state of the serial enables
|
||||||
|
parameter SEN_IDLE = 24'hffffff
|
||||||
|
)
|
||||||
|
(
|
||||||
|
//clock and synchronous reset
|
||||||
|
input clock, input reset,
|
||||||
|
|
||||||
|
//configuration settings bus
|
||||||
|
input [DESTW-1:0] CONFIG_tdest,
|
||||||
|
input [79:0] CONFIG_tdata,
|
||||||
|
input CONFIG_tvalid,
|
||||||
|
output CONFIG_tready,
|
||||||
|
|
||||||
|
//32-bit data readback
|
||||||
|
output reg [DESTW-1:0] READBACK_tdest,
|
||||||
|
output [31:0] READBACK_tdata,
|
||||||
|
output READBACK_tvalid,
|
||||||
|
input READBACK_tready,
|
||||||
|
|
||||||
|
//spi interface, slave selects, clock, data in, data out
|
||||||
|
output [WIDTH-1:0] sen,
|
||||||
|
output sclk,
|
||||||
|
output mosi,
|
||||||
|
input miso
|
||||||
|
);
|
||||||
|
|
||||||
|
//state
|
||||||
|
localparam WAIT_CONFIG = 0;
|
||||||
|
localparam PRE_IDLE = 1;
|
||||||
|
localparam CLK_REG = 2;
|
||||||
|
localparam CLK_INV = 3;
|
||||||
|
localparam POST_IDLE = 4;
|
||||||
|
localparam IDLE_SEN = 5;
|
||||||
|
localparam WAIT_READBACK = 6;
|
||||||
|
reg [2:0] state;
|
||||||
|
|
||||||
|
//configuration settings
|
||||||
|
reg [15:0] sclk_divider;
|
||||||
|
reg [23:0] slave_select;
|
||||||
|
reg [5:0] num_bits;
|
||||||
|
reg datain_edge, dataout_edge;
|
||||||
|
|
||||||
|
//output ready/valid signals
|
||||||
|
assign CONFIG_tready = (state == WAIT_CONFIG);
|
||||||
|
assign READBACK_tvalid = (state == WAIT_READBACK);
|
||||||
|
|
||||||
|
//serial clock either idles or is in one of two clock states
|
||||||
|
reg sclk_reg;
|
||||||
|
assign sclk = sclk_reg;
|
||||||
|
|
||||||
|
//serial enables either idle or enabled based on state
|
||||||
|
wire sen_is_idle = (state == WAIT_CONFIG) || (state == IDLE_SEN);
|
||||||
|
wire [23:0] sen24 = (sen_is_idle)? SEN_IDLE : (SEN_IDLE ^ slave_select);
|
||||||
|
reg [WIDTH-1:0] sen_reg;
|
||||||
|
always @(posedge clock) sen_reg <= sen24[WIDTH-1:0];
|
||||||
|
assign sen = sen_reg;
|
||||||
|
|
||||||
|
//data output shift register
|
||||||
|
reg [31:0] dataout_reg;
|
||||||
|
wire [31:0] dataout_next = {dataout_reg[30:0], 1'b0};
|
||||||
|
assign mosi = dataout_reg[31];
|
||||||
|
|
||||||
|
//data input shift register
|
||||||
|
reg [31:0] datain_reg;
|
||||||
|
wire [31:0] datain_next = {datain_reg[30:0], miso};
|
||||||
|
assign READBACK_tdata = datain_reg;
|
||||||
|
|
||||||
|
//counter for spi clock
|
||||||
|
reg [15:0] sclk_counter;
|
||||||
|
wire sclk_counter_done = (sclk_counter == sclk_divider);
|
||||||
|
wire [15:0] sclk_counter_next = (sclk_counter_done)? 0 : sclk_counter + 1;
|
||||||
|
|
||||||
|
//counter for latching bits miso/mosi
|
||||||
|
reg [6:0] bit_counter;
|
||||||
|
wire [6:0] bit_counter_next = bit_counter + 1;
|
||||||
|
wire bit_counter_done = (bit_counter_next == num_bits);
|
||||||
|
|
||||||
|
always @(posedge clock) begin
|
||||||
|
if (reset) begin
|
||||||
|
state <= WAIT_CONFIG;
|
||||||
|
sclk_reg <= CLK_IDLE;
|
||||||
|
end
|
||||||
|
else begin
|
||||||
|
case (state)
|
||||||
|
|
||||||
|
WAIT_CONFIG: begin
|
||||||
|
if (CONFIG_tvalid && CONFIG_tready) begin
|
||||||
|
state <= PRE_IDLE;
|
||||||
|
end
|
||||||
|
{sclk_divider, dataout_edge, datain_edge, num_bits, slave_select, dataout_reg} <= CONFIG_tdata;
|
||||||
|
READBACK_tdest <= CONFIG_tdest;
|
||||||
|
sclk_counter <= 0;
|
||||||
|
bit_counter <= 0;
|
||||||
|
sclk_reg <= CLK_IDLE;
|
||||||
|
end
|
||||||
|
|
||||||
|
PRE_IDLE: begin
|
||||||
|
if (sclk_counter_done) state <= CLK_REG;
|
||||||
|
sclk_counter <= sclk_counter_next;
|
||||||
|
sclk_reg <= CLK_IDLE;
|
||||||
|
end
|
||||||
|
|
||||||
|
CLK_REG: begin
|
||||||
|
if (sclk_counter_done) begin
|
||||||
|
state <= CLK_INV;
|
||||||
|
if (datain_edge != CLK_IDLE) datain_reg <= datain_next;
|
||||||
|
if (dataout_edge != CLK_IDLE && bit_counter != 0) dataout_reg <= dataout_next;
|
||||||
|
sclk_reg <= ~CLK_IDLE; //transition to rising when CLK_IDLE == 0
|
||||||
|
end
|
||||||
|
sclk_counter <= sclk_counter_next;
|
||||||
|
end
|
||||||
|
|
||||||
|
CLK_INV: begin
|
||||||
|
if (sclk_counter_done) begin
|
||||||
|
state <= (bit_counter_done)? POST_IDLE : CLK_REG;
|
||||||
|
bit_counter <= bit_counter_next;
|
||||||
|
if (datain_edge == CLK_IDLE) datain_reg <= datain_next;
|
||||||
|
if (dataout_edge == CLK_IDLE && ~bit_counter_done) dataout_reg <= dataout_next;
|
||||||
|
sclk_reg <= CLK_IDLE; //transition to falling when CLK_IDLE == 0
|
||||||
|
end
|
||||||
|
sclk_counter <= sclk_counter_next;
|
||||||
|
end
|
||||||
|
|
||||||
|
POST_IDLE: begin
|
||||||
|
if (sclk_counter_done) state <= IDLE_SEN;
|
||||||
|
sclk_counter <= sclk_counter_next;
|
||||||
|
sclk_reg <= CLK_IDLE;
|
||||||
|
end
|
||||||
|
|
||||||
|
IDLE_SEN: begin
|
||||||
|
if (sclk_counter_done) state <= WAIT_READBACK;
|
||||||
|
sclk_counter <= sclk_counter_next;
|
||||||
|
sclk_reg <= CLK_IDLE;
|
||||||
|
end
|
||||||
|
|
||||||
|
WAIT_READBACK: begin
|
||||||
|
if (READBACK_tready && READBACK_tvalid) begin
|
||||||
|
state <= WAIT_CONFIG;
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
default: state <= WAIT_CONFIG;
|
||||||
|
|
||||||
|
endcase //state
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
/*******************************************************************
|
||||||
|
* Debug
|
||||||
|
******************************************************************/
|
||||||
|
generate
|
||||||
|
if (DEBUG == 1) begin
|
||||||
|
wire [35:0] CONTROL0;
|
||||||
|
chipscope_icon chipscope_icon
|
||||||
|
(
|
||||||
|
.CONTROL0(CONTROL0)
|
||||||
|
);
|
||||||
|
wire [255:0] DATA;
|
||||||
|
wire [7:0] TRIG0;
|
||||||
|
chipscope_ila chipscope_ila
|
||||||
|
(
|
||||||
|
.CONTROL(CONTROL0),
|
||||||
|
.CLK(clock),
|
||||||
|
.DATA(DATA),
|
||||||
|
.TRIG0(TRIG0)
|
||||||
|
);
|
||||||
|
assign TRIG0 =
|
||||||
|
{
|
||||||
|
4'b0,
|
||||||
|
CONFIG_tvalid, CONFIG_tready,
|
||||||
|
READBACK_tvalid, READBACK_tready
|
||||||
|
};
|
||||||
|
|
||||||
|
assign DATA[79:0] = CONFIG_tdata;
|
||||||
|
assign DATA[111:80] = READBACK_tdata;
|
||||||
|
|
||||||
|
assign DATA[112] = CONFIG_tvalid;
|
||||||
|
assign DATA[113] = CONFIG_tready;
|
||||||
|
assign DATA[114] = READBACK_tvalid;
|
||||||
|
assign DATA[115] = READBACK_tready;
|
||||||
|
|
||||||
|
assign DATA[127:120] = state;
|
||||||
|
end
|
||||||
|
endgenerate
|
||||||
|
|
||||||
|
endmodule //axis_spi_core
|
||||||
@@ -175,6 +175,10 @@ module umtrx_core
|
|||||||
wire [31:0] set_data, set_data_dsp, set_data_sys, set_data_fe, set_data_udp_wb, set_data_udp_sys;
|
wire [31:0] set_data, set_data_dsp, set_data_sys, set_data_fe, set_data_udp_wb, set_data_udp_sys;
|
||||||
wire set_stb, set_stb_dsp, set_stb_sys, set_stb_fe, set_stb_udp_wb, set_stb_udp_sys;
|
wire set_stb, set_stb_dsp, set_stb_sys, set_stb_fe, set_stb_udp_wb, set_stb_udp_sys;
|
||||||
|
|
||||||
|
wire set_stb_dsp0, set_stb_dsp1;
|
||||||
|
wire [31:0] set_data_dsp0, set_data_dsp1;
|
||||||
|
wire [7:0] set_addr_dsp0, set_addr_dsp1;
|
||||||
|
|
||||||
reg wb_rst;
|
reg wb_rst;
|
||||||
wire dsp_rst, sys_rst, fe_rst;
|
wire dsp_rst, sys_rst, fe_rst;
|
||||||
wire net_clr;
|
wire net_clr;
|
||||||
@@ -412,17 +416,80 @@ module umtrx_core
|
|||||||
|
|
||||||
// /////////////////////////////////////////////////////////////////////////
|
// /////////////////////////////////////////////////////////////////////////
|
||||||
// SPI -- Slave #2
|
// SPI -- Slave #2
|
||||||
wire [31:0] spi_debug;
|
reg [31:0] spi_readback0;
|
||||||
wire [31:0] spi_readback;
|
reg [31:0] spi_readback1;
|
||||||
wire spi_ready;
|
wire spi_ready;
|
||||||
simple_spi_core #(.BASE(SR_SPI_CORE), .WIDTH(5)) shared_spi(
|
|
||||||
|
wire [0:0] AXIS_SPI_CONFIG_tdest;
|
||||||
|
wire [79:0] AXIS_SPI_CONFIG_tdata;
|
||||||
|
wire AXIS_SPI_CONFIG_tvalid;
|
||||||
|
wire AXIS_SPI_CONFIG_tready;
|
||||||
|
|
||||||
|
wire [0:0] AXIS_SPI_READBACK_tdest;
|
||||||
|
wire [31:0] AXIS_SPI_READBACK_tdata;
|
||||||
|
wire AXIS_SPI_READBACK_tvalid;
|
||||||
|
wire AXIS_SPI_READBACK_tready;
|
||||||
|
|
||||||
|
axis_spi_core #(.DESTW(1), .WIDTH(5), .DEBUG(0)) axis_shared_spi(
|
||||||
.clock(dsp_clk), .reset(dsp_rst),
|
.clock(dsp_clk), .reset(dsp_rst),
|
||||||
.set_stb(set_stb_dsp), .set_addr(set_addr_dsp), .set_data(set_data_dsp),
|
|
||||||
.readback(spi_readback), .ready(spi_ready),
|
.CONFIG_tdest(AXIS_SPI_CONFIG_tdest),
|
||||||
|
.CONFIG_tdata(AXIS_SPI_CONFIG_tdata),
|
||||||
|
.CONFIG_tvalid(AXIS_SPI_CONFIG_tvalid),
|
||||||
|
.CONFIG_tready(AXIS_SPI_CONFIG_tready),
|
||||||
|
|
||||||
|
.READBACK_tdest(AXIS_SPI_READBACK_tdest),
|
||||||
|
.READBACK_tdata(AXIS_SPI_READBACK_tdata),
|
||||||
|
.READBACK_tvalid(AXIS_SPI_READBACK_tvalid),
|
||||||
|
.READBACK_tready(AXIS_SPI_READBACK_tready),
|
||||||
|
|
||||||
.sen({aux_sen2,aux_sen1,sen_dac,sen_lms2,sen_lms1}),
|
.sen({aux_sen2,aux_sen1,sen_dac,sen_lms2,sen_lms1}),
|
||||||
.sclk(sclk), .mosi(mosi), .miso(miso), .debug(spi_debug)
|
.sclk(sclk), .mosi(mosi), .miso(miso)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//setting register block for spi dest 0 (wishbone) and spi dest 1 (ctrl fifo)
|
||||||
|
//Note: the strobes are exclusive (settings fifo cross clock)
|
||||||
|
wire [79:0] spi_config [0:1];
|
||||||
|
wire [0:1] spi_trigger;
|
||||||
|
wire [0:1] set_stb_dsp_n = {set_stb_dsp0, set_stb_dsp1};
|
||||||
|
genvar i;
|
||||||
|
generate for (i=0; i <= 1; i=i+1) begin
|
||||||
|
setting_reg #(.my_addr(SR_SPI_CORE+2),.width(32)) axis_shared_spi_sr0(
|
||||||
|
.clk(dsp_clk),.rst(dsp_rst),.strobe(set_stb_dsp_n[i]),.addr(set_addr_dsp),.in(set_data_dsp),
|
||||||
|
.out(spi_config[i][31:0]),.changed(spi_trigger[i]));
|
||||||
|
|
||||||
|
setting_reg #(.my_addr(SR_SPI_CORE+1),.width(32)) axis_shared_spi_sr1(
|
||||||
|
.clk(dsp_clk),.rst(dsp_rst),.strobe(set_stb_dsp_n[i]),.addr(set_addr_dsp),.in(set_data_dsp),
|
||||||
|
.out(spi_config[i][63:32]),.changed());
|
||||||
|
|
||||||
|
setting_reg #(.my_addr(SR_SPI_CORE+0),.width(16)) axis_shared_spi_sr2(
|
||||||
|
.clk(dsp_clk),.rst(dsp_rst),.strobe(set_stb_dsp_n[i]),.addr(set_addr_dsp),.in(set_data_dsp),
|
||||||
|
.out(spi_config[i][79:64]),.changed());
|
||||||
|
end endgenerate
|
||||||
|
|
||||||
|
//assign config bus from setting register sources
|
||||||
|
//Note: the triggers are exclusive (settings fifo cross clock)
|
||||||
|
assign AXIS_SPI_CONFIG_tdest = (spi_trigger[0])?1'b0:1'b1;
|
||||||
|
assign AXIS_SPI_CONFIG_tdata = (spi_trigger[0])?spi_config[0]:spi_config[1];
|
||||||
|
assign AXIS_SPI_CONFIG_tvalid = (spi_trigger != 0);
|
||||||
|
|
||||||
|
//create spi ready to block the ctrl fifo ASAP
|
||||||
|
wire spi_ready_now = AXIS_SPI_CONFIG_tready && !AXIS_SPI_CONFIG_tvalid;
|
||||||
|
assign spi_ready = spi_ready_now && spi_ready_prev;
|
||||||
|
reg spi_ready_prev;
|
||||||
|
always @(posedge dsp_clk) begin
|
||||||
|
spi_ready_prev <= spi_ready_now;
|
||||||
|
end
|
||||||
|
|
||||||
|
//readback output bus latches values into readback register
|
||||||
|
assign AXIS_SPI_READBACK_tready = 1'b1;
|
||||||
|
always @(posedge dsp_clk) begin
|
||||||
|
if (AXIS_SPI_READBACK_tvalid && AXIS_SPI_READBACK_tready) begin
|
||||||
|
if (AXIS_SPI_READBACK_tdest == 1'b0) spi_readback0 <= AXIS_SPI_READBACK_tdata;
|
||||||
|
if (AXIS_SPI_READBACK_tdest == 1'b1) spi_readback1 <= AXIS_SPI_READBACK_tdata;
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
// /////////////////////////////////////////////////////////////////////////
|
// /////////////////////////////////////////////////////////////////////////
|
||||||
// I2C -- Slave #3
|
// I2C -- Slave #3
|
||||||
i2c_master_top #(.ARST_LVL(1))
|
i2c_master_top #(.ARST_LVL(1))
|
||||||
@@ -448,7 +515,7 @@ module umtrx_core
|
|||||||
// Buffer Pool Status -- Slave #5
|
// Buffer Pool Status -- Slave #5
|
||||||
|
|
||||||
//compatibility number -> increment when the fpga has been sufficiently altered
|
//compatibility number -> increment when the fpga has been sufficiently altered
|
||||||
localparam compat_num = {16'd9, 16'd1}; //major, minor
|
localparam compat_num = {16'd9, 16'd2}; //major, minor
|
||||||
|
|
||||||
wire [31:0] irq_readback = {16'b0, aux_ld2, aux_ld1, button, spi_ready, 12'b0};
|
wire [31:0] irq_readback = {16'b0, aux_ld2, aux_ld1, button, spi_ready, 12'b0};
|
||||||
|
|
||||||
@@ -456,7 +523,7 @@ module umtrx_core
|
|||||||
(.wb_clk_i(wb_clk), .wb_rst_i(wb_rst), .wb_stb_i(s5_stb),
|
(.wb_clk_i(wb_clk), .wb_rst_i(wb_rst), .wb_stb_i(s5_stb),
|
||||||
.wb_adr_i(s5_adr), .wb_dat_o(s5_dat_i), .wb_ack_o(s5_ack),
|
.wb_adr_i(s5_adr), .wb_dat_o(s5_dat_i), .wb_ack_o(s5_ack),
|
||||||
|
|
||||||
.word00(spi_readback),.word01(`NUMDDC),.word02(`NUMDUC),.word03(32'b0),
|
.word00(spi_readback0),.word01(`NUMDDC),.word02(`NUMDUC),.word03(32'b0),
|
||||||
.word04(32'b0),.word05(32'b0),.word06(32'b0),.word07(32'b0),
|
.word04(32'b0),.word05(32'b0),.word06(32'b0),.word07(32'b0),
|
||||||
.word08(status),.word09(32'b0),.word10(vita_time[63:32]),
|
.word08(status),.word09(32'b0),.word10(vita_time[63:32]),
|
||||||
.word11(vita_time[31:0]),.word12(compat_num),.word13(irq_readback),
|
.word11(vita_time[31:0]),.word12(compat_num),.word13(irq_readback),
|
||||||
@@ -498,10 +565,6 @@ module umtrx_core
|
|||||||
(.clk_i(dsp_clk), .rst_i(dsp_rst), .set_stb_i(set_stb_dsp), .set_addr_i(set_addr_dsp), .set_data_i(set_data_dsp),
|
(.clk_i(dsp_clk), .rst_i(dsp_rst), .set_stb_i(set_stb_dsp), .set_addr_i(set_addr_dsp), .set_data_i(set_data_dsp),
|
||||||
.clk_o(fe_clk), .rst_o(fe_rst), .set_stb_o(set_stb_fe), .set_addr_o(set_addr_fe), .set_data_o(set_data_fe));
|
.clk_o(fe_clk), .rst_o(fe_rst), .set_stb_o(set_stb_fe), .set_addr_o(set_addr_fe), .set_data_o(set_data_fe));
|
||||||
|
|
||||||
wire set_stb_dsp0, set_stb_dsp1;
|
|
||||||
wire [31:0] set_data_dsp0, set_data_dsp1;
|
|
||||||
wire [7:0] set_addr_dsp0, set_addr_dsp1;
|
|
||||||
|
|
||||||
//mux settings_bus_crossclock and settings_readback_bus_fifo_ctrl with prio
|
//mux settings_bus_crossclock and settings_readback_bus_fifo_ctrl with prio
|
||||||
assign set_stb_dsp = set_stb_dsp0 | set_stb_dsp1;
|
assign set_stb_dsp = set_stb_dsp0 | set_stb_dsp1;
|
||||||
assign set_addr_dsp = set_stb_dsp1? set_addr_dsp1 : set_addr_dsp0;
|
assign set_addr_dsp = set_stb_dsp1? set_addr_dsp1 : set_addr_dsp0;
|
||||||
@@ -542,7 +605,7 @@ module umtrx_core
|
|||||||
.in_data(ctrl_data_dsp), .in_valid(ctrl_valid_dsp), .in_ready(ctrl_ready_dsp),
|
.in_data(ctrl_data_dsp), .in_valid(ctrl_valid_dsp), .in_ready(ctrl_ready_dsp),
|
||||||
.out_data(resp_data_dsp), .out_valid(resp_valid_dsp), .out_ready(resp_ready_dsp),
|
.out_data(resp_data_dsp), .out_valid(resp_valid_dsp), .out_ready(resp_ready_dsp),
|
||||||
.strobe(set_stb_dsp1), .addr(set_addr_dsp1), .data(set_data_dsp1),
|
.strobe(set_stb_dsp1), .addr(set_addr_dsp1), .data(set_data_dsp1),
|
||||||
.word00(spi_readback),.word01(32'b0),.word02(32'b0),.word03(32'b0),
|
.word00(spi_readback1),.word01(32'b0),.word02(32'b0),.word03(32'b0),
|
||||||
.word04(32'b0),.word05(32'b0),.word06(32'b0),.word07(32'b0),
|
.word04(32'b0),.word05(32'b0),.word06(32'b0),.word07(32'b0),
|
||||||
.word08(32'b0),.word09(32'b0),.word10(vita_time[63:32]),
|
.word08(32'b0),.word09(32'b0),.word10(vita_time[63:32]),
|
||||||
.word11(vita_time[31:0]),.word12(32'b0),.word13(irq_readback),
|
.word11(vita_time[31:0]),.word12(32'b0),.word13(irq_readback),
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ INSTALL(PROGRAMS
|
|||||||
umtrx_nmea
|
umtrx_nmea
|
||||||
umtrx_gps_coord
|
umtrx_gps_coord
|
||||||
umtrx_auto_calibration
|
umtrx_auto_calibration
|
||||||
|
umtrx_firmware
|
||||||
DESTINATION bin
|
DESTINATION bin
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
16
host/utils/umtrx_firmware
Executable file
16
host/utils/umtrx_firmware
Executable file
@@ -0,0 +1,16 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
case word in
|
||||||
|
flash )
|
||||||
|
umtrx_net_burner --addr=192.168.10.2 --fpga=/usr/share/umtrx/firmware/u2plus_umtrx_v2.bin --fw=/usr/share/umtrx/firmware/umtrx_txrx_uhd.bin --reset
|
||||||
|
;;
|
||||||
|
check )
|
||||||
|
;;
|
||||||
|
* )
|
||||||
|
cat <<-EOF
|
||||||
|
Usage:
|
||||||
|
$0 flash - burn packaged firmware to umtrx
|
||||||
|
$0 check - compare versions of packaged firmware and one installed on umtrx
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
esac
|
||||||
@@ -51,8 +51,8 @@ class umtrx_property_tree:
|
|||||||
self._send_request('GET', path, value_type='DOUBLE')
|
self._send_request('GET', path, value_type='DOUBLE')
|
||||||
return self._recv_response()
|
return self._recv_response()
|
||||||
|
|
||||||
def query_sensor_raw(self, sensor_path):
|
def query_sensor_raw(self, path):
|
||||||
self._send_request('GET', sensor_path, value_type='SENSOR')
|
self._send_request('GET', path, value_type='SENSOR')
|
||||||
return self._recv_response()
|
return self._recv_response()
|
||||||
|
|
||||||
def query_range_raw(self, path):
|
def query_range_raw(self, path):
|
||||||
@@ -64,24 +64,24 @@ class umtrx_property_tree:
|
|||||||
#
|
#
|
||||||
|
|
||||||
def query_bool_value(self, path):
|
def query_bool_value(self, path):
|
||||||
res = self.query_bool_raw(sensor_path)
|
res = self.query_bool_raw(path)
|
||||||
return res['result']['value']
|
return res['result']['value']
|
||||||
|
|
||||||
def query_int_value(self, path):
|
def query_int_value(self, path):
|
||||||
res = self.query_int_raw(sensor_path)
|
res = self.query_int_raw(path)
|
||||||
return res['result']['value']
|
return res['result']['value']
|
||||||
|
|
||||||
def query_double_value(self, path):
|
def query_double_value(self, path):
|
||||||
res = self.query_double_raw(sensor_path)
|
res = self.query_double_raw(path)
|
||||||
return res['result']['value']
|
return res['result']['value']
|
||||||
|
|
||||||
def query_sensor_value(self, sensor_path):
|
def query_sensor_value(self, path):
|
||||||
res = self.query_sensor_raw(sensor_path)
|
res = self.query_sensor_raw(path)
|
||||||
return res['result']['value']
|
return res['result']['value']
|
||||||
|
|
||||||
def query_range_value(self, path):
|
def query_range_value(self, path):
|
||||||
res = self.query_range_raw(sensor_path)
|
res = self.query_range_raw(path)
|
||||||
return res['result']['value']
|
return res['result']
|
||||||
|
|
||||||
#
|
#
|
||||||
# Setters
|
# Setters
|
||||||
|
|||||||
Binary file not shown.
Binary file not shown.
Reference in New Issue
Block a user