-
Notifications
You must be signed in to change notification settings - Fork 65
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix: checking can id #40
Conversation
57d77b4
to
44c0676
Compare
@JWhitleyWork can you check this fix? |
There are two ways to test for standard vs extended frames in SocketCAN: First mask the ID with the largest extended CAN ID and then check the value of the CAN ID and see if it is larger than the maximum standard frame ID (how it is done in the code now) or check the EFF bit returned in the unmasked ID. Both are valid so I don't think this change is necessary. Let me know if you feel differently. |
@JWhitleyWork Thanks for the fast response, but I couldn't handle the following situation: In case, my extended ID will be: 0x01F0A020, and if I give this ID to my can_msgs Frame message, is_extended() function returns False: ros2_socketcan/ros2_socketcan/src/socket_can_id.cpp Lines 77 to 81 in 8996cdb
If I set the my can id:0x81F0A020 at can_msgs::Frame msg, is_extended() function returns true but I get this error since it exceeds the maximum limit: ros2_socketcan/ros2_socketcan/src/socket_can_id.cpp Lines 139 to 142 in 8996cdb
At this point, what do you recommend me to do in this situation? Thanks in advance @JWhitleyWork |
@JWhitleyWork friendly reminder 😃 |
Signed-off-by: ismetatabay <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@JWhitleyWork you've mentioned that there are two valid ways to check for standard vs. extended frames:
- Masking the ID with the largest extended CAN ID and comparing the value: This is what's being done currently, but it doesn't account for the flag bits included in id.
- Checking the EFF bit in the unmasked ID: This is essentially what the proposed change is doing.
While both methods are valid, the current implementation doesn't handle cases where id includes flag bits, leading to potential errors.
Current proposal addresses the issue where including the EFF
flag in the id
causes incorrect behavior.
By masking out the flag bits before the comparison, we align the function's behavior with the expected CAN ID specifications.
Therefore, I'll approve the change to ensure correct handling of extended CAN IDs.
Description
At the Extended Can ID, the most significant bit determines the EFF flag (CAN_EFF_FLAG). For example, if our Extended CAN ID will be:
0x01F0A020 (00000001111100001010000000100000)
and if it's EFF Flag is 1, the value will be
0x81F0A020 (10000001111100001010000000100000).
Therefore, the CAN ID value is exceeds the 29 bit max value. (~536million - 0x1FBF'FFFFU). If we want to check can id value, we need to unmask it first. This PR fixes this problem.