Re: [PATCH] MIPS: PCI: Fix smp_processor_id() in preemptible

From: James Hogan
Date: Mon Jul 24 2017 - 19:42:31 EST


On Thu, Jul 20, 2017 at 04:04:43PM +0100, Matt Redfearn wrote:
> Commit 1c3c5eab1715 ("sched/core: Enable might_sleep() and
> smp_processor_id() checks early") enables checks for might_sleep() and
> smp_processor_id() being used in preemptible code earlier in the boot
> than before. This results in a new BUG from
> pcibios_set_cache_line_size().
>
> BUG: using smp_processor_id() in preemptible [00000000] code:
> swapper/0/1
> caller is pcibios_set_cache_line_size+0x10/0x70
> CPU: 1 PID: 1 Comm: swapper/0 Not tainted 4.13.0-rc1-00007-g3ce3e4ba4275 #615
> Stack : 0000000000000000 ffffffff81189694 0000000000000000 ffffffff81822318
> 000000000000004e 0000000000000001 800000000e20bd08 20c49ba5e3540000
> 0000000000000000 0000000000000000 ffffffff818d0000 0000000000000000
> 0000000000000000 ffffffff81189328 ffffffff818ce692 0000000000000000
> 0000000000000000 ffffffff81189bc8 ffffffff818d0000 0000000000000000
> ffffffff81828907 ffffffff81769970 800000020ec78d80 ffffffff818c7b48
> 0000000000000001 0000000000000001 ffffffff818652b0 ffffffff81896268
> ffffffff818c0000 800000020ec7fb40 800000020ec7fc58 ffffffff81684cac
> 0000000000000000 ffffffff8118ab50 0000000000000030 ffffffff81769970
> 0000000000000001 ffffffff81122a58 0000000000000000 0000000000000000
> ...
> Call Trace:
> [<ffffffff81122a58>] show_stack+0x90/0xb0
> [<ffffffff81684cac>] dump_stack+0xac/0xf0
> [<ffffffff813f7050>] check_preemption_disabled+0x120/0x128
> [<ffffffff818855e8>] pcibios_set_cache_line_size+0x10/0x70
> [<ffffffff81100578>] do_one_initcall+0x48/0x140
> [<ffffffff81865dc4>] kernel_init_freeable+0x194/0x24c
> [<ffffffff8169c534>] kernel_init+0x14/0x118
> [<ffffffff8111ca84>] ret_from_kernel_thread+0x14/0x1c
>
> Fix this by using raw_current_cpu_data instead.
>
> Signed-off-by: Matt Redfearn <matt.redfearn@xxxxxxxxxx>
> ---
>
> In heteregenerous systems the more correct fix for this would be to
> iterate over CPUs checking each ones cache hierarchy. However, as no
> such systems currently exist that seems wasteful.

I fear this may return to bite us at some point.

How about switching to using cpu_*cache_line_size(), which uses
cpu_data[0]? That way we'll at least be able to grep for users when the
macros are later fixed or removed.

Admitedly there is no cpu_tcache_line_size(), but it could be trivially
added.

Cheers
James

>
> ---
> arch/mips/pci/pci.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/arch/mips/pci/pci.c b/arch/mips/pci/pci.c
> index bd67ac74fe2d..7ef8d97fa324 100644
> --- a/arch/mips/pci/pci.c
> +++ b/arch/mips/pci/pci.c
> @@ -28,7 +28,7 @@ EXPORT_SYMBOL(PCIBIOS_MIN_MEM);
>
> static int __init pcibios_set_cache_line_size(void)
> {
> - struct cpuinfo_mips *c = &current_cpu_data;
> + struct cpuinfo_mips *c = &raw_current_cpu_data;
> unsigned int lsize;
>
> /*
> --
> 2.7.4
>
>

Attachment: signature.asc
Description: Digital signature