aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDario Nieuwenhuis <[email protected]>2024-02-27 12:19:03 +0000
committerGitHub <[email protected]>2024-02-27 12:19:03 +0000
commit62c5df7e5bff50ce8553f675323fabf2e02ea2c6 (patch)
tree08b9349dc92534f1e1578afc69d927a09a1f2aff
parent55cda6ad97bc31e690d20cf0a351d2ab28a1a542 (diff)
parent9a4f58fe158551bd0c38d23a71f6b719d4ce5130 (diff)
Merge pull request #2631 from MaxiluxSystems/small-fdcan-fixes
stm32: can: fd: fix SID read/write and BRS setting for TX
-rw-r--r--embassy-stm32/src/can/fd/peripheral.rs8
1 files changed, 5 insertions, 3 deletions
diff --git a/embassy-stm32/src/can/fd/peripheral.rs b/embassy-stm32/src/can/fd/peripheral.rs
index 0771d6fbb..9c29e4887 100644
--- a/embassy-stm32/src/can/fd/peripheral.rs
+++ b/embassy-stm32/src/can/fd/peripheral.rs
@@ -721,13 +721,15 @@ fn make_id(id: u32, extended: bool) -> embedded_can::Id {
721 if extended { 721 if extended {
722 embedded_can::Id::from(unsafe { embedded_can::ExtendedId::new_unchecked(id & 0x1FFFFFFF) }) 722 embedded_can::Id::from(unsafe { embedded_can::ExtendedId::new_unchecked(id & 0x1FFFFFFF) })
723 } else { 723 } else {
724 embedded_can::Id::from(unsafe { embedded_can::StandardId::new_unchecked((id & 0x000007FF) as u16) }) 724 // A standard identifier is stored into ID[28:18].
725 embedded_can::Id::from(unsafe { embedded_can::StandardId::new_unchecked(((id >> 18) & 0x000007FF) as u16) })
725 } 726 }
726} 727}
727 728
728fn put_tx_header(mailbox: &mut TxBufferElement, header: &Header) { 729fn put_tx_header(mailbox: &mut TxBufferElement, header: &Header) {
729 let (id, id_type) = match header.id() { 730 let (id, id_type) = match header.id() {
730 embedded_can::Id::Standard(id) => (id.as_raw() as u32, IdType::StandardId), 731 // A standard identifier has to be written to ID[28:18].
732 embedded_can::Id::Standard(id) => ((id.as_raw() as u32) << 18, IdType::StandardId),
731 embedded_can::Id::Extended(id) => (id.as_raw() as u32, IdType::ExtendedId), 733 embedded_can::Id::Extended(id) => (id.as_raw() as u32, IdType::ExtendedId),
732 }; 734 };
733 735
@@ -737,7 +739,7 @@ fn put_tx_header(mailbox: &mut TxBufferElement, header: &Header) {
737 } else { 739 } else {
738 FrameFormat::Classic 740 FrameFormat::Classic
739 }; 741 };
740 let brs = header.len() > 8 || header.bit_rate_switching(); 742 let brs = (frame_format == FrameFormat::Fdcan) && header.bit_rate_switching();
741 743
742 mailbox.header.write(|w| { 744 mailbox.header.write(|w| {
743 unsafe { w.id().bits(id) } 745 unsafe { w.id().bits(id) }