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

arm: cortex a: cache management #53269

Closed
wants to merge 1 commit into from

Conversation

yroeht
Copy link
Contributor

@yroeht yroeht commented Dec 21, 2022

Implement cache management functions not only for Cortex-M but also for Cortex-A. Use CMSIS low level calls.

Signed-off-by: Théophile Ranquet [email protected]

Copy link
Member

@povergoing povergoing left a comment

Choose a reason for hiding this comment

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

Is it better to split the cache.c to cortex_a_r/cache.c and cortex_m/cache.c cause there are too many #if defineds
CC: @microbuilder @carlocaione @stephanosio

@yroeht
Copy link
Contributor Author

yroeht commented Dec 26, 2022

Is it better to split the cache.c to cortex_a_r/cache.c and cortex_m/cache.c cause there are too many #if defineds CC: @microbuilder @carlocaione @stephanosio

In my opinion this would make a lot of sense, I just didn't want to take that initiative on my own.

@carlocaione
Copy link
Collaborator

In my opinion this would make a lot of sense, I just didn't want to take that initiative on my own.

go for it.

Implement cache management functions not only for Cortex-M but also for
Cortex-A. Use CMSIS low level calls.

Signed-off-by: Théophile Ranquet <[email protected]>
@microbuilder
Copy link
Member

@carlocaione Mind having another look?

Comment on lines +51 to +57
uintptr_t addr = (uintptr_t)start_addr;
uintptr_t end_addr = (uintptr_t)addr + size;

addr /= CONFIG_DCACHE_LINE_SIZE;
addr *= CONFIG_DCACHE_LINE_SIZE;

for (; addr < end_addr; addr += CONFIG_DCACHE_LINE_SIZE)
Copy link
Collaborator

Choose a reason for hiding this comment

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

Can we put this preamble in an inline helper maybe?

addr *= CONFIG_DCACHE_LINE_SIZE;

for (; addr < end_addr; addr += CONFIG_DCACHE_LINE_SIZE)
L1C_InvalidateDCacheMVA((void *)start_addr);
Copy link
Collaborator

Choose a reason for hiding this comment

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

why are we acting on start_addr?

Comment on lines +68 to +69
addr /= CONFIG_DCACHE_LINE_SIZE;
addr *= CONFIG_DCACHE_LINE_SIZE;
Copy link
Collaborator

Choose a reason for hiding this comment

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

Is this correct? Let's say we have a 32 bytes cache line and you want to invalidate address 0x00000030, according to this code you end up invalidating only 0x00000020 to 0x00000040, if the memory content at 0x00000020 to 0x00000030 is dirty, you are corrupting the memory.

Copy link
Member

Choose a reason for hiding this comment

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

@yroeht FYI, it might help:)

* For the data cache invalidate operation, clean and invalidate
* the partial cache lines at both ends of the given range to
* prevent data corruption.
*
* For example (assume cache line size is 64 bytes):
* There are 2 consecutive 32-byte buffers, which can be cached in
* one line like below.
* +------------------+------------------+
* Cache line: | buffer 0 (dirty) | buffer 1 |
* +------------------+------------------+
* For the start address not aligned case, when invalidate the
* buffer 1, the full cache line will be invalidated, if the buffer
* 0 is dirty, its data will be lost.
* The same logic applies to the not aligned end address.

@github-actions
Copy link

This pull request has been marked as stale because it has been open (more than) 60 days with no activity. Remove the stale label or add a comment saying that you would like to have the label removed otherwise this pull request will automatically be closed in 14 days. Note, that you can always re-open a closed pull request at any time.

@github-actions github-actions bot added the Stale label Mar 12, 2023
@microbuilder
Copy link
Member

@yroeht Can you address some of the change requests here?

@github-actions github-actions bot removed the Stale label Mar 13, 2023
@microbuilder
Copy link
Member

Superseded by #56178

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area: ARM ARM (32-bit) Architecture
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

5 participants