WIP to fix timing on newer nightlies-
All bits seem to register here, but with zeroes reliably becoming ones in a way that desaturates things towards white
This commit is contained in:
parent
bd4de16015
commit
ea8c4f00a7
1 changed files with 44 additions and 7 deletions
|
@ -1,4 +1,5 @@
|
||||||
#![no_std]
|
#![no_std]
|
||||||
|
#![feature(asm)]
|
||||||
|
|
||||||
extern crate cortex_m;
|
extern crate cortex_m;
|
||||||
extern crate embedded_hal;
|
extern crate embedded_hal;
|
||||||
|
@ -9,6 +10,7 @@ pub use cortex_m::asm::delay;
|
||||||
pub use hal::entry;
|
pub use hal::entry;
|
||||||
|
|
||||||
use core::fmt::Debug;
|
use core::fmt::Debug;
|
||||||
|
use core::sync::atomic::{compiler_fence, Ordering};
|
||||||
use core::u8;
|
use core::u8;
|
||||||
pub use embedded_hal::digital::v2::OutputPin;
|
pub use embedded_hal::digital::v2::OutputPin;
|
||||||
use hal::{clock::GenericClockController, pac::Peripherals};
|
use hal::{clock::GenericClockController, pac::Peripherals};
|
||||||
|
@ -67,14 +69,42 @@ where
|
||||||
{
|
{
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn write(&mut self, bit: bool) {
|
pub fn write(&mut self, bit: bool) {
|
||||||
|
// go high
|
||||||
self.high_out.set_high().unwrap();
|
self.high_out.set_high().unwrap();
|
||||||
delay(if bit {
|
|
||||||
ONE_HIGH_CYCLES
|
unsafe {
|
||||||
} else {
|
compiler_fence(Ordering::SeqCst);
|
||||||
ZERO_HIGH_CYCLES
|
asm!(
|
||||||
});
|
// ? nops
|
||||||
|
"nop;", "nop;", "nop;", "nop;", "nop;", "nop;", "nop;", "nop;", "nop;",
|
||||||
|
);
|
||||||
|
compiler_fence(Ordering::SeqCst);
|
||||||
|
}
|
||||||
|
|
||||||
|
if bit {
|
||||||
|
unsafe {
|
||||||
|
compiler_fence(Ordering::SeqCst);
|
||||||
|
asm!(
|
||||||
|
// 7 nops
|
||||||
|
"nop;", "nop;", "nop;", "nop;", "nop;", "nop;", "nop;", "nop;", "nop;", "nop;",
|
||||||
|
"nop;", "nop;", "nop;", "nop;",
|
||||||
|
);
|
||||||
|
compiler_fence(Ordering::SeqCst);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// go low
|
||||||
self.high_out.set_low().unwrap();
|
self.high_out.set_low().unwrap();
|
||||||
delay(if bit { ONE_LOW_CYCLES } else { ZERO_LOW_CYCLES });
|
|
||||||
|
unsafe {
|
||||||
|
compiler_fence(Ordering::SeqCst);
|
||||||
|
asm!(
|
||||||
|
// 2 nops
|
||||||
|
"nop;", "nop;", "nop;", "nop;", "nop;", "nop;", "nop;", "nop;", "nop;", "nop;",
|
||||||
|
"nop;", "nop;", "nop;", "nop;", "nop;",
|
||||||
|
);
|
||||||
|
compiler_fence(Ordering::SeqCst);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -87,7 +117,14 @@ where
|
||||||
self.write(byte & 0x04 != 0);
|
self.write(byte & 0x04 != 0);
|
||||||
self.write(byte & 0x02 != 0);
|
self.write(byte & 0x02 != 0);
|
||||||
self.write(byte & 0x01 != 0);
|
self.write(byte & 0x01 != 0);
|
||||||
delay(5);
|
unsafe {
|
||||||
|
compiler_fence(Ordering::SeqCst);
|
||||||
|
asm!(
|
||||||
|
// 5 nops
|
||||||
|
"nop;", "nop;", "nop;", "nop;", "nop;",
|
||||||
|
);
|
||||||
|
compiler_fence(Ordering::SeqCst);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Blink light, probably to indicate a loop is still running
|
/// Blink light, probably to indicate a loop is still running
|
||||||
|
|
Loading…
Add table
Reference in a new issue