mirror of
https://github.com/italicsjenga/rp-hal-boards.git
synced 2025-01-11 04:51:31 +11:00
Use u8 instead of usize for pio address calculation
This commit is contained in:
parent
7cca9a71d7
commit
6a5747b213
|
@ -156,7 +156,7 @@ impl<P: PIOExt> PIO<P> {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Tries to find an appropriate offset for the instructions, in range 0..=31.
|
/// Tries to find an appropriate offset for the instructions, in range 0..=31.
|
||||||
fn find_offset_for_instructions(&self, i: &[u16], origin: Option<u8>) -> Option<usize> {
|
fn find_offset_for_instructions(&self, i: &[u16], origin: Option<u8>) -> Option<u8> {
|
||||||
if i.len() > PIO_INSTRUCTION_COUNT || i.is_empty() {
|
if i.len() > PIO_INSTRUCTION_COUNT || i.is_empty() {
|
||||||
None
|
None
|
||||||
} else {
|
} else {
|
||||||
|
@ -167,10 +167,10 @@ impl<P: PIOExt> PIO<P> {
|
||||||
{
|
{
|
||||||
None
|
None
|
||||||
} else {
|
} else {
|
||||||
Some(origin as usize)
|
Some(origin)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for i in (0..=32 - i.len()).rev() {
|
for i in (0..=32 - (i.len() as u8)).rev() {
|
||||||
if self.used_instruction_space & (mask << i) == 0 {
|
if self.used_instruction_space & (mask << i) == 0 {
|
||||||
return Some(i);
|
return Some(i);
|
||||||
}
|
}
|
||||||
|
@ -197,10 +197,10 @@ impl<P: PIOExt> PIO<P> {
|
||||||
.map(|instr| {
|
.map(|instr| {
|
||||||
if instr & 0b1110_0000_0000_0000 == 0 {
|
if instr & 0b1110_0000_0000_0000 == 0 {
|
||||||
// this is a JMP instruction -> add offset to address
|
// this is a JMP instruction -> add offset to address
|
||||||
let address = (instr & 0b11111) as usize;
|
let address = (instr & 0b11111) as u8;
|
||||||
let address = address + offset;
|
let address = address + offset;
|
||||||
assert!(
|
assert!(
|
||||||
address < pio::RP2040_MAX_PROGRAM_SIZE,
|
address < pio::RP2040_MAX_PROGRAM_SIZE as u8,
|
||||||
"Invalid JMP out of the program after offset addition"
|
"Invalid JMP out of the program after offset addition"
|
||||||
);
|
);
|
||||||
instr & (!0b11111) | address as u16
|
instr & (!0b11111) | address as u16
|
||||||
|
@ -211,7 +211,8 @@ impl<P: PIOExt> PIO<P> {
|
||||||
})
|
})
|
||||||
.enumerate()
|
.enumerate()
|
||||||
.for_each(|(i, instr)| {
|
.for_each(|(i, instr)| {
|
||||||
self.pio.instr_mem[i + offset].write(|w| unsafe { w.instr_mem0().bits(instr) })
|
self.pio.instr_mem[i + offset as usize]
|
||||||
|
.write(|w| unsafe { w.instr_mem0().bits(instr) })
|
||||||
});
|
});
|
||||||
self.used_instruction_space |= Self::instruction_mask(p.code.len()) << offset;
|
self.used_instruction_space |= Self::instruction_mask(p.code.len()) << offset;
|
||||||
Ok(InstalledProgram {
|
Ok(InstalledProgram {
|
||||||
|
|
Loading…
Reference in a new issue