From: Huang Pei <huangpei@loongson.cn>
To: "Maciej W. Rozycki" <macro@orcam.me.uk>
Cc: Thomas Bogendoerfer <tsbogend@alpha.franken.de>,
ambrosehua@gmail.com, Bibo Mao <maobibo@loongson.cn>,
Andrew Morton <akpm@linux-foundation.org>,
linux-mips@vger.kernel.org, linux-arch@vger.kernel.org,
linux-mm@kvack.org, Jiaxun Yang <jiaxun.yang@flygoat.com>,
Paul Burton <paulburton@kernel.org>,
Li Xuefeng <lixuefeng@loongson.cn>,
Yang Tiezhu <yangtiezhu@loongson.cn>,
Gao Juxin <gaojuxin@loongson.cn>,
Fuxin Zhang <zhangfx@lemote.com>, Huacai Chen <chenhc@lemote.com>
Subject: Re: [PATCH] MIPS: clean up CONFIG_MIPS_PGD_C0_CONTEXT handling
Date: Fri, 5 Mar 2021 15:13:22 +0800 [thread overview]
Message-ID: <20210305071322.srv5gv5sro5p4dll@ambrosehua-HP-xw6600-Workstation> (raw)
In-Reply-To: <alpine.DEB.2.21.2103040227500.19637@angie.orcam.me.uk>
Hi,
On Thu, Mar 04, 2021 at 02:40:54AM +0100, Maciej W. Rozycki wrote:
> On Thu, 4 Mar 2021, Huang Pei wrote:
>
> > > > @@ -1164,8 +1165,8 @@ build_fast_tlb_refill_handler (u32 **p, struct uasm_label **l,
> > > >
> > > > if (pgd_reg == -1) {
> > > > vmalloc_branch_delay_filled = 1;
> > > > - /* 1 0 1 0 1 << 6 xkphys cached */
> > > > - uasm_i_ori(p, ptr, ptr, 0x540);
> > > > + /* insert bit[63:59] of CAC_BASE into bit[11:6] of ptr */
> > > > + uasm_i_ori(p, ptr, ptr, (CAC_BASE >> 53));
> > >
> > > Instead I'd paper the issue over by casting the constant to `s64'.
> > >
> > > Or better yet fixed it properly by defining CAC_BASE, etc. as `unsigned
> > > long long' long rather than `unsigned long' to stop all this nonsense
> > > (e.g. PHYS_TO_XKPHYS already casts the result to `s64'). Thomas, WDYT?
> > Sorry, I do not get it , on MIPS32, how can CAC_BASE be unsigned long
> > long ?
>
> By using the `ULL' suffix with constants. It won't change code produced,
> because they are unsigned anyway and the compiler will truncate them with
> no change to the actual value to fit in narrower data types as needed, but
> it will silence the warnings.
>
> Maciej
On Linux 5.11 with this patch and **ONLY** attaching ULL to CAC_BASE in
arch/mips/include/asm/mach-generic/space.h for CONFIG_32BIT, cross gcc
7.5 in Ubuntu 18.04, loongon1c_defconfig
..........
make[1]: Entering directory '/home/hp/projects/Linux/temp/out_stable'
GEN Makefile
CALL /home/hp/projects/Linux/temp/linux-stable/scripts/atomic/check-atomics.sh
CALL /home/hp/projects/Linux/temp/linux-stable/scripts/checksyscalls.sh
CC arch/mips/mm/cache.o
CC arch/mips/kernel/branch.o
CC arch/mips/mm/context.o
CC arch/mips/loongson32/common/time.o
CC arch/mips/loongson32/ls1c/board.o
CHK include/generated/compile.h
CC arch/mips/vdso/vgettimeofday.o
HOSTCC arch/mips/vdso/genvdso
CC kernel/sched/cputime.o
In file included from /home/hp/projects/Linux/temp/linux-stable/arch/mips/include/asm/mmiowb.h:5:0,
from /home/hp/projects/Linux/temp/linux-stable/include/linux/spinlock.h:61,
from /home/hp/projects/Linux/temp/linux-stable/include/linux/wait.h:9,
from /home/hp/projects/Linux/temp/linux-stable/include/linux/wait_bit.h:8,
from /home/hp/projects/Linux/temp/linux-stable/include/linux/fs.h:6,
from /home/hp/projects/Linux/temp/linux-stable/arch/mips/mm/cache.c:9:
/home/hp/projects/Linux/temp/linux-stable/arch/mips/include/asm/io.h: In function ‘phys_to_virt’:
/home/hp/projects/Linux/temp/linux-stable/arch/mips/include/asm/io.h:122:9: error: cast to pointer
from integer of different size [-Werror=int-to-pointer-cast]
return (void *)(address + PAGE_OFFSET - PHYS_OFFSET);
^
In file included from /home/hp/projects/Linux/temp/linux-stable/arch/mips/include/asm/mmiowb.h:5:0,
from /home/hp/projects/Linux/temp/linux-stable/include/linux/spinlock.h:61,
from /home/hp/projects/Linux/temp/linux-stable/include/linux/wait.h:9,
from /home/hp/projects/Linux/temp/linux-stable/include/linux/pid.h:6,
from /home/hp/projects/Linux/temp/linux-stable/include/linux/sched.h:14,
from /home/hp/projects/Linux/temp/linux-stable/include/linux/sched/signal.h:7,
from /home/hp/projects/Linux/temp/linux-stable/arch/mips/kernel/branch.c:10:
/home/hp/projects/Linux/temp/linux-stable/arch/mips/include/asm/io.h: In function ‘phys_to_virt’:
/home/hp/projects/Linux/temp/linux-stable/arch/mips/include/asm/io.h:122:9: error: cast to pointer
from integer of different size [-Werror=int-to-pointer-cast]
return (void *)(address + PAGE_OFFSET - PHYS_OFFSET);
.........
Only change CAC_BASE Does NOT work
Huang Pei
next prev parent reply other threads:[~2021-03-05 7:13 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-02-27 6:19 [PATCH V2] MIPS: clean up CONFIG_MIPS_PGD_C0_CONTEXT Huang Pei
2021-02-27 6:19 ` [PATCH] MIPS: clean up CONFIG_MIPS_PGD_C0_CONTEXT handling Huang Pei
2021-02-28 23:00 ` Maciej W. Rozycki
2021-03-04 1:06 ` Huang Pei
2021-03-04 1:40 ` Maciej W. Rozycki
2021-03-05 7:13 ` Huang Pei [this message]
2021-03-07 20:54 ` Maciej W. Rozycki
2021-03-08 1:27 ` huangpei
2021-03-13 1:39 [PATCH V5] MIPS: clean up MIPS_PGD_C0_CONTEXT Huang Pei
2021-03-13 1:39 ` [PATCH] MIPS: clean up CONFIG_MIPS_PGD_C0_CONTEXT handling Huang Pei
2021-03-14 13:09 ` Thomas Bogendoerfer
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=20210305071322.srv5gv5sro5p4dll@ambrosehua-HP-xw6600-Workstation \
--to=huangpei@loongson.cn \
--cc=akpm@linux-foundation.org \
--cc=ambrosehua@gmail.com \
--cc=chenhc@lemote.com \
--cc=gaojuxin@loongson.cn \
--cc=jiaxun.yang@flygoat.com \
--cc=linux-arch@vger.kernel.org \
--cc=linux-mips@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=lixuefeng@loongson.cn \
--cc=macro@orcam.me.uk \
--cc=maobibo@loongson.cn \
--cc=paulburton@kernel.org \
--cc=tsbogend@alpha.franken.de \
--cc=yangtiezhu@loongson.cn \
--cc=zhangfx@lemote.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