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

[ncp] add initial support of NCP #2283

Closed
wants to merge 1 commit into from

Conversation

Irving-cl
Copy link
Contributor

@Irving-cl Irving-cl commented May 11, 2024

This PR adds initial support of NCP in otbr-agent. When otbr-agent
starts, it will detect the Co-processor type. If the Co-processor is
NCP, otbr-agent will still run. But at this moment, it will provide
a dbus API to get the device role of the NCP, which is 'Disabled'
because no other functions are supported now.

This PR implements NcpSpinel which is the main class to communicate
with the NCP. Different from RadioSpinel in openthread, NcpSpinel
is totally async. There are no blocking operations like WaitResponse
in RadioSpinel.

Currently when the Co-processor type is NCP, most modules in otbr-agent
will be initialized and run. These may be added gradually later. And
the dbus server also initiates differently when Co-processor type is NCP.
When it's NCP, the dbus server registers AsyncGetPropertyHandler
instead of GetPropertyHandler used now.

Depends-on openthread/openthread#10272

@Irving-cl
Copy link
Contributor Author

@bukepo @zhanglongxia @abtink @superwhd @wgtdkp

I think the change is a non-trivial one. The PR is still under development. There are many things to do: adding test, refactoring. But I hope that I can get some feedback on the framework and the direction in early stage. PTAL when you have a moment.

@Irving-cl Irving-cl force-pushed the add_ncp_spinel branch 18 times, most recently from fc93d3d to 311bbb6 Compare May 17, 2024 07:12
@Irving-cl Irving-cl force-pushed the add_ncp_spinel branch 5 times, most recently from 607b9e6 to 340be32 Compare May 20, 2024 05:14
@Irving-cl
Copy link
Contributor Author

This PR is ready for review now. It seems to be difficult to break
the PR down into smaller PRs. Here is an abstraction of what the PR
does:

  1. Defined an interface (IControllerOpenThread) where we place the
    unified thread control APIs (for both NCP and RCP cases). In this PR,
    only one API (GetDeviceRole) is added for testing.
  2. The original core class ControllerOpenThread is renamed as ControllerOpenThreadRcp
    and refactor'ed as an implementation class of IControllerOpenThread.
    Most of its original methods still exist.
  3. Another class ControllerOpenThreadNcp is added to implement IControllerOpenThread
    and is used under NCP case.
  4. The dependencies on ControllerOpenThread of the current modules
    are not changed at this staged. For example, BackboneAgent, NdProxyManager,
    BorderAgent all depend on an instance of ControllerOpenThread.
    Now they still depend on ControllerOpenThreadRcp, instead of IControllerOpenThread.
    Currently these modules won't be initialized and started under NCP
    mode. We may change this when later working on enabling these modules
    under NCP mode.
  5. Refactor'ed the initialization process. Currently the modules hold
    a reference to ControllerOpenThread. And the reference is passed
    in the class constructors. In this PR, th reference is changed to
    pointer and pointer is passed in Init method because the instance
    is created later based on the co-processor type.
  6. Renamed the variable Ncp. Currently the variable name for an
    instance of ControllerOpenThread is mNcp or aNcp. This is
    confusing from my perspective. The PR changes all these names to
    Ctrlr (Controller).
  7. Added a test case to test the dbus API under NCP mode.

There is still a pending PR in openthread. Without it the CI here
fails. Please take a loook when you have a chance.
@zhanglongxia @abtink @superwhd

@Irving-cl Irving-cl marked this pull request as ready for review May 20, 2024 05:59
@Irving-cl Irving-cl added the P2 label May 20, 2024
@Irving-cl
Copy link
Contributor Author

Per discussion, the PR is still too large for review. I'll try to breakdown it.

The first breakdown PR is: #2294

Please review the simple one first. Thanks!

@Irving-cl
Copy link
Contributor Author

The second breakdown PR is: #2299

Copy link

codecov bot commented Jun 28, 2024

Codecov Report

Attention: Patch coverage is 11.76471% with 105 lines in your changes missing coverage. Please review.

Project coverage is 1.63%. Comparing base (2b41187) to head (f1ccb6a).
Report is 703 commits behind head on main.

Files Patch % Lines
src/ncp/ncp_spinel.cpp 10.43% 103 Missing ⚠️
src/ncp/ncp_host.cpp 66.66% 1 Missing ⚠️
src/ncp/ncp_spinel.hpp 0.00% 1 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main   #2283       +/-   ##
==========================================
- Coverage   55.77%   1.63%   -54.15%     
==========================================
  Files          87      91        +4     
  Lines        6890    9925     +3035     
  Branches        0     717      +717     
==========================================
- Hits         3843     162     -3681     
- Misses       3047    9756     +6709     
- Partials        0       7        +7     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@Irving-cl
Copy link
Contributor Author

This PR has been breakdown into a few PRs. Close this one.

@Irving-cl Irving-cl closed this Jun 28, 2024
@Irving-cl Irving-cl deleted the add_ncp_spinel branch August 22, 2024 05:58
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant