forgot to push again
Some checks failed
ci / Check build (push) Has been cancelled
ci / Check formatting (push) Has been cancelled
ci / Check Documentation Build (push) Has been cancelled
ci / Clippy (push) Has been cancelled
ci / Check build (pull_request) Has been cancelled
ci / Check formatting (pull_request) Has been cancelled
ci / Check Documentation Build (pull_request) Has been cancelled
ci / Clippy (pull_request) Has been cancelled

This commit is contained in:
2025-07-12 11:59:34 +02:00
parent fbbff803d4
commit d25c8b4ead

View File

@@ -48,6 +48,7 @@ static ETH_RX_BUFS: static_cell::ConstStaticCell<[AlignedBuffer; NUM_RX_BUFS]> =
static ETH_TX_BUFS: static_cell::ConstStaticCell<[AlignedBuffer; NUM_TX_BUFS]> =
static_cell::ConstStaticCell::new([AlignedBuffer([0; zynq7000_hal::eth::MTU]); NUM_TX_BUFS]);
/*
static ETH_ERR_QUEUE: static_cell::ConstStaticCell<
embassy_sync::channel::Channel<
embassy_sync::blocking_mutex::raw::CriticalSectionRawMutex,
@@ -55,6 +56,14 @@ static ETH_ERR_QUEUE: static_cell::ConstStaticCell<
8,
>,
> = static_cell::ConstStaticCell::new(embassy_sync::channel::Channel::new());
*/
static ETH_ERR_QUEUE: embassy_sync::channel::Channel<
embassy_sync::blocking_mutex::raw::CriticalSectionRawMutex,
InterruptResult,
8,
> = embassy_sync::channel::Channel::new();
/*
static ETH_ERR_SENDER: critical_section::Mutex<
RefCell<
Option<
@@ -67,6 +76,7 @@ static ETH_ERR_SENDER: critical_section::Mutex<
>,
>,
> = critical_section::Mutex::new(RefCell::new(None));
*/
/// See memory.x file. 1 MB starting at this address will be configured as uncached memory using the
/// MMU.
@@ -246,13 +256,15 @@ async fn main(spawner: Spawner) -> ! {
RESOURCES.init(embassy_net::StackResources::new()),
rng.next_u64(),
);
let eth_err_queue = ETH_ERR_QUEUE.take();
let sender = eth_err_queue.sender();
//let eth_err_queue = ETH_ERR_QUEUE.take();
//let mut receiver = eth_err_queue.sender();
/*
let receiver = eth_err_queue.receiver();
critical_section::with(|cs| {
let mut sender_ref = ETH_ERR_SENDER.borrow(cs).borrow_mut();
sender_ref.replace(sender);
});
*/
spawner.spawn(embassy_net_task(runner)).unwrap();
let mut mio_led = Output::new_for_mio(gpio_pins.mio.mio7, PinState::Low);
@@ -271,7 +283,7 @@ async fn main(spawner: Spawner) -> ! {
];
let mut ip_mode = IpMode::LinkDown;
loop {
while let Ok(msg) = receiver.try_receive() {}
while let Ok(msg) = ETH_ERR_QUEUE.try_receive() {}
match ip_mode {
// Assuming that auto-negotiation is performed automatically.
IpMode::LinkDown => {
@@ -341,11 +353,12 @@ pub extern "C" fn _irq_handler() {
zynq7000_hal::eth::EthernetId::Eth0,
);
if result.has_anomalies() || result.has_errors() {
critical_section::with(|cs| {
let sender_ref = ETH_ERR_SENDER.borrow(cs).borrow_mut();
let sender_mut = sender_ref.unwrap();
sender_mut.try_send(result).ok();
})
ETH_ERR_QUEUE.try_send(result).ok();
/*
let sender_ref = ETH_ERR_SENDER.borrow(cs).borrow_mut();
let sender_mut = sender_ref.unwrap();
sender_mut.try_send(result).ok();
*/
}
// TODO: Send the result structure back to the main thread.
}