From: Jun Sun <jsun@mvista.com>
To: linux@cthulhu.engr.sgi.com, linux-mips@fnet.fr, ralf@oss.sgi.com
Subject: PROPOSAL : multi-way cache support in Linux/MIPS
Date: Tue, 01 Aug 2000 16:52:25 -0700 [thread overview]
Message-ID: <398762B9.D8507860@mvista.com> (raw)
Ralf,
I have got NEC DDB5476 running stable enough that I am comfortable to
check in
my code. Will you take it?
Assuming the answer is yes, there are several issues regarding checking
in.
I will bring them up one by one.
The first issue is multi-way cache support. DDB5476 uses R5432 CPU
which
has two-way set-associative cache. The problematic part is the
index-based cache operations in r4xxcache.h does not cover all ways in a
set.
I think this is a problem in general. So far I have seen MIPS
processors with
2-way, 4-way and 8-way sets. And I have seen them using ether least-
significant-addressing-bits or most-significant-addressing-bits
within a cache line to select ways.
Here is my proposal :
. introduce two variables,
cache_num_ways - number of ways in a set
cache_way_selection_offset - the offset added to the address to
select
next cache line in the same set. For LSBs addressing,
it is
equal to 1. For MSBs addressing, it is equal to
cache_line_size / cache_num_ways. (It can potentially
take
care of some future weired way-selection scheme as long
as
the offset is uniform)
. These variables are initialized in cpu_probe().
(Alternatively, I think we should have cpu_info table, that contains
all
these cpu information. Then a general routine can fill in the based
on
the cpu id. This can get rid of a bunch of ugly switch/case
statements.)
. in the include/asm/r4kcache.h file, all Index-based cache operation
needs
to changed like the following (for illustration only; need
optimization) :
-----
while(start < end) {
cache16_unroll32(start,Index_Writeback_Inv_D);
start += 0x200;
}
+++++
while(start < end) {
for (i=0; i< cache_num_ways; i++) {
cache16_unroll32(start +
i*cache_way_selection_offset,
Index_Writeback_Inv_D);
}
start += 0x200;
}
=====
What do you think? If it is OK, I can do the patch. The cpu_info table
is a nice wish, but I don't think I know enough to do that job yet.
Jun
next reply other threads:[~2000-08-01 23:57 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2000-08-01 23:52 Jun Sun [this message]
2000-08-02 18:12 ` PROPOSAL : multi-way cache support in Linux/MIPS Dominic Sweetman
2000-08-02 21:38 ` Jun Sun
-- strict thread matches above, loose matches on Subject: below --
2000-08-02 8:26 Kevin D. Kissell
2000-08-02 8:26 ` Kevin D. Kissell
2000-08-02 17:05 ` Jun Sun
2000-08-02 18:15 Kevin D. Kissell
2000-08-02 18:15 ` Kevin D. Kissell
2000-08-02 21:50 ` Jun Sun
2000-08-02 18:36 Kevin D. Kissell
2000-08-02 18:36 ` Kevin D. Kissell
2000-08-02 22:44 Kevin D. Kissell
2000-08-02 22:44 ` Kevin D. Kissell
2000-08-02 23:10 ` Jun Sun
2000-08-02 23:31 ` Ralf Baechle
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=398762B9.D8507860@mvista.com \
--to=jsun@mvista.com \
--cc=linux-mips@fnet.fr \
--cc=linux@cthulhu.engr.sgi.com \
--cc=ralf@oss.sgi.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox