Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp6768380imu; Mon, 3 Dec 2018 02:27:25 -0800 (PST) X-Google-Smtp-Source: AFSGD/XAwNKz/Gf63tJ4Ic92/F+sMlYg3GI6+LbCJ/wC41xdko/xN/GTeAQQVbHh/yYLI4xxTTxq X-Received: by 2002:a17:902:bb05:: with SMTP id l5mr15673459pls.230.1543832845188; Mon, 03 Dec 2018 02:27:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543832845; cv=none; d=google.com; s=arc-20160816; b=iB6wA/zfa8wXMeb7rNrNEyOwfmMn8A0xOY+3s9oY6BFMQh/3b3otK7Dz7XMBFbxIgL txWTKj6JgZzogsL4C9L8IzCbv+Bwv8YyxJ8S93JkX+CWUmEdKNPFuuKFqyEdPOiX8fbv wsJhvg1CGYMe/Ku2SyUHhR9MkAFwtmAaexSekr1drxOuwC56uSfJUNDejVzpBlcOVyib A7HlViqR+KrjxEst8nbVqgtunw+vojTTx8vwmNdAr+deEobuAFjHlTkVg/JcLcU/dtsU 4uIS9zB9YgXGnjbaFcsmHkQt/oQbNr1USGAw/uiHqRx0RqwpgQuhOjN881QCaCoQMMRw f8WA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:to :from; bh=8U3lYsFNgzSXjIFmiMRKHYoYk0S1yEUBfaDR0UrVMtE=; b=R40SpnSHjXD/W6nsLrSylbiV80fX8gp35laKOLuK/Y06J2VztO4aFc0Z6mo8ikEUVj /3O6GnwSt00xad+25Ufv3VA5r/XuiSEOyhApNVJ3pDAytOd37pIR5mPwfGJ3AWnBrZAq GQq8JhiCRtW0Ec9DVNblqAvb7Ab27hGRoyhlJC1OSNW9qtl9xSudrS/lk2U/ybHjqeX1 rzduatrDrXosjwNLrbFdisRJeCDbeOycaT77uEBmpLYMUwuO1G1tQptsk9GedLdR1aOJ OcKaae27enV9J1ReRJ1jfFqoiC4i+PGpRLCxwIx/v0zLxhfOg/fFcIoUo/pEEr9Jnuif 80aw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e7si14405939pfh.147.2018.12.03.02.27.10; Mon, 03 Dec 2018 02:27:25 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726313AbeLCKZr (ORCPT + 99 others); Mon, 3 Dec 2018 05:25:47 -0500 Received: from mail.windriver.com ([147.11.1.11]:53892 "EHLO mail.windriver.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726045AbeLCKZr (ORCPT ); Mon, 3 Dec 2018 05:25:47 -0500 Received: from ALA-HCA.corp.ad.wrs.com ([147.11.189.40]) by mail.windriver.com (8.15.2/8.15.1) with ESMTPS id wB3AMsQX029793 (version=TLSv1 cipher=AES128-SHA bits=128 verify=FAIL); Mon, 3 Dec 2018 02:22:55 -0800 (PST) Received: from pek-lpg-core2.corp.ad.wrs.com (128.224.153.41) by ALA-HCA.corp.ad.wrs.com (147.11.189.40) with Microsoft SMTP Server id 14.3.408.0; Mon, 3 Dec 2018 02:22:54 -0800 From: To: , , , , , , , Subject: [PATCH v2] kernel/dma: Fix panic caused by passing swiotlb to command line Date: Mon, 3 Dec 2018 18:22:51 +0800 Message-ID: <1543832571-121638-1-git-send-email-zhe.he@windriver.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: He Zhe setup_io_tlb_npages does not check input argument before passing it to isdigit. The argument would be a NULL pointer if "swiotlb", without its value, is set in command line and thus causes the following panic. PANIC: early exception 0xe3 IP 10:ffffffffbb9b8e9f error 0 cr2 0x0 [ 0.000000] CPU: 0 PID: 0 Comm: swapper Not tainted 4.19.0-rc3-yocto-standard+ #9 [ 0.000000] RIP: 0010:setup_io_tlb_npages+0xf/0x95 ... [ 0.000000] Call Trace: [ 0.000000] do_early_param+0x57/0x8e [ 0.000000] parse_args+0x208/0x320 [ 0.000000] ? rdinit_setup+0x30/0x30 [ 0.000000] parse_early_options+0x29/0x2d [ 0.000000] ? rdinit_setup+0x30/0x30 [ 0.000000] parse_early_param+0x36/0x4d [ 0.000000] setup_arch+0x336/0x99e [ 0.000000] start_kernel+0x6f/0x4e6 [ 0.000000] x86_64_start_reservations+0x24/0x26 [ 0.000000] x86_64_start_kernel+0x6f/0x72 [ 0.000000] secondary_startup_64+0xa4/0xb0 This patch adds a check to prevent the panic and sets it for 4MB by default. Signed-off-by: He Zhe Cc: stable@vger.kernel.org Cc: konrad.wilk@oracle.com Cc: hch@lst.de Cc: m.szyprowski@samsung.com Cc: robin.murphy@arm.com Signed-off-by: He Zhe --- v2: Set swiotlb for 4MB by default kernel/dma/swiotlb.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/kernel/dma/swiotlb.c b/kernel/dma/swiotlb.c index 045930e..0e18cd4 100644 --- a/kernel/dma/swiotlb.c +++ b/kernel/dma/swiotlb.c @@ -58,6 +58,9 @@ */ #define IO_TLB_MIN_SLABS ((1<<20) >> IO_TLB_SHIFT) +#define IO_TLB_DEFAULT_MB 4 +#define IO_TLB_DEFAULT_SLABS ((IO_TLB_DEFAULT_MB<<20) >> IO_TLB_SHIFT) + enum swiotlb_force swiotlb_force; /* @@ -103,6 +106,14 @@ static int late_alloc; static int __init setup_io_tlb_npages(char *str) { + if (!str) { + pr_err("No value provided for swiotlb, " + "set it to %d slabs for %dMB by default.\n", + IO_TLB_DEFAULT_SLABS, IO_TLB_DEFAULT_MB); + io_tlb_nslabs = IO_TLB_DEFAULT_SLABS; + return 0; + } + if (isdigit(*str)) { io_tlb_nslabs = simple_strtoul(str, &str, 0); /* avoid tail segment of size < IO_TLB_SEGSIZE */ -- 2.7.4