-
Notifications
You must be signed in to change notification settings - Fork 683
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
Add Layer Build and Validation for DoIP (Diagnostic over IP) Support #1655
base: dev
Are you sure you want to change the base?
Conversation
As per the contributing guidelines, please retarget the PR to the |
Observed several issues in the CI pipelines, likely due to missing definitions for |
Packet++/header/ProtocolType.h
Outdated
/** | ||
* Diagnostic over IP protocol (DOIP) | ||
*/ | ||
const ProtocolType DOIP = 38; |
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.
ID 38 is already taken by DHCPv6
protocol. The next available ID is 58, please add it after GTPv2
@@ -437,7 +437,6 @@ namespace pcpp | |||
|
|||
HttpResponseStatusCode() = default; | |||
|
|||
// cppcheck-suppress noExplicitConstructor |
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.
Why removing this cppcheck-suppress
comment?
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.
Cppcheck flags this as an incorrect suppression on my local machine. Let me know if you think I should revert it.
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.
That is interesting. Which version of CPPcheck are you using?
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.
2.7 as recommanded in CONTRIBUTING.md and still flags incorrect suppression, I'm keeping this changes so can I commit my recents updates,
3rdParty/json/include/json.hpp
Outdated
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.
Why update this file?
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.
same thing as my previous comment, I only removed some suppress-checks detected as incorrect
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.
Can you add one pcap file with all of these packets?
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.
yes sure, I'll revert suppress-checks and add pcap file containig all tested packets in next PR, also try to cover some missing checks based on codecov feedback
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## dev #1655 +/- ##
==========================================
+ Coverage 83.11% 83.55% +0.43%
==========================================
Files 277 283 +6
Lines 48207 50042 +1835
Branches 10192 10704 +512
==========================================
+ Hits 40069 41813 +1744
- Misses 7243 7300 +57
- Partials 895 929 +34
Flags with carried forward coverage won't be shown. Click here to find out more. ☔ View full report in Codecov by Sentry. |
@raissi-oussema are you planning to continue working on this PR? |
Hi, I was engaged with other tasks, but I plan to get back to this PR soon. Thanks for your understanding! |
.improve maps searchs for doipEnumsToStrings .cover more uses cases based on codecov feedback
Design suggestions or code improvements are always welcome and greatly appreciated. |
@raissi-oussema to make it easier to review, do you think you can add some documentation on the DoIP protocol to the PR body? It'd mostly be helpful to get more details on the header structure and different possible message |
@seladb I need support for CI pipelines, I can't figure out why are they still failing. And a clear documentation was successfully added to PR body to make it easier for you to start the code review. |
Doxigen pipeline: XDP pipeline: VS pipeline: |
What could be the problem for dioxygen pipeline, doipLayer.h is well documented [line 42] ? |
/** | ||
* @class DoipLayer | ||
* Represents an DoIP protocol layer. Currently only IPv4 DoIP messages are supported | ||
*/ | ||
class DoIpLayer : public Layer |
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.
The class needs to match case too.
/** | |
* @class DoipLayer | |
* Represents an DoIP protocol layer. Currently only IPv4 DoIP messages are supported | |
*/ | |
class DoIpLayer : public Layer | |
/** | |
* @class DoIpLayer | |
* Represents an DoIP protocol layer. Currently only IPv4 DoIP messages are supported | |
*/ | |
class DoIpLayer : public Layer |
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.
@raissi-oussema Probably this root cause of CI fail. Case does not match so doxygen generates warning/error
/** | ||
* \namespace pcpp | ||
* \brief The main namespace for the PcapPlusPlus lib | ||
*/ |
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.
/** | |
* \namespace pcpp | |
* \brief The main namespace for the PcapPlusPlus lib | |
*/ | |
/** | |
* @namespace pcpp | |
* @brief The main namespace for the PcapPlusPlus lib | |
*/ |
* Set the doip payload length | ||
* @param[in] length the doip payload length to set | ||
*/ | ||
void setPayloadength(uint32_t length); |
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.
void setPayloadength(uint32_t length); | |
void setPayloadLength(uint32_t length); |
m_Data = new uint8_t[m_DataLen]; | ||
memset(m_Data, 0, m_DataLen); |
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.
This should also zero initialize the array.
m_Data = new uint8_t[m_DataLen]; | |
memset(m_Data, 0, m_DataLen); | |
m_Data = new uint8_t[m_DataLen]{}; |
os << "DOIP Layer:" << std::endl; | ||
os << "Protocol Version: " << getProtocolVersionAsStr() << std::hex << " (0x" << unsigned((uint8_t)version) | ||
<< ")" << std::endl; | ||
os << "Payload Type: " << getPayloadTypeAsStr() << std::hex << " (0x" << std::setw(4) << std::setfill('0') | ||
<< (uint16_t)type << ")" << std::endl; | ||
os << std::dec << "Payload Length: " << length << std::endl; |
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.
Use '\n'
instead of sdt::endl
while in the middle of chaining outputs. Each std::endl
performs a buffer flush. In this case the flush is a noop as stringstream
does not flush, but it is still an overhead.
std::stringstream os; | ||
if (!resolveLayer()) | ||
{ | ||
os << "Malformed doip Packet"; | ||
return os.str(); | ||
} |
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.
As this specific branch returns a static string the stream can be skipped here.
std::stringstream os; | |
if (!resolveLayer()) | |
{ | |
os << "Malformed doip Packet"; | |
return os.str(); | |
} | |
if (!resolveLayer()) | |
{ | |
return "Malformed doip Packet"; | |
} | |
std::stringstream os; |
|
||
void DoIpLayer::setPayloadType(DoIpPayloadTypes type) | ||
{ | ||
getDoIpHeader()->payloadType = htobe16((uint16_t)type); |
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.
nit: C style cast
/** | ||
* \namespace pcpp | ||
* \brief The main namespace for the PcapPlusPlus library | ||
*/ |
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.
/** | |
* \namespace pcpp | |
* \brief The main namespace for the PcapPlusPlus library | |
*/ | |
/** | |
* @namespace pcpp | |
* @brief The main namespace for the PcapPlusPlus library | |
*/ |
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.
This file has a lot of doc comments that use both \param
and @param
styling. It is clearer if only one style is used (at least per comment section). Preferably the @ ones.
// implement abstract methods | ||
|
||
/** | ||
* TODO, parse UDS layer |
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.
Is this for another PR? If so, should the remaining data be parsed as a generic payload layer for now?
DoIP Protocol Overview
The Diagnostic over IP (DoIP) protocol is used in automotive diagnostic systems to facilitate communication between diagnostic tools and ECUs (Electronic Control Units) over IP-based networks. It enables remote diagnostics, configuration, and software updates over Ethernet, offering an efficient and scalable solution for modern vehicles.
Header Structure (8 bytes)
Pyload types / code / structure