diff options
| -rw-r--r-- | embassy-stm32/src/can/fd/peripheral.rs | 8 |
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 | ||
| 728 | fn put_tx_header(mailbox: &mut TxBufferElement, header: &Header) { | 729 | fn 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) } |
