public inbox for kernelnewbies@kernelnewbies.org
 help / color / mirror / Atom feed
* arm64: Question about barriers with the mmu off
@ 2020-11-16 11:58 Wonhyuk Yang
  2020-11-17  2:14 ` Valdis Klētnieks
  0 siblings, 1 reply; 7+ messages in thread
From: Wonhyuk Yang @ 2020-11-16 11:58 UTC (permalink / raw)
  To: kernelnewbies

Hi, I have a question about dmb barriers in arm64's head.S.
In the head.S, I could see the pattern below several times.

str w0, [x1]
dmb sys
dc ivac, x1   // Invalidate potentially stale cache line

I found that,
Commit(fix cache flushing and barriers in set_cpu_boot_mode_flag)
explained the code.

> This patch reworks the broken flushing code so that we:
>
> (1) Use a DMB to order the strongly-ordered write of the cacheline
> against the subsequent cache-maintenance operation (by-VA
> operations only hazard against normal, cacheable accesses).
>
> (2) Use a single dc ivac instruction to invalidate any clean lines
> containing a stale copy of the line after it has been updated.
> Use a DMB to order the strongly-> ordered write of the cacheline

But I can't  understand why the store operation should precede the
dc operation.

Is there any problem, if the dc operation precedes the store operation?

_______________________________________________
Kernelnewbies mailing list
Kernelnewbies@kernelnewbies.org
https://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2020-11-18  0:56 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2020-11-16 11:58 arm64: Question about barriers with the mmu off Wonhyuk Yang
2020-11-17  2:14 ` Valdis Klētnieks
2020-11-17  3:00   ` Wonhyuk Yang
2020-11-17  3:45     ` Valdis Klētnieks
2020-11-17  5:08       ` Wonhyuk Yang
2020-11-17  6:25         ` Valdis Klētnieks
2020-11-18  0:53           ` Wonhyuk Yang

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox