-
Notifications
You must be signed in to change notification settings - Fork 1.2k
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
SDP MSPI driver #18893
SDP MSPI driver #18893
Conversation
The following west manifest projects have changed revision in this Pull Request:
✅ All manifest checks OK Note: This message is automatically posted and updated by the Manifest GitHub Action. |
CI InformationTo view the history of this post, clich the 'edited' button above Inputs:Sources:sdk-nrf: PR head: e7aa8d4771810f535f3db720b857570c4aeb81c7 more detailssdk-nrf:
Github labels
List of changed files detected by CI (23)
Outputs:ToolchainVersion: 11349092be Test Spec & Results: ✅ Success; ❌ Failure; 🟠 Queued; 🟡 Progress; ◻️ Skipped;
|
You can find the documentation preview for this PR at this link. It will be updated about 10 minutes after the documentation build succeeds. Note: This comment is automatically posted by the Documentation Publishing GitHub Action. |
e660c0e
to
04e12ea
Compare
04e12ea
to
55aedeb
Compare
You can find the documentation preview for this PR at this link. It will be updated about 10 minutes after the documentation build succeeds. Note: This comment is automatically posted by the Documentation Publish GitHub Action. |
91bb39f
to
c2e11f9
Compare
Memory footprint analysis revealed the following potential issuessample.matter.template.debug[nrf7002dk/nrf5340/cpuapp]: High ROM usage: 911938[B] - link (cc: @kkasperczyk-no @ArekBalysNordic @markaj-nordic) Note: This message is automatically posted and updated by the CI (latest/sdk-nrf/PR-18893/32) |
c2e11f9
to
eedb55d
Compare
2df40f2
to
81dc879
Compare
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.
Test configuration look ok.
scripts/twister/alt/zephyr/tests/drivers/mspi/api/testcase.yaml
Outdated
Show resolved
Hide resolved
fd6a31a
to
bb4ab6a
Compare
bfa93e8
to
c4b8b0c
Compare
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.
Mostly nit comments.
case NRFE_MSPI_TXRX: { | ||
if (len) { | ||
ipc_received = len - 1; | ||
ipc_receive_buffer = (uint8_t *)&response->data; |
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.
It seems a bit too much to save an address of one uint8_t
, instead of copying it, especially because the pointer will most likely be of 32-bit size. So instead of creating one uint8_t
, we create a uint32_t
.
Unless it is supposed to be a preparation for receiving more data from FLPR. In that case, it can be left as it is.
return -EINVAL; | ||
} | ||
|
||
return xfer_packet(packet, xfer->timeout); |
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.
If this is the only place xfer_packet
function is used, then maybe xfer_packet
should be deleted and its body pasted here?
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.
Some more nit comments. You do not have to apply them in this PR, I do not want to block it.
#define D2_PIN 3 | ||
#define D3_PIN 4 | ||
#define CS_PIN 5 | ||
#include <drivers/mspi/nrfe_mspi.h> |
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.
I think there could be a separate header file for pin numbers/pin translation. I am not a fan of including the whole nrfe_mspi.h
here, HRT does not need to know FLPR response struct, for example.
However, I guess the pin numbers/pin translation can be changed in the future when pin checking is added, so it can stay as it is for now.
typedef struct __packed { | ||
uint8_t opcode; | ||
struct mspi_cfg cfg; | ||
} nrfe_mspi_cfg_t; | ||
|
||
typedef struct __packed { | ||
uint8_t opcode; | ||
struct mspi_dev_cfg cfg; | ||
} nrfe_mspi_dev_cfg_t; | ||
|
||
typedef struct __packed { | ||
uint8_t opcode; | ||
struct mspi_xfer xfer; | ||
} nrfe_mspi_xfer_t; | ||
|
||
typedef struct __packed { | ||
uint8_t opcode; | ||
struct mspi_xfer_packet packet; | ||
} nrfe_mspi_xfer_packet_t; |
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: If these structs have to be defined anyway, in order to have the same enum sizes on APP and FLPR, then why not define them in nrfe_mspi.h
and use them on APP side too while sending? Alternatively, a structure with union of Zephyr structures can be defined:
typedef struct __packed { | |
uint8_t opcode; | |
struct mspi_cfg cfg; | |
} nrfe_mspi_cfg_t; | |
typedef struct __packed { | |
uint8_t opcode; | |
struct mspi_dev_cfg cfg; | |
} nrfe_mspi_dev_cfg_t; | |
typedef struct __packed { | |
uint8_t opcode; | |
struct mspi_xfer xfer; | |
} nrfe_mspi_xfer_t; | |
typedef struct __packed { | |
uint8_t opcode; | |
struct mspi_xfer_packet packet; | |
} nrfe_mspi_xfer_packet_t; | |
typedef union __packed { | |
struct mspi_cfg cfg; | |
struct mspi_dev_cfg dev_cfg; | |
struct mspi_xfer xfer; | |
struct mspi_xfer_packet packet; | |
} nrfe_mspi_driver_data; | |
typedef struct __packed { | |
uint8_t opcode; | |
union nrfe_mspi_driver_data data; | |
} nrfe_mspi_ipc_data_t; |
* nrfe_mspi_pinctrl_soc_pin_t *pins_cfg = (nrfe_mspi_pinctrl_soc_pin_t *)data; | ||
* response.opcode = pins_cfg->opcode; | ||
* | ||
* for (uint8_t i = 0; i < NRFE_MSPI_PINS_MAX; i++) { | ||
* uint32_t psel = NRF_GET_PIN(pins_cfg->pin[i]); | ||
* uint32_t fun = NRF_GET_FUN(pins_cfg->pin[i]); | ||
* NRF_GPIO_Type *reg = nrf_gpio_pin_port_decode(&psel); | ||
* } |
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: there should be no commented-out code.
data_buffer[XFER_COMMAND_IDX] = 0xe5b326c1; | ||
data_buffer[XFER_ADDRESS_IDX] = 0xaabbccdd; | ||
|
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: since sample data is removed, this can also be removed.
c4b8b0c
to
167eea0
Compare
167eea0
to
f362b53
Compare
Add SDP MSPI driver, dts and include files. Signed-off-by: Jakub Zymelka <[email protected]>
Add new snippet files for SDP MSPI. Signed-off-by: Jakub Zymelka <[email protected]>
Add cmake files to be able to include the SDP MSPI application in solutions where SDP MSPI is required. Signed-off-by: Jakub Zymelka <[email protected]>
Add IPC solution based on icmsg to application for FLPR core to communicate with SDP MSPI driver. Signed-off-by: Jakub Zymelka <[email protected]>
Add yaml configuration to enable SDP MSPI API test. Signed-off-by: Jakub Zymelka <[email protected]>
f362b53
to
e7aa8d4
Compare
# Extract SoC name from related variables | ||
string(REPLACE "/" ";" split_board_qualifiers "${BOARD_QUALIFIERS}") | ||
list(GET split_board_qualifiers 1 target_soc) | ||
set(board_target_flpr "${BOARD}/${target_soc}/cpuflpr") | ||
set(target_soc) | ||
|
||
# Select the SDP application | ||
if(SB_CONFIG_SDP_GPIO) | ||
set(sdp_app_dir "${ZEPHYR_NRF_MODULE_DIR}/applications/sdp/gpio") |
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 really needs to come from a Kconfig like the network core image so people can add their own, will approve but fix in a follow up PR
SDP MSPI driver