aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/lib/timing
diff options
context:
space:
mode:
Diffstat (limited to 'fpga/usrp3/lib/timing')
-rw-r--r--fpga/usrp3/lib/timing/Makefile.srcs12
-rw-r--r--fpga/usrp3/lib/timing/pps.v22
-rw-r--r--fpga/usrp3/lib/timing/time_compare.v51
-rw-r--r--fpga/usrp3/lib/timing/time_transfer_tb.v55
-rw-r--r--fpga/usrp3/lib/timing/timekeeper.v74
5 files changed, 0 insertions, 214 deletions
diff --git a/fpga/usrp3/lib/timing/Makefile.srcs b/fpga/usrp3/lib/timing/Makefile.srcs
deleted file mode 100644
index 09f0596c5..000000000
--- a/fpga/usrp3/lib/timing/Makefile.srcs
+++ /dev/null
@@ -1,12 +0,0 @@
-#
-# Copyright 2013 Ettus Research LLC
-#
-
-##################################################
-# Timing Sources
-##################################################
-TIMING_SRCS = $(abspath $(addprefix $(BASE_DIR)/../lib/timing/, \
-time_compare.v \
-timekeeper.v \
-pps.v\
-))
diff --git a/fpga/usrp3/lib/timing/pps.v b/fpga/usrp3/lib/timing/pps.v
deleted file mode 100644
index 49d3641b7..000000000
--- a/fpga/usrp3/lib/timing/pps.v
+++ /dev/null
@@ -1,22 +0,0 @@
-//
-// Copyright 2014 Ettus Research LLC
-//
-
-module pps_generator
- #(parameter CLK_FREQ=0, DUTY=25)
- (input clk, input reset, output pps);
-
- reg[31:0] count;
-
- always @(posedge clk) begin
- if (reset) begin
- count <= 32'b1;
- end else if (count >= CLK_FREQ) begin
- count <= 32'b1;
- end else begin
- count <= count + 1'b1;
- end
- end
-
- assign pps = (count < CLK_FREQ * DUTY / 100);
-endmodule //pps_generator
diff --git a/fpga/usrp3/lib/timing/time_compare.v b/fpga/usrp3/lib/timing/time_compare.v
deleted file mode 100644
index 272c41b65..000000000
--- a/fpga/usrp3/lib/timing/time_compare.v
+++ /dev/null
@@ -1,51 +0,0 @@
-//
-// Copyright 2011-2012 Ettus Research LLC
-//
-
-
-
-// 64 bits worth of ticks
-//
-// Not concerned with clock wrapping, human race will likely have extermintated it's self by this time.
-//
-
-module time_compare
- (
- input clk,
- input reset,
- input [63:0] time_now,
- input [63:0] trigger_time,
- output now,
- output early,
- output late,
- output too_early);
-
-/*
- reg [63:0] time_diff;
-
- always @(posedge clk) begin
- if (reset) begin
- time_diff <= 64'b0;
- now <= 1'b0;
- late <= 1'b0;
- early <= 1'b0;
- end
- else begin
- time_diff <= trigger_time - time_now;
- now <= ~(|time_diff);
- late <= time_diff[63];
- early <= ~now & ~late;
- end
- end
- //assign now = ~(|time_diff);
- //assign late = time_diff[63];
- //assign early = ~now & ~late;
- assign too_early = 0; //not implemented
-*/
-
- assign now = time_now == trigger_time;
- assign late = time_now > trigger_time;
- assign early = ~now & ~late;
- assign too_early = 0; //not implemented
-
-endmodule // time_compare
diff --git a/fpga/usrp3/lib/timing/time_transfer_tb.v b/fpga/usrp3/lib/timing/time_transfer_tb.v
deleted file mode 100644
index af1207605..000000000
--- a/fpga/usrp3/lib/timing/time_transfer_tb.v
+++ /dev/null
@@ -1,55 +0,0 @@
-//
-// Copyright 2011 Ettus Research LLC
-//
-
-
-
-`timescale 1ns / 1ps
-
-module time_transfer_tb();
-
- reg clk = 0, rst = 1;
- always #5 clk = ~clk;
-
- initial
- begin
- @(negedge clk);
- @(negedge clk);
- rst <= 0;
- end
-
- initial $dumpfile("time_transfer_tb.vcd");
- initial $dumpvars(0,time_transfer_tb);
-
- initial #100000000 $finish;
-
- wire exp_time, pps, pps_rcv;
- wire [63:0] vita_time_rcv;
- reg [63:0] vita_time = 0;
- reg [63:0] counter = 0;
-
- localparam PPS_PERIOD = 439; // PPS_PERIOD % 10 must = 9
- always @(posedge clk)
- if(counter == PPS_PERIOD)
- counter <= 0;
- else
- counter <= counter + 1;
- assign pps = (counter == (PPS_PERIOD-1));
-
- always @(posedge clk)
- vita_time <= vita_time + 1;
-
- time_sender time_sender
- (.clk(clk),.rst(rst),
- .vita_time(vita_time),
- .send_sync(pps),
- .exp_time_out(exp_time) );
-
- time_receiver time_receiver
- (.clk(clk),.rst(rst),
- .vita_time(vita_time_rcv),
- .sync_rcvd(pps_rcv),
- .exp_time_in(exp_time) );
-
- wire [31:0] delta = vita_time - vita_time_rcv;
-endmodule // time_transfer_tb
diff --git a/fpga/usrp3/lib/timing/timekeeper.v b/fpga/usrp3/lib/timing/timekeeper.v
deleted file mode 100644
index 761bda5bc..000000000
--- a/fpga/usrp3/lib/timing/timekeeper.v
+++ /dev/null
@@ -1,74 +0,0 @@
-//
-// Copyright 2013-2014 Ettus Research LLC
-//
-
-
-module timekeeper
- #(parameter BASE = 0)
- (input clk, input reset, input pps,
- input set_stb, input [7:0] set_addr, input [31:0] set_data,
- output reg [63:0] vita_time, output reg [63:0] vita_time_lastpps);
-
- //////////////////////////////////////////////////////////////////////////
- // timer settings for this module
- //////////////////////////////////////////////////////////////////////////
- wire [63:0] time_at_next_event;
- wire set_time_pps, set_time_now;
- wire cmd_trigger;
-
- setting_reg #(.my_addr(BASE), .width()) sr_time_hi
- (.clk(clk), .rst(reset), .strobe(set_stb), .addr(set_addr), .in(set_data),
- .out(time_at_next_event[63:32]), .changed());
-
- setting_reg #(.my_addr(BASE+1), .width()) sr_time_lo
- (.clk(clk), .rst(reset), .strobe(set_stb), .addr(set_addr), .in(set_data),
- .out(time_at_next_event[31:0]), .changed());
-
- setting_reg #(.my_addr(BASE+2), .width(2)) sr_ctrl
- (.clk(clk), .rst(reset), .strobe(set_stb), .addr(set_addr), .in(set_data),
- .out({set_time_pps, set_time_now}), .changed(cmd_trigger));
-
- //////////////////////////////////////////////////////////////////////////
- // PPS edge detection logic
- //////////////////////////////////////////////////////////////////////////
- reg pps_del, pps_del2;
- always @(posedge clk)
- {pps_del2,pps_del} <= {pps_del, pps};
-
- wire pps_edge = !pps_del2 & pps_del;
-
- //////////////////////////////////////////////////////////////////////////
- // arm the trigger to latch a new time when the ctrl register is written
- //////////////////////////////////////////////////////////////////////////
- reg armed;
- wire time_event = armed && ((set_time_now) || (set_time_pps && pps_edge));
- always @(posedge clk) begin
- if (reset) armed <= 1'b0;
- else if (cmd_trigger) armed <= 1'b1;
- else if (time_event) armed <= 1'b0;
- end
-
- //////////////////////////////////////////////////////////////////////////
- // vita time tracker - update every tick or when we get an "event"
- //////////////////////////////////////////////////////////////////////////
- always @(posedge clk)
- if(reset)
- vita_time <= 64'h0;
- else if (time_event)
- vita_time <= time_at_next_event;
- else
- vita_time <= vita_time + 64'h1;
-
- //////////////////////////////////////////////////////////////////////////
- // track the time at last pps so host can detect the pps
- //////////////////////////////////////////////////////////////////////////
- always @(posedge clk)
- if(reset)
- vita_time_lastpps <= 64'h0;
- else if(pps_edge)
- if(time_event)
- vita_time_lastpps <= time_at_next_event;
- else
- vita_time_lastpps <= vita_time + 64'h1;
-
-endmodule // timekeeper