Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp3602407ybx; Sun, 3 Nov 2019 23:10:10 -0800 (PST) X-Google-Smtp-Source: APXvYqy6oXRxVB6wBkkW5LCVsdKT7C6OJqZYluE3zwm1d6vGy3YJaPbpulvWKTXF8SEGMBHG2P1I X-Received: by 2002:aa7:ca0c:: with SMTP id y12mr27392458eds.224.1572851410503; Sun, 03 Nov 2019 23:10:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1572851410; cv=none; d=google.com; s=arc-20160816; b=oMWwHWmi5/gWnkaIgdiB1HcZ0E6dmd8ZQ1CTTZXG3EX1HWxJqewdIXKyXBS9K01pcP DkqW/srkNL+u8BDDGv6eky/PB1aQvtI70YzOYBx7hLtzI76/+leosIiFyo0mXPMPt7Tc Ci2kbRmwBy9Jwkg2MVbnF6BxQ8yR2qmT/YXkU5AQTPK6wTYzPQZRaImbGW3ieWFleHFu 9RDw0n1gqjFicbeh8gOpbATnmT+ibetOrAqqiEzed21NvzY0MzDPIiXacbhkFZLrySZp zGHWVinTtQApV9qbYHhsYry8T4f6g6c3MjdqrQKpK82SuWZKyDYJgr4VeQIGgeeV6Z9t HE4w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:subject:message-id:date:from :mime-version:dkim-signature; bh=v3wRS/GCt1JcbtGZPLunVzhglTfqvaHyzRcXN60Gypc=; b=jJvfBiBYyhgQwAXIbM/LZ05q2LPio8P+MR3opcUDRGEKuVRXQguzczf8de08EUPvV1 2RoJjIDAl40CaGvUukbStEyfYRoS9JH3oToC/gAwk+nGcZv7McNWlg/V/U0ucpJ4j0OI D1mPT4dZqsx8Hgt3+e25igO4/Vwz2LchVriNSifTG07r07Q7QfM79/SyCvk2sR8KIcmh sG/TlKtzyZoD77WddiWaUO31cl9lFbJE896TRqfzkhKbL6xKIm9R883szNlIbP71xeI9 K3xAvdkx6acSUFkGanZ18D58mB+E1uU9zw2Kwsf66DMCGqSXa8aIr4B431Xg4w1F1tqE a/7w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Kmj2s2Wh; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d25si6947348edb.19.2019.11.03.23.09.46; Sun, 03 Nov 2019 23:10:10 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Kmj2s2Wh; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727788AbfKDHG4 (ORCPT + 99 others); Mon, 4 Nov 2019 02:06:56 -0500 Received: from mail-io1-f68.google.com ([209.85.166.68]:41732 "EHLO mail-io1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727267AbfKDHG4 (ORCPT ); Mon, 4 Nov 2019 02:06:56 -0500 Received: by mail-io1-f68.google.com with SMTP id r144so17214772iod.8; Sun, 03 Nov 2019 23:06:54 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:from:date:message-id:subject:to; bh=v3wRS/GCt1JcbtGZPLunVzhglTfqvaHyzRcXN60Gypc=; b=Kmj2s2WhR+XPsN5lHjLIX7ONh1QlAnYolGlDouLDW4frOZHIoj3qP03fR3JlgZQ/HQ QN5Ef8x2KeAwmS4Vn3pXhoQ2Jv53GGupsHzqzw9S/WDQMMIXvcSlg3b8qkxBrkR3cGuC 4FV5bz2mNwFuQ//tTgwmcSXn8Jo0y7RRpwiaMd+7EUukDhv0NcfIPmrWu8hXNF3A9jsy m4D28triGwlX6fPzPg+e4fwNgxjo2gxW4dEP5I0+QDtJkkgi3DfozK7QVW+ACqEoXTFp FrWPu3sON0UxdV1Qt9u6Jje2RCq4madKVgkOBjUgCNgQd1Cr/uYGNxeNyHqOUOuomDgo MoEg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:from:date:message-id:subject:to; bh=v3wRS/GCt1JcbtGZPLunVzhglTfqvaHyzRcXN60Gypc=; b=V0aTbcptAZjuy3sVCoTHYCW3QgdwTdTEoE+cx+WpVPWCE00owbbbMFurZObEI5xvfK 7o2ZiE/OJXn6S9V750vbdTvnRVg99u180LqZSzJEh5oP28WwVUBMFV2WlRYM7Rmm7xPO ajDoyADC1q8C6P8cQJnttt9cZ4bgIrZdfiLbhMtGhI34I7SjnfOpgIHKmLM3UwSJLjcG A2FK7+TNCqTMcF+JC7aYBGA6IOerlSbzlWE1DqAPFbxiZpXN+rukmOK7boaB7B4yKkat nYA3sFeh5VVl+2X3T3t1WdH//s8DjdSEASSCn7jln6WBaNK5DA85nSp7y6cf28DmpekO 4fIA== X-Gm-Message-State: APjAAAWiSRZ5ohDG+sB/6JC7JzHHerWDDZMwH784jkAffF6cO/rn3bQ8 tOoKecShPEIb/SJBjdgmzal6i69x3yAh8fYqNEjbHvNopPA= X-Received: by 2002:a5d:8e17:: with SMTP id e23mr11694586iod.263.1572851214146; Sun, 03 Nov 2019 23:06:54 -0800 (PST) MIME-Version: 1.0 From: youling 257 Date: Mon, 4 Nov 2019 15:06:37 +0800 Message-ID: Subject: Re: ALSA: pcm: use dma_can_mmap() to check if a device supports dma_mmap_* To: linux-xtensa@linux-xtensa.org, Michal Simek , Vladimir Murzin , linux-parisc@vger.kernel.org, linux-sh@vger.kernel.org, Takashi Iwai , linuxppc-dev@lists.ozlabs.org, Helge Deller , x86@kernel.org, Linux Kernel Mailing List , linux-m68k@lists.linux-m68k.org, Robin Murphy , linux-arm-kernel@lists.infradead.org, hch@lst.de, gregkh@google.com Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch cause oops on android mainline kernel about gadget audio_source. Androidx86 run on android mainline kernel. [ 385.104963] android_work: sent uevent USB_STATE=CONNECTED [ 385.109006] android_work: sent uevent USB_STATE=DISCONNECTED [ 385.182024] android_work: sent uevent USB_STATE=CONNECTED [ 385.184737] configfs-gadget gadget: high-speed config #1: b [ 385.184921] android_work: sent uevent USB_STATE=CONFIGURED [ 385.285268] BUG: kernel NULL pointer dereference, address: 0000000000000220 [ 385.285339] #PF: supervisor read access in kernel mode [ 385.285374] #PF: error_code(0x0000) - not-present page [ 385.285436] PGD 80000000791e6067 P4D 80000000791e6067 PUD 0 [ 385.285473] Oops: 0000 [#1] PREEMPT SMP PTI [ 385.285509] CPU: 0 PID: 5780 Comm: Binder:1383_5 Tainted: G O 5.4.0-rc6-android-x86_64+ #1 [ 385.285571] Hardware name: Insyde ONDA Tablet/ONDA Tablet, BIOS ONDA.D890HBBNR0A 03/11/2015 [ 385.285639] RIP: 0010:dma_can_mmap+0x5/0x30 [ 385.285675] Code: 74 11 e9 ae 98 b2 00 48 8b 05 9f 40 94 01 48 85 c0 75 e3 31 c0 c3 66 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 40 00 0f 1f 44 00 00 <48> 8b 87 20 02 00 00 48 85 c0 74 09 48 83 78 10 00 0f 95 c0 c3 48 [ 385.285762] RSP: 0018:ffffb39443b63b78 EFLAGS: 00010246 [ 385.285797] RAX: 0000000000000001 RBX: ffffa28b91756600 RCX: 0000000000000040 [ 385.285857] RDX: ffffffffb62b2a00 RSI: 0000000000000000 RDI: 0000000000000000 [ 385.285917] RBP: ffffa28bac69f800 R08: ffffffffb63141b0 R09: ffffa28bf9a34a88 [ 385.285952] R10: ffffffffb62b2be0 R11: ffffffffb62b2bd0 R12: 0000000000000008 [ 385.286013] R13: 0000000000000000 R14: ffffa28bacd736a8 R15: ffffa28bacd736c8 [ 385.286076] FS: 0000000000000000(0000) GS:ffffa28bfb600000(0063) knlGS:00000000f5d81970 [ 385.286110] CS: 0010 DS: 002b ES: 002b CR0: 0000000080050033 [ 385.286171] CR2: 0000000000000220 CR3: 000000007b2f6000 CR4: 00000000001006f0 [ 385.286232] Call Trace: [ 385.286275] snd_pcm_hw_constraints_complete+0x3e/0x1f0 [ 385.286314] snd_pcm_open_substream+0x94/0x140 [ 385.286377] snd_pcm_open+0xf0/0x240 [ 385.286416] ? wake_up_q+0x60/0x60 [ 385.286460] snd_pcm_playback_open+0x3d/0x60 [ 385.286533] chrdev_open+0xa2/0x1c0 [ 385.286574] ? cdev_put.part.0+0x20/0x20 [ 385.286615] do_dentry_open+0x13a/0x380 [ 385.286686] path_openat+0x588/0x15d0 [ 385.286728] do_filp_open+0x91/0x100 [ 385.286769] ? __check_object_size+0x136/0x147 [ 385.286840] do_sys_open+0x184/0x280 [ 385.286880] ? handle_mm_fault+0xd7/0x1c0 [ 385.286920] do_fast_syscall_32+0x8e/0x250 [ 385.286992] entry_SYSENTER_compat+0x7c/0x8e [ 385.287302] CR2: 0000000000000220 [ 385.287391] ---[ end trace 73ffcefcbbe2b9a0 ]--- [ 385.296269] RIP: 0010:dma_can_mmap+0x5/0x30 [ 385.296337] Code: 74 11 e9 ae 98 b2 00 48 8b 05 9f 40 94 01 48 85 c0 75 e3 31 c0 c3 66 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 40 00 0f 1f 44 00 00 <48> 8b 87 20 02 00 00 48 85 c0 74 09 48 83 78 10 00 0f 95 c0 c3 48 [ 385.296407] RSP: 0018:ffffb39443b63b78 EFLAGS: 00010246 [ 385.296477] RAX: 0000000000000001 RBX: ffffa28b91756600 RCX: 0000000000000040 [ 385.296516] RDX: ffffffffb62b2a00 RSI: 0000000000000000 RDI: 0000000000000000 [ 385.296584] RBP: ffffa28bac69f800 R08: ffffffffb63141b0 R09: ffffa28bf9a34a88 [ 385.296654] R10: ffffffffb62b2be0 R11: ffffffffb62b2bd0 R12: 0000000000000008 [ 385.296693] R13: 0000000000000000 R14: ffffa28bacd736a8 R15: ffffa28bacd736c8 [ 385.296761] FS: 0000000000000000(0000) GS:ffffa28bfb600000(0063) knlGS:00000000f5d81970 [ 385.296830] CS: 0010 DS: 002b ES: 002b CR0: 0000000080050033 [ 385.296867] CR2: 0000000000000220 CR3: 000000007b2f6000 CR4: 00000000001006f0 [ 385.296936] Kernel panic - not syncing: Fatal exception [ 385.296985] Kernel Offset: 0x33e00000 from 0xffffffff81000000 (relocation range: 0xffffffff80000000-0xffffffffbfffffff) [ 385.305185] Rebooting in 5 seconds.. Revert it no the oops. Revert "ALSA: pcm: use dma_can_mmap() to check if a device supports dma_mmap_*" This reverts commit 425da159707b271dc865d7e167ac104a0e60e4af. --- sound/core/pcm_native.c | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c index 91c6ad58729f..61f6229c9124 100644 --- a/sound/core/pcm_native.c +++ b/sound/core/pcm_native.c @@ -220,12 +220,13 @@ static bool hw_support_mmap(struct snd_pcm_substream *substream) { if (!(substream->runtime->hw.info & SNDRV_PCM_INFO_MMAP)) return false; - - if (substream->ops->mmap || - substream->dma_buffer.dev.type != SNDRV_DMA_TYPE_DEV) - return true; - - return dma_can_mmap(substream->dma_buffer.dev.dev); + /* architecture supports dma_mmap_coherent()? */ +#if defined(CONFIG_MMU) || !defined(CONFIG_HAS_DMA) + if (!substream->ops->mmap && + substream->dma_buffer.dev.type == SNDRV_DMA_TYPE_DEV) + return false; +#endif + return true; } static int constrain_mask_params(struct snd_pcm_substream *substream,