Skip to content
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

Updated startIntTask in LinuxGpioDriver to take a stack size argument #2068

Merged

Conversation

kubiak-jpl
Copy link
Contributor

Originating Project/Creator @kubiak-jpl
Affected Component LinuxGpioDriver
Affected Architectures(s) Linux
Related Issue(s) N/A
Has Unit Tests (y/n) No
Builds Without Errors (y/n) Yes
Unit Tests Pass (y/n) N/A
Documentation Included (y/n) No

Change Description

Updates the startIntTask method call in LinuxGpioDriver to include a stack size argument for the new thread. This matches the behavior of the read thread call in LinuxUartDriver.

The stack size argument was inserted into the middle of the list of arguments to match LinuxUartDriver. However, existing code that uses both priority and CPU affinity arguments will be broken if directly updated. In practice I am unsure if this is too big of an issue as cpu affinity arguments will likely be invalid stack sizes.

Rationale

The application author is responsible for setting the stack size of the task, not the framework

Testing/Review Recommendations

Currently untested. Building LinuxGpioDriver still builds standalone and building this code in an internal project was successful

@thomas-bc thomas-bc changed the base branch from master to devel June 3, 2023 02:58
Os::TaskString name;
name.format("GPINT_%s",this->getObjName()); // The task name can only be 16 chars including null
Os::Task::TaskStatus stat = this->m_intTask.start(name, LinuxGpioDriverComponentImpl::intTaskEntry, this, priority, Os::Task::TASK_DEFAULT, cpuAffinity);
Os::Task::TaskStatus stat = this->m_intTask.start(name, LinuxGpioDriverComponentImpl::intTaskEntry, this, priority, stackSize, cpuAffinity);

Check warning

Code scanning / CodeQL

Unchecked function argument

This use of parameter priority has not been checked.
Os::TaskString name;
name.format("GPINT_%s",this->getObjName()); // The task name can only be 16 chars including null
Os::Task::TaskStatus stat = this->m_intTask.start(name, LinuxGpioDriverComponentImpl::intTaskEntry, this, priority, Os::Task::TASK_DEFAULT, cpuAffinity);
Os::Task::TaskStatus stat = this->m_intTask.start(name, LinuxGpioDriverComponentImpl::intTaskEntry, this, priority, stackSize, cpuAffinity);

Check warning

Code scanning / CodeQL

Unchecked function argument

This use of parameter stackSize has not been checked.
Os::TaskString name;
name.format("GPINT_%s",this->getObjName()); // The task name can only be 16 chars including null
Os::Task::TaskStatus stat = this->m_intTask.start(name, LinuxGpioDriverComponentImpl::intTaskEntry, this, priority, Os::Task::TASK_DEFAULT, cpuAffinity);
Os::Task::TaskStatus stat = this->m_intTask.start(name, LinuxGpioDriverComponentImpl::intTaskEntry, this, priority, stackSize, cpuAffinity);

Check warning

Code scanning / CodeQL

Unchecked function argument

This use of parameter cpuAffinity has not been checked.
@@ -397,10 +397,10 @@
}

Os::Task::TaskStatus LinuxGpioDriverComponentImpl ::
startIntTask(NATIVE_UINT_TYPE priority, NATIVE_UINT_TYPE cpuAffinity) {
startIntTask(NATIVE_UINT_TYPE priority, NATIVE_UINT_TYPE stackSize, NATIVE_UINT_TYPE cpuAffinity) {

Check notice

Code scanning / CodeQL

Use of basic integral type

priority uses the basic integral type unsigned int rather than a typedef with size and signedness.
@@ -397,10 +397,10 @@
}

Os::Task::TaskStatus LinuxGpioDriverComponentImpl ::
startIntTask(NATIVE_UINT_TYPE priority, NATIVE_UINT_TYPE cpuAffinity) {
startIntTask(NATIVE_UINT_TYPE priority, NATIVE_UINT_TYPE stackSize, NATIVE_UINT_TYPE cpuAffinity) {

Check notice

Code scanning / CodeQL

Use of basic integral type

stackSize uses the basic integral type unsigned int rather than a typedef with size and signedness.
@@ -397,10 +397,10 @@
}

Os::Task::TaskStatus LinuxGpioDriverComponentImpl ::
startIntTask(NATIVE_UINT_TYPE priority, NATIVE_UINT_TYPE cpuAffinity) {
startIntTask(NATIVE_UINT_TYPE priority, NATIVE_UINT_TYPE stackSize, NATIVE_UINT_TYPE cpuAffinity) {

Check notice

Code scanning / CodeQL

Use of basic integral type

cpuAffinity uses the basic integral type unsigned int rather than a typedef with size and signedness.
Copy link
Collaborator

@LeStarch LeStarch left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me!

@LeStarch
Copy link
Collaborator

LeStarch commented Jun 3, 2023

Looks like the GPIO stubs file wasn't updated. @kubiak-jpl want to fix that? If not I'll get to it Monday.

@LeStarch LeStarch merged commit 5096ad4 into nasa:devel Jun 8, 2023
Boehm-Michael pushed a commit to Boehm-Michael/fprime that referenced this pull request Jun 22, 2023
…nasa#2068)

* Updated startIntTask in LinuxGpioDriver to take an optional stack size argument

* Updated LinuxGpioDriver Stubs for startIntTask update
thomas-bc pushed a commit that referenced this pull request Aug 4, 2023
…#2068)

* Updated startIntTask in LinuxGpioDriver to take an optional stack size argument

* Updated LinuxGpioDriver Stubs for startIntTask update
thomas-bc added a commit that referenced this pull request Aug 4, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants