forked from M-Labs/artiq-zynq
phy fw: update csr
This commit is contained in:
parent
35f5e77d63
commit
5e2b3360b9
@ -1,10 +1,6 @@
|
|||||||
use embedded_hal::prelude::_embedded_hal_blocking_delay_DelayUs;
|
|
||||||
use libboard_zynq::timer::GlobalTimer;
|
|
||||||
use log::info;
|
use log::info;
|
||||||
|
|
||||||
use crate::pl::{csr, csr::CXP};
|
use crate::pl::csr;
|
||||||
|
|
||||||
pub const CXP_CHANNELS: u8 = csr::CXP_LEN as u8;
|
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Clone, Copy, Debug)]
|
||||||
#[allow(non_camel_case_types)]
|
#[allow(non_camel_case_types)]
|
||||||
@ -18,8 +14,8 @@ pub enum CXP_SPEED {
|
|||||||
CXP_12,
|
CXP_12,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn setup(timer: &mut GlobalTimer) {
|
pub fn setup() {
|
||||||
rx::setup(timer);
|
rx::setup();
|
||||||
tx::setup();
|
tx::setup();
|
||||||
change_linerate(CXP_SPEED::CXP_1);
|
change_linerate(CXP_SPEED::CXP_1);
|
||||||
}
|
}
|
||||||
@ -57,21 +53,13 @@ mod tx {
|
|||||||
mod rx {
|
mod rx {
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
pub fn setup(timer: &mut GlobalTimer) {
|
pub fn setup() {
|
||||||
unsafe {
|
unsafe {
|
||||||
csr::cxp_phys::rx_qpll_reset_write(1);
|
csr::cxp_phys::rx_qpll_reset_write(1);
|
||||||
info!("waiting for QPLL/CPLL to lock...");
|
info!("waiting for QPLL/CPLL to lock...");
|
||||||
while csr::cxp_phys::rx_qpll_locked_read() != 1 {}
|
while csr::cxp_phys::rx_qpll_locked_read() != 1 {}
|
||||||
info!("QPLL locked");
|
info!("QPLL locked");
|
||||||
|
|
||||||
csr::cxp_phys::rx_gtx_start_init_write(1);
|
csr::cxp_phys::rx_gtx_start_init_write(1);
|
||||||
|
|
||||||
// DEBUG: printout
|
|
||||||
info!("waiting for rx setup...");
|
|
||||||
timer.delay_us(50_000);
|
|
||||||
for ch in 0..CXP_CHANNELS {
|
|
||||||
info!("rx_phaligndone = {}", (CXP[ch as usize].rx_rxinit_phaligndone_read)());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,11 +101,9 @@ mod rx {
|
|||||||
|
|
||||||
// DEBUG:
|
// DEBUG:
|
||||||
// println!("RX GTX DRP:");
|
// println!("RX GTX DRP:");
|
||||||
for ch in 0..CXP_CHANNELS {
|
// println!("channel {}, 0x88 = {:#06x}", channel, gtx_read(channel, 0x88));
|
||||||
// println!("channel {}, 0x88 = {:#06x}", channel, gtx_read(channel, 0x88));
|
gtx_write(0x88, div_reg);
|
||||||
gtx_write(ch, 0x88, div_reg);
|
// println!("channel {}, 0x88 = {:#06x}", channel, gtx_read(channel, 0x88));
|
||||||
// println!("channel {}, 0x88 = {:#06x}", channel, gtx_read(channel, 0x88));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn change_cdr_cfg(speed: CXP_SPEED) {
|
fn change_cdr_cfg(speed: CXP_SPEED) {
|
||||||
@ -164,33 +150,29 @@ mod rx {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
for channel in 0..CXP_CHANNELS {
|
gtx_write(0x0A8, cdr_cfg.cfg_reg0);
|
||||||
gtx_write(channel, 0x0A8, cdr_cfg.cfg_reg0);
|
gtx_write(0x0A9, cdr_cfg.cfg_reg1);
|
||||||
gtx_write(channel, 0x0A9, cdr_cfg.cfg_reg1);
|
gtx_write(0x0AA, cdr_cfg.cfg_reg2);
|
||||||
gtx_write(channel, 0x0AA, cdr_cfg.cfg_reg2);
|
gtx_write(0x0AB, cdr_cfg.cfg_reg3);
|
||||||
gtx_write(channel, 0x0AB, cdr_cfg.cfg_reg3);
|
gtx_write(0x0AC, cdr_cfg.cfg_reg4);
|
||||||
gtx_write(channel, 0x0AC, cdr_cfg.cfg_reg4);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
fn gtx_read(channel: u8, address: u16) -> u16 {
|
fn gtx_read(address: u16) -> u16 {
|
||||||
let channel = channel as usize;
|
|
||||||
unsafe {
|
unsafe {
|
||||||
(CXP[channel].rx_gtx_daddr_write)(address);
|
csr::cxp_phys::rx_gtx_daddr_write(address);
|
||||||
(CXP[channel].rx_gtx_dread_write)(1);
|
csr::cxp_phys::rx_gtx_dread_write(1);
|
||||||
while (CXP[channel].rx_gtx_dready_read)() != 1 {}
|
while csr::cxp_phys::rx_gtx_dready_read() != 1 {}
|
||||||
(CXP[channel].rx_gtx_dout_read)()
|
csr::cxp_phys::rx_gtx_dout_read()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn gtx_write(channel: u8, address: u16, value: u16) {
|
fn gtx_write(address: u16, value: u16) {
|
||||||
let channel = channel as usize;
|
|
||||||
unsafe {
|
unsafe {
|
||||||
(CXP[channel].rx_gtx_daddr_write)(address);
|
csr::cxp_phys::rx_gtx_daddr_write(address);
|
||||||
(CXP[channel].rx_gtx_din_write)(value);
|
csr::cxp_phys::rx_gtx_din_write(value);
|
||||||
(CXP[channel].rx_gtx_din_stb_write)(1);
|
csr::cxp_phys::rx_gtx_din_stb_write(1);
|
||||||
while (CXP[channel].rx_gtx_dready_read)() != 1 {}
|
while csr::cxp_phys::rx_gtx_dready_read() != 1 {}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user