aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormatt <matt@221aa14e-8319-0410-a670-987f0aec2ac5>2008-12-15 04:26:43 +0000
committermatt <matt@221aa14e-8319-0410-a670-987f0aec2ac5>2008-12-15 04:26:43 +0000
commit0c6c48651ad45dd6c835c94aad80d760400138ae (patch)
treec348f91006f3c592e1bfc9cc7e9c1f8038ae60e2
parent5b9d02869cf32c5220e1fc995ba5341a24acf0dc (diff)
downloaduhd-0c6c48651ad45dd6c835c94aad80d760400138ae.tar.gz
uhd-0c6c48651ad45dd6c835c94aad80d760400138ae.tar.bz2
uhd-0c6c48651ad45dd6c835c94aad80d760400138ae.zip
pps sync works, meets timing
git-svn-id: http://gnuradio.org/svn/gnuradio/trunk@10120 221aa14e-8319-0410-a670-987f0aec2ac5
-rw-r--r--timing/time_sync.v27
-rwxr-xr-xtop/u2_core/u2_core.v12
2 files changed, 26 insertions, 13 deletions
diff --git a/timing/time_sync.v b/timing/time_sync.v
index 04999190b..6b9848064 100644
--- a/timing/time_sync.v
+++ b/timing/time_sync.v
@@ -5,8 +5,11 @@ module time_sync
input cyc_i, input stb_i, input [2:0] adr_i,
input we_i, input [31:0] dat_i, output [31:0] dat_o, output ack_o,
input sys_clk_i, output [31:0] master_time_o,
- input pps_in, input exp_pps_in, output exp_pps_out,
- output reg int_o );
+ input pps_posedge, input pps_negedge,
+ input exp_pps_in, output exp_pps_out,
+ output reg int_o,
+ output reg epoch_o,
+ output reg pps_o );
wire [31:0] master_time_rcvd;
reg [31:0] master_time;
@@ -19,6 +22,7 @@ module time_sync
reg tick_int_enable, tick_source, external_sync;
reg [31:0] tick_interval;
reg sync_on_next_pps;
+ reg pps_edge;
// Generate master time
always @(posedge sys_clk_i)
@@ -57,6 +61,7 @@ module time_sync
external_sync <= 0;
tick_interval <= 100000-1; // default to 1K times per second
delta_time <= 0;
+ pps_edge <= 0;
end
else if(wb_write)
case(adr_i[2:0])
@@ -65,6 +70,7 @@ module time_sync
tick_source <= dat_i[0];
tick_int_enable <= dat_i[1];
external_sync <= dat_i[2];
+ pps_edge <= dat_i[3];
end
3'd1 :
tick_interval <= dat_i;
@@ -81,7 +87,7 @@ module time_sync
else if(pps_ext)
sync_on_next_pps <= 0;
else if(wb_write & (adr_i[2:0] == 3))
- sync_on_next_pps <= 0;
+ sync_on_next_pps <= 1;
always @(posedge sys_clk_i)
if(internal_tick)
@@ -109,11 +115,14 @@ module time_sync
reg pps_in_d1, pps_in_d2;
always @(posedge sys_clk_i)
begin
- pps_in_d1 <= pps_in;
+ pps_in_d1 <= pps_edge ? pps_posedge : pps_negedge;
pps_in_d2 <= pps_in_d1;
end
assign pps_ext = pps_in_d1 & ~pps_in_d2;
+ always @(posedge sys_clk_i)
+ pps_o <= pps_ext;
+
// Need to register this?
reg internal_tick_d1;
always @(posedge sys_clk_i) internal_tick_d1 <= internal_tick;
@@ -121,9 +130,15 @@ module time_sync
always @(posedge wb_clk_i)
if(rst_i)
int_o <= 0;
- else if(tick_int_enable & (internal_tick | internal_tick_d1))
+/*
+ else if(tick_int_enable & (internal_tick | internal_tick_d1))
int_o <= 1;
else
int_o <= 0;
-
+*/
+ always @(posedge sys_clk_i)
+ if(rst_i)
+ epoch_o <= 0;
+ else
+ epoch_o <= (master_time_o[27:0] == 0);
endmodule // time_sync
diff --git a/top/u2_core/u2_core.v b/top/u2_core/u2_core.v
index 0ecb378af..09fd6e7e5 100755
--- a/top/u2_core/u2_core.v
+++ b/top/u2_core/u2_core.v
@@ -565,11 +565,9 @@ module u2_core
.cyc_i(s12_cyc),.stb_i(s12_stb),.adr_i(s12_adr[4:2]),
.we_i(s12_we),.dat_i(s12_dat_o),.dat_o(s12_dat_i),.ack_o(s12_ack),
.sys_clk_i(dsp_clk),.master_time_o(master_time),
- //.pps_posedge(pps_posedge),.pps_negedge(pps_negedge),
- .pps_in(pps_negedge),
+ .pps_posedge(pps_posedge),.pps_negedge(pps_negedge),
.exp_pps_in(exp_pps_in),.exp_pps_out(exp_pps_out),
- //.int_o(pps_int),.epoch_o(epoch),.pps_o(pps_o) );
- .int_o(pps_int));
+ .int_o(pps_int),.epoch_o(epoch),.pps_o(pps_o) );
assign s12_err = 0;
assign s12_rty = 0;
@@ -710,11 +708,11 @@ module u2_core
assign debug_clk[0] = wb_clk;
assign debug_clk[1] = dsp_clk;
- assign debug = 0;
+ assign debug = 0; //master_time;
assign debug_gpio_0={{8'b0},
{8'b0},
- {8'b0},
- {1'b0,pps_o,pps_int,epoch,pps_pos_d1,pps_posedge,pps_neg_d1,pps_negedge}};
+ {4'b0,strobe_rx,run_rx,strobe_tx,run_tx},
+ {s12_ack,pps_o,pps_int,epoch,pps_pos_d1,pps_posedge,pps_neg_d1,pps_negedge}};
assign debug_gpio_1 = 0;
endmodule // u2_core