RE: Reading an entire cacheline

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi all,

Please look at following codes:

save_flags(flags);
cli();
__asm__ __volatile__(
	"	.set	noreorder\n"
	"	.set	mips32\n"
	"2:	.set	mips3\n"
	"	cache	5, 0x00(%12)\n"
	"	.set	mips0\n"
	"	mfc0	%0, $28, 0\n"
	"	mfc0	%1, $28, 1\n"
	"	mfc0	%2, $29, 1\n"
	"	.set	mips3\n"
	"	cache	5, 0x08(%12)\n"
	"	.set	mips0\n"
	"	mfc0	%3, $28, 0\n"
	"	mfc0	%4, $28, 1\n"
	"	mfc0	%5, $29, 1\n"
	//"	bne	%0, %3, 2b\n"
	"	.set	mips3\n"
	"	cache	5, 0x10(%12)\n"
	"	.set	mips0\n"
	"	mfc0	%6, $28, 0\n"
	"	mfc0	%7, $28, 1\n"
	"	mfc0	%8, $29, 1\n"
	//"	bne	%0, %6, 2b\n"
	"	.set	mips3\n"
	"	cache	5, 0x18(%12)\n"
	"	.set	mips0\n"
	"	mfc0	%9, $28, 0\n"
	"	mfc0	%10, $28, 1\n"
	"	mfc0	%11, $29, 1\n"
	//"	bne	%0, %9, 2b\n"
	"	.set	mips0\n"
	"	.set	reorder"
	: "=r" (tag[1][way][0]), "=r" (datalo[1][way][0]),
	  "=r" (datahi[1][way][0]),
	  "=r" (tag[1][way][1]), "=r" (datalo[1][way][1]),
	  "=r" (datahi[1][way][1]),
	  "=r" (tag[1][way][2]), "=r" (datalo[1][way][2]),
	  "=r" (datahi[1][way][2]),
	  "=r" (tag[1][way][3]), "=r" (datalo[1][way][3]),
	  "=r" (datahi[1][way][3])
	: "r" (0x80000000 | (way << 14) | (line << 5))
);
restore_flags(flags);

Interrupt is disabled and no memory variable is touched while reading four
words in a cacheline. When bne instructions're activated, this code still
makes a infinitive loop. I don't know what does make changes in the d-cache.
Or.. am I doing something wrong? Any idea'll be welcomed. Thanks.

Regards,
JS.


PS. if you think my question is not proper in this mailing list, please let
me know.


-----Original Message-----
From: linux-mips-bounce@xxxxxxxxxxxxxx
[mailto:linux-mips-bounce@xxxxxxxxxxxxxx] On Behalf Of Kim, Jong-Sung
Sent: Monday, April 24, 2006 6:52 PM
To: linux-mips@xxxxxxxxxxxxxx
Subject: RE: Reading an entire cacheline

Dear Mr. Kissell and the others,

I apologize for my rude question if you felt like. I was first in this
mailing list and I didn't think I had to describe the background of my
problem such in depth. I have an application stored in an onboard block
device and it sometimes makes bus error or segmentation fault during
do_page_fault().
When the application is stored in and executed from an nfs device or an
ramfs or any other device, it works without any problem. So I think the
problem comes from the device driver or something below.
In some experiments, the cache invalidation in a point reduces the frequency
of abnormal terminations. (I don't know it's a walk-around or just reduction
yet) When the application was copied from the device onto the other (ram or
network) device, it works well. So I guess the problem is related to the
cache and not from just d-cache incoherency. I targeted the consistency
between d- and i-cache as first. If you have any idea, please let me know.
For the device driver for the block device is very large and not my work,
I'm still in the dark. ^^;

Thank you for your hints about the interrupt disabling and the variable
cachability. They could be very helpful for me. For the tag, I meant the
physical address field of the valid tag. Thank you again.


Regards,
JS.


-----Original Message-----
From: Kevin D. Kissell [mailto:kevink@xxxxxxxx] 
Sent: Monday, April 24, 2006 4:41 PM
To: Kim, Jong-Sung; linux-mips@xxxxxxxxxxxxxx
Subject: Re: Reading an entire cacheline

Yes, your question was too brief the first time around - I couldn't
tell what you were really asking.  I'm still not 100% sure of what
you're doing, though.   I don't want to sound insulting, but you're
disabling interrupts during this operation, right?  And if you're
copying the values into variables in memory, you're doing nothing
but non-cached references, right?  When you see the tags changing
on you, which bits are changing, and what are they defined to mean?

            Regards,

            Kevin K.

----- Original Message ----- 
From: "Kim, Jong-Sung" <jsungkim@xxxxxxx>
To: <linux-mips@xxxxxxxxxxxxxx>
Sent: Monday, April 24, 2006 9:23 AM
Subject: RE: Reading an entire cacheline


> Hi all,
> 
> Was my question too brief? I'm using MIPS5Kf core included in a Broadcom
> implemented processor and it has a 32kB d-cache and a same sized i-cache.
> Cache configuration is 2-way, 32-byte cacheline for both d- and i-cache
> without L2 cache. Of course, MIPS-port Linux as the kernel for it. And, a
> onboard block device has problem in its operation. I don't think it's a
> kernel problem. So I wanna inspect the contents of cache RAMs at the
device
> driver's context. I've added some lines of codes look like follow:
> 
> __asm__ __volatile__(
> ".set noreorder\n\t"
> ".set mips3\n\t"
> "cache 5, 0x00(%3)\n\t" // load d-cache tag
> ".set mips0\n\t" // by index
> ".set mips32\n\t"
> "mfc0 %0, $28, 0\n\t"
> "mfc0 %1, $28, 1\n\t"
> "mfc0 %2, $29, 1\n\t"
> .set mips0\n\t"
> .set reorder"
> : "=r" (tag), "=r" (data_lo), "=r" (data_hi)
> : "r" (0x80000000 | (way << 14) | (index << 5) | (word <<
> 3))
> );
> 
> This is executed for every index, every way, and every word. The thing
aches
> my head is the tags from a single cacheline differs. (very often for
> d-cache) So I modified the code to reread the cacheline from the first
word
> when the tag was modified before reading all four words. Then the code
never
> return. I couldn't find any related information from manual.
> 
> Please give me a hint for reading whole cacheline safely.
> 
> 
> -----Original Message-----
> From: linux-mips-bounce@xxxxxxxxxxxxxx
> [mailto:linux-mips-bounce@xxxxxxxxxxxxxx] On Behalf Of Kim, Jong-Sung
> Sent: Tuesday, April 18, 2006 9:37 AM
> To: linux-mips@xxxxxxxxxxxxxx
> Subject: Reading an entire cacheline
> 
> Hi,
> 
> Is there any way to read an entire cacheline from the MIPS5Kf? Four
> sequential cache instructions do similarly, but sometimes the tags from a
> same cacheline differ. How can I read a consistent cacheline safely?
> 
> Thanks.
> 
> 
> 
> 
> 
> 
> 
> 
> 
> 
> 
> 











[Index of Archives]     [Linux MIPS Home]     [LKML Archive]     [Linux ARM Kernel]     [Linux ARM]     [Linux]     [Git]     [Yosemite News]     [Linux SCSI]     [Linux Hams]

  Powered by Linux