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

drivers: dma: Introduce driver for NXP's eDMA IP #65671

Merged
merged 2 commits into from
Jan 23, 2024

Conversation

LaurentiuM1234
Copy link
Collaborator

@LaurentiuM1234 LaurentiuM1234 commented Nov 23, 2023

Please check commit c63a3e7's description for reason why this driver is used instead of dma_mcux_edma.

@zephyrbot
Copy link
Collaborator

zephyrbot commented Nov 23, 2023

The following west manifest projects have been modified in this Pull Request:

Name Old Revision New Revision Diff
hal_nxp zephyrproject-rtos/hal_nxp@9b2693c zephyrproject-rtos/hal_nxp@d6d43ca (master) zephyrproject-rtos/[email protected]

Note: This message is automatically posted and updated by the Manifest GitHub Action.

@teburd
Copy link
Collaborator

teburd commented Nov 23, 2023

I’m ok with having another eDMA, what I did with the designware dma is try to create a common set of functions and reuse them where possible as there are many users of the designware gpdma. It would be nice if eDMA did something similar if possible. Like if there’s common transfer block definitions and configuration registers for example some helpers could be made to reuse between the two.

@LaurentiuM1234
Copy link
Collaborator Author

I’m ok with having another eDMA, what I did with the designware dma is try to create a common set of functions and reuse them where possible as there are many users of the designware gpdma. It would be nice if eDMA did something similar if possible. Like if there’s common transfer block definitions and configuration registers for example some helpers could be made to reuse between the two.

ACK. If everyone's ok with this, I'd like to have this in first as-is before making such clean-ups. It would make it a bit easier for me and I'm thinking it would also ease the review process a bit.

@LaurentiuM1234
Copy link
Collaborator Author

V4 updates

  1. Changed naming to dma_nxp_edma. No functional change.

@LaurentiuM1234
Copy link
Collaborator Author

@DerekSnell could you please review this again? Thanks!

dbaluta
dbaluta previously approved these changes Jan 17, 2024
decsny
decsny previously requested changes Jan 17, 2024
Copy link
Member

@decsny decsny left a comment

Choose a reason for hiding this comment

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

I do not think it is efficicient to maintain 2 EDMA drivers if it's not necessary. Can you please be more concrete about why we cannot reuse code for the legacy EDMA versions, because I do not understand from your comments.

@decsny decsny dismissed their stale review January 17, 2024 20:12

removed for internal discussion about edma roadmap

Copy link
Contributor

@DerekSnell DerekSnell left a comment

Choose a reason for hiding this comment

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

Hi @LaurentiuM1234,

Thank you for updating this PR. There are still some references to i.MX I want removed, since this driver could be used on other SOCs. But once you remove those, I will remove my block. Thank you

drivers/dma/Kconfig.nxp_edma Outdated Show resolved Hide resolved
dts/bindings/dma/nxp,edma.yaml Outdated Show resolved Hide resolved
drivers/dma/Kconfig.nxp_edma Outdated Show resolved Hide resolved
drivers/dma/dma_nxp_edma.c Outdated Show resolved Hide resolved
drivers/dma/dma_nxp_edma.h Outdated Show resolved Hide resolved
dts/bindings/dma/nxp,edma.yaml Outdated Show resolved Hide resolved
dts/bindings/dma/nxp,edma.yaml Outdated Show resolved Hide resolved
@LaurentiuM1234
Copy link
Collaborator Author

Hi @LaurentiuM1234,

Thank you for updating this PR. There are still some references to i.MX I want removed, since this driver could be used on other SOCs. But once you remove those, I will remove my block. Thank you

Should be fixed now

dbaluta
dbaluta previously approved these changes Jan 18, 2024
drivers/dma/dma_nxp_edma.c Show resolved Hide resolved
drivers/dma/dma_nxp_edma.c Outdated Show resolved Hide resolved
drivers/dma/dma_nxp_edma.c Show resolved Hide resolved
iuliana-prodan
iuliana-prodan previously approved these changes Jan 18, 2024
@DerekSnell DerekSnell dismissed their stale review January 18, 2024 22:23

Thank you @LaurentiuM1234, for addressing my comments. I have removed my block

Bump up hal_nxp revision to contain the EDMA REV2-related
changes from NXP HAL.

Signed-off-by: Laurentiu Mihalcea <[email protected]>
This commit introduces a driver for NXP's eDMA IP.

The main reasons for introducing a new driver are the following:

	1) The HAL EDMA wrappers don't support well different
	eDMA versions (e.g: i.MX93 and i.MX8QM). As such, a new
	revision had to be introduced, thus requiring a new Zephyr
	driver.

	2) The eDMA versions found on i.MX93, i.MX8QM, and i.MX8QXP
	don't use the DMAMUX IP (instead, channel MUX-ing is performed
	through an eDMA register in the case of i.MX93).

Signed-off-by: Laurentiu Mihalcea <[email protected]>
@zephyrbot zephyrbot added platform: NXP Drivers NXP Semiconductors, drivers and removed DNM This PR should not be merged (Do Not Merge) labels Jan 22, 2024
@LaurentiuM1234
Copy link
Collaborator Author

dependency merged, should be good to go as well once CI is green

@dbaluta
Copy link
Collaborator

dbaluta commented Jan 23, 2024

@teburd @dleach02 good to merge. dependency merged and SHA updated.

@nashif nashif merged commit 6abc592 into zephyrproject-rtos:main Jan 23, 2024
22 of 24 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area: Devicetree Binding PR modifies or adds a Device Tree binding area: DMA Direct Memory Access manifest manifest-hal_nxp platform: NXP Drivers NXP Semiconductors, drivers platform: NXP NXP
Projects
None yet
Development

Successfully merging this pull request may close these issues.

9 participants