forked from M-Labs/artiq-zynq
removed references for clock, replaced with timer
This commit is contained in:
parent
5fa575ce4c
commit
7b25bc710e
@ -4,7 +4,7 @@ version = "0.0.0"
|
|||||||
authors = ["M-Labs"]
|
authors = ["M-Labs"]
|
||||||
|
|
||||||
[lib]
|
[lib]
|
||||||
name = "board_artiqzynq"
|
name = "libboard_artiqzynq"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
log = "0.4"
|
log = "0.4"
|
||||||
|
@ -1,38 +0,0 @@
|
|||||||
use core::i64;
|
|
||||||
use csr; // <- port
|
|
||||||
|
|
||||||
const INIT: u64 = i64::MAX as u64;
|
|
||||||
const FREQ: u64 = csr::CONFIG_CLOCK_FREQUENCY as u64;
|
|
||||||
|
|
||||||
pub fn init() {
|
|
||||||
unsafe {
|
|
||||||
csr::timer0::en_write(0);
|
|
||||||
csr::timer0::load_write(INIT);
|
|
||||||
csr::timer0::reload_write(INIT);
|
|
||||||
csr::timer0::en_write(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_us() -> u64 {
|
|
||||||
unsafe {
|
|
||||||
csr::timer0::update_value_write(1);
|
|
||||||
(INIT - csr::timer0::value_read()) / (FREQ / 1_000_000)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_ms() -> u64 {
|
|
||||||
unsafe {
|
|
||||||
csr::timer0::update_value_write(1);
|
|
||||||
(INIT - csr::timer0::value_read()) / (FREQ / 1_000)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn spin_us(interval: u64) {
|
|
||||||
unsafe {
|
|
||||||
csr::timer0::update_value_write(1);
|
|
||||||
let threshold = csr::timer0::value_read() - interval * (FREQ / 1_000_000);
|
|
||||||
while csr::timer0::value_read() > threshold {
|
|
||||||
csr::timer0::update_value_write(1)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,5 +1,6 @@
|
|||||||
pub mod jesd {
|
pub mod jesd {
|
||||||
use board_misoc::{csr, clock}; // <- port
|
use libboard_artiqzynq::pl::csr;
|
||||||
|
use libboard_zynq::timer::GlobalTimer;
|
||||||
|
|
||||||
pub fn reset(reset: bool) {
|
pub fn reset(reset: bool) {
|
||||||
unsafe {
|
unsafe {
|
||||||
@ -25,18 +26,18 @@ pub mod jesd {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn prbs(dacno: u8, en: bool) {
|
pub fn prbs(dacno: u8, en: bool, timer: GlobalTimer) {
|
||||||
unsafe {
|
unsafe {
|
||||||
(csr::JDCG[dacno as usize].jesd_control_prbs_config_write)(if en {0b01} else {0b00})
|
(csr::JDCG[dacno as usize].jesd_control_prbs_config_write)(if en {0b01} else {0b00})
|
||||||
}
|
}
|
||||||
clock::spin_us(5000);
|
timer.delay_us(5000);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn stpl(dacno: u8, en: bool) {
|
pub fn stpl(dacno: u8, en: bool, timer: GlobalTimer) {
|
||||||
unsafe {
|
unsafe {
|
||||||
(csr::JDCG[dacno as usize].jesd_control_stpl_enable_write)(if en {1} else {0})
|
(csr::JDCG[dacno as usize].jesd_control_stpl_enable_write)(if en {1} else {0})
|
||||||
}
|
}
|
||||||
clock::spin_us(5000);
|
timer.delay_us(5000);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn jsync(dacno: u8) -> bool {
|
pub fn jsync(dacno: u8) -> bool {
|
||||||
@ -47,8 +48,8 @@ pub mod jesd {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub mod jdac {
|
pub mod jdac {
|
||||||
use board_misoc::{csr, clock}; // <- port
|
use libboard_artiqzynq::{pl::csr, drtioaux};
|
||||||
use board_artiq::drtioaux; // <- port
|
use libboard_zynq::timer::GlobalTimer;
|
||||||
|
|
||||||
use super::jesd;
|
use super::jesd;
|
||||||
use super::super::jdac_common;
|
use super::super::jdac_common;
|
||||||
@ -83,13 +84,13 @@ pub mod jdac {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn init() -> Result<(), &'static str> {
|
pub fn init(timer: GlobalTimer) -> Result<(), &'static str> {
|
||||||
for dacno in 0..csr::JDCG.len() {
|
for dacno in 0..csr::JDCG.len() {
|
||||||
let dacno = dacno as u8;
|
let dacno = dacno as u8;
|
||||||
info!("DAC-{} initializing...", dacno);
|
info!("DAC-{} initializing...", dacno);
|
||||||
|
|
||||||
jesd::enable(dacno, true);
|
jesd::enable(dacno, true);
|
||||||
clock::spin_us(10_000);
|
timer.delay_us(10_000);
|
||||||
if !jesd::phy_done(dacno) {
|
if !jesd::phy_done(dacno) {
|
||||||
error!("JESD core PHY not done");
|
error!("JESD core PHY not done");
|
||||||
return Err("JESD core PHY not done");
|
return Err("JESD core PHY not done");
|
||||||
@ -109,7 +110,7 @@ pub mod jdac {
|
|||||||
jesd::prbs(dacno, false);
|
jesd::prbs(dacno, false);
|
||||||
|
|
||||||
basic_request(dacno, jdac_common::INIT, 0)?;
|
basic_request(dacno, jdac_common::INIT, 0)?;
|
||||||
clock::spin_us(5000);
|
timer.delay_us(5000);
|
||||||
|
|
||||||
if !jesd::jsync(dacno) {
|
if !jesd::jsync(dacno) {
|
||||||
error!("JESD core reported bad SYNC");
|
error!("JESD core reported bad SYNC");
|
||||||
@ -121,15 +122,15 @@ pub mod jdac {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn stpl() -> Result<(), &'static str> {
|
pub fn stpl(timer: GlobalTimer) -> Result<(), &'static str> {
|
||||||
for dacno in 0..csr::JDCG.len() {
|
for dacno in 0..csr::JDCG.len() {
|
||||||
let dacno = dacno as u8;
|
let dacno = dacno as u8;
|
||||||
|
|
||||||
info!("Running STPL test on DAC-{}...", dacno);
|
info!("Running STPL test on DAC-{}...", dacno);
|
||||||
|
|
||||||
jesd::stpl(dacno, true);
|
jesd::stpl(dacno, true, timer);
|
||||||
basic_request(dacno, jdac_common::STPL, 0)?;
|
basic_request(dacno, jdac_common::STPL, 0)?;
|
||||||
jesd::stpl(dacno, false);
|
jesd::stpl(dacno, false, timer);
|
||||||
|
|
||||||
info!(" ...done STPL test");
|
info!(" ...done STPL test");
|
||||||
}
|
}
|
||||||
|
@ -7,12 +7,12 @@ extern crate log;
|
|||||||
use core::convert::TryFrom;
|
use core::convert::TryFrom;
|
||||||
use board_misoc::{csr, irq, ident, clock, i2c}; // <- port, use libboard_zynq
|
use board_misoc::{csr, irq, ident, clock, i2c}; // <- port, use libboard_zynq
|
||||||
#[cfg(has_si5324)]
|
#[cfg(has_si5324)]
|
||||||
use board_artiqzynq::si5324; // <- move from runtime
|
use libboard_artiqzynq::si5324;
|
||||||
#[cfg(has_wrpll)]
|
#[cfg(has_wrpll)]
|
||||||
use board_artiq::wrpll; // <- port
|
use board_artiq::wrpll; // <- port
|
||||||
use board_artiq::spi; // <- port?, use libboard_zynq (if spi available/necessary)
|
use board_artiq::spi; // <- port?, use libboard_zynq (if spi available/necessary)
|
||||||
use board_artiqzynq::{drtio_routing drtioaux}; // <- artiqzync
|
use libboard_artiqzynq::{drtio_routing drtioaux};
|
||||||
use board_artiqzynq::logger;
|
use libboard_artiqzynq::logger;
|
||||||
|
|
||||||
mod repeater;
|
mod repeater;
|
||||||
#[cfg(has_jdcg)]
|
#[cfg(has_jdcg)]
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
use board_artiq::{drtioaux, drtio_routing};
|
use board_artiqzynq::{drtioaux, drtio_routing};
|
||||||
#[cfg(has_drtio_routing)]
|
#[cfg(has_drtio_routing)]
|
||||||
use board_misoc::{csr, clock};
|
use board_artiqzynq::{pl::csr, clock};
|
||||||
|
|
||||||
#[cfg(has_drtio_routing)]
|
#[cfg(has_drtio_routing)]
|
||||||
fn rep_link_rx_up(repno: u8) -> bool {
|
fn rep_link_rx_up(repno: u8) -> bool {
|
||||||
|
Loading…
Reference in New Issue
Block a user