Flush cpu caches
Ian Lepore
ian at freebsd.org
Wed Jul 10 20:08:06 UTC 2019
On Tue, 2019-07-09 at 17:30 +0000, adr wrote:
> On Tue, 9 Jul 2019, Ian Lepore wrote:
>
> > Date: Tue, 09 Jul 2019 11:20:23 -0600
> > From: Ian Lepore <ian at freebsd.org>
> > To: adr <adr at SDF.ORG>, freebsd-arm at freebsd.org
> > Subject: Re: Flush cpu caches
> >
> > On Tue, 2019-07-09 at 16:54 +0000, adr wrote:
> > > First of all, hello everyone.
> > >
> > > I'm completely new to FreeBSD (not to BSD). I need to use
> > > something like arm_sync_icache(2) on OpenBSD and NetBSD.
> > >
> > > I'd find what I think I need in machine/cpufunc.h, but the linker
> > > can't find any function symbol. I suppose I have to pass a lib to
> > > the linker, but no idea which one.
> > >
> > > Some help?
> > >
> > > Thanks in advance,
> > > adr.
> > >
> >
> > Hmmm, we have a prototype for arm_sync_icache() but no library
> > function
> > for it. I'll make a note to look into that asap.
> >
> > Until I figure out how to add it properly, you could implement it
> > locally like this:
> >
> > #include <machine/sysarch.h>
> >
> > void arm_sync_icache(u_int addr, int len)
> > {
> > struct arm_sync_icache_args arg;
> >
> > arg.addr = (uintptr_t)addr;
> > arg.len = (uintptr_t)len;
> >
> > sysarch(ARM_SYNC_ICACHE, &arg);
> > }
> >
> > -- Ian
> >
> >
>
> ARM_SYNC_ICACHE
>
> Thanks a lot, that is all I need.
>
> I'll try to not be a pain in the *.
>
> adr.
For anyone interested, I've posted a review for adding
arm_drain_writebuf() and arm_sync_icache() calls to our libc, to be
compatible with the other *BSD systems...
https://reviews.freebsd.org/D20906
-- Ian
More information about the freebsd-arm
mailing list