aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/sim/serial_to_settings/serial_settings_tasks.v
diff options
context:
space:
mode:
authorBen Hilburn <ben.hilburn@ettus.com>2014-02-14 12:05:07 -0800
committerBen Hilburn <ben.hilburn@ettus.com>2014-02-14 12:05:07 -0800
commitff1546f8137f7f92bb250f685561b0c34cc0e053 (patch)
tree7fa6fd05c8828df256a1b20e2935bd3ba9899e2c /fpga/usrp3/sim/serial_to_settings/serial_settings_tasks.v
parent4f691d88123784c2b405816925f1a1aef69d18c1 (diff)
downloaduhd-ff1546f8137f7f92bb250f685561b0c34cc0e053.tar.gz
uhd-ff1546f8137f7f92bb250f685561b0c34cc0e053.tar.bz2
uhd-ff1546f8137f7f92bb250f685561b0c34cc0e053.zip
Pushing the bulk of UHD-3.7.0 code.
Diffstat (limited to 'fpga/usrp3/sim/serial_to_settings/serial_settings_tasks.v')
-rw-r--r--fpga/usrp3/sim/serial_to_settings/serial_settings_tasks.v59
1 files changed, 59 insertions, 0 deletions
diff --git a/fpga/usrp3/sim/serial_to_settings/serial_settings_tasks.v b/fpga/usrp3/sim/serial_to_settings/serial_settings_tasks.v
new file mode 100644
index 000000000..a9e2c0344
--- /dev/null
+++ b/fpga/usrp3/sim/serial_to_settings/serial_settings_tasks.v
@@ -0,0 +1,59 @@
+
+ task serial_settings_transaction;
+ input [7:0] address;
+ input [31:0] data;
+
+ integer x;
+
+ begin
+ scl_r <= 1'b1;
+ sda_r <= 1'b1;
+ @(negedge clk);
+ @(negedge clk);
+ // Drive SDA low whilst SCL high to signal START
+ sda_r <= 1'b0;
+ @(negedge clk);
+ @(negedge clk);
+ // Send 8 Address bits MSB first on falling edge of SCL clocks
+ for (x = 7; x >= 0; x = x - 1)
+ serial_settings_bit(address[x]);
+ // Send 32 Data bits MSB first on falling edge of SCL clocks
+ for (x = 31; x >= 0; x = x - 1)
+ serial_settings_bit(data[x]);
+ // Send STOP.
+ scl_r <= 1'b0;
+ sda_r <= 1'b0;
+ @(negedge clk);
+ @(negedge clk);
+ @(negedge clk);
+ @(negedge clk);
+ scl_r <= 1'b1;
+ @(negedge clk);
+ @(negedge clk);
+ @(negedge clk);
+ @(negedge clk);
+ sda_r <= 1'b1;
+ @(negedge clk);
+ @(negedge clk);
+ @(negedge clk);
+ @(negedge clk);
+ end
+ endtask // serial_settings_transaction
+
+ task serial_settings_bit;
+ input one_bit;
+
+ begin
+ scl_r <= 1'b0;
+ sda_r <= one_bit;
+ @(negedge clk);
+ @(negedge clk);
+ @(negedge clk);
+ @(negedge clk);
+ scl_r <= 1'b1;
+ @(negedge clk);
+ @(negedge clk);
+ @(negedge clk);
+ @(negedge clk);
+ end
+ endtask // send_settings_bit