Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp3667618iob; Sat, 7 May 2022 11:20:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzeKiv6hg+89qgAVRJOVlU4UyGKsBWpVGrKRln6HErf4kJ+M93pGYINsymn/DdQKw0wRNdY X-Received: by 2002:aa7:83d0:0:b0:50c:eb2b:8e8a with SMTP id j16-20020aa783d0000000b0050ceb2b8e8amr8950220pfn.31.1651947638752; Sat, 07 May 2022 11:20:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651947638; cv=none; d=google.com; s=arc-20160816; b=bIMs8dq0QvbNxlPipm4482k5uC2lw25AyrtuBJuJr9+CSRBAqC00dd4NIjeSBAQjwY olh5gDf2IGqcbdCtsfy9Qt9nxXZGdyWPEoP6Q/nh4DbhdsVjiejiNg4XqjDUBsJC1yk4 ABLsPDCthdhPRAyXuKuGTHmupGordrN4MtFEWkuT3VD6rZLE8piVIXJwojaOHvd29bFf aOvhpi7yw9F0Af1D5ufwvyohoDzVdEIRjk19HdPzCYEZhJlGHzplHbMLleGubsXFKU74 HUzCziCmIIcWiJXcj20iveRLAQgb8k60hZlZD9w6BvgenI0kBPEh330lNtoUEYu4jvbe eUFw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=oeCi0WJlUlmAdUeOo2uz48KTn4E3vAZHoMZo0EAAkuM=; b=iT7JiSETYdX4U42Hm0T2PjTuo3ke/hptwrl9JviyUmdxrqx/kQyvLgkRbhnJwNTTWy pG1kBu3RqFywJkROGo99abmD32OfGvGjaOiFfrYJCTI9tjud8eREp5E0MjV02bC1++0V dexeOphPaTbAvrMckaIC+ieFChZVP1cNp64jP1kAx5nWPsGv9kRFFxdR/bzvnxnmphyX 1l937hXHVd9ZPlVvCLyplcHZCvZPYSjprGI+usJ40N20v/kUJ+Mxpoa3z6hDlvOrZz1g qS1sEqDrL9FHdSTxEiUYOyPMs6IVE0W/ruBW+qyrmZgc56whJnFRdd2UvaeUTw+O6aUG XZZA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=Gg5ruBm2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id f12-20020a62380c000000b0050de3100e2asi7774129pfa.97.2022.05.07.11.20.25; Sat, 07 May 2022 11:20:38 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=Gg5ruBm2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1346371AbiEFSL3 (ORCPT + 99 others); Fri, 6 May 2022 14:11:29 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59716 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244654AbiEFSL0 (ORCPT ); Fri, 6 May 2022 14:11:26 -0400 Received: from mail-pg1-x52b.google.com (mail-pg1-x52b.google.com [IPv6:2607:f8b0:4864:20::52b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 382536A071 for ; Fri, 6 May 2022 11:07:43 -0700 (PDT) Received: by mail-pg1-x52b.google.com with SMTP id e5so6705144pgc.5 for ; Fri, 06 May 2022 11:07:43 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=oeCi0WJlUlmAdUeOo2uz48KTn4E3vAZHoMZo0EAAkuM=; b=Gg5ruBm21DzYEMBQr5TEYEc1ZQ7fUIgBCnTB6MXv3XeOLGNCg7AK+0aaUv6X+C40FB C1AgAN7/vfAEFz4C/EyjuyR88RWUdMSq/FXBwWFCXhdOWL8IPNPkzGYF+pCIin34BV0Q UT8Y3bBcpR7hia7BFnmou2ARRH3YINHkaijaw= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=oeCi0WJlUlmAdUeOo2uz48KTn4E3vAZHoMZo0EAAkuM=; b=RqhayMVcEaywZClDJPocxFqyVkBFzAvEcs1eyE8N4mNmGKLAj9Wrpo/XGsA/qFQRJe Uh8N4Q/2KQv9ZfWvPYzC4YVErXb1f9ayRG0ZQis+8tB0x7ru8gVftz6afB8Ac3Zxyqm1 AhuG7VlNBs+b0Lp9SdBzE/rDr4qOEsStnpmFq5Ixv2kezvY8+gIvtr6W7dowlufonO4l ZqEHG/+TREroUydPIxJfUceq3sxOsfxMlZ159oejmINNMPmycVA2K0kIq0uWtFsU46oa 573JuuPP43HWEeVaNqfo0z50vbad5TFiBWwqjlz368Qg3CruterkqsjPFOL97iBSle0U +42Q== X-Gm-Message-State: AOAM532vKwePv8g8C6vmT+iorQXvr8takPWqI7IzFh+k6Pwwsk0RtWlE ktBjlWmpJUhilcvHWqO05fgeow== X-Received: by 2002:aa7:8888:0:b0:50f:2e7a:76b7 with SMTP id z8-20020aa78888000000b0050f2e7a76b7mr4747567pfe.48.1651860462705; Fri, 06 May 2022 11:07:42 -0700 (PDT) Received: from localhost ([2620:15c:202:201:5605:d5cd:699b:1b26]) by smtp.gmail.com with UTF8SMTPSA id y10-20020a170902d64a00b0015e8d4eb2d8sm2031674plh.290.2022.05.06.11.07.41 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 06 May 2022 11:07:42 -0700 (PDT) Date: Fri, 6 May 2022 11:07:41 -0700 From: Matthias Kaehlcke To: Sibi Sankar Cc: bjorn.andersson@linaro.org, arnd@arndb.de, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, sboyd@kernel.org, agross@kernel.org, linux-remoteproc@vger.kernel.org, mathieu.poirier@linaro.org Subject: Re: [PATCH] remoteproc: qcom_q6v5_mss: map/unmap metadata region before/after use Message-ID: References: <1651845086-16535-1-git-send-email-quic_sibis@quicinc.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <1651845086-16535-1-git-send-email-quic_sibis@quicinc.com> X-Spam-Status: No, score=-2.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, May 06, 2022 at 07:21:26PM +0530, Sibi Sankar wrote: > The application processor accessing the dynamically assigned metadata > region after assigning it to the remote Q6 would lead to an XPU violation. > Fix this by un-mapping the metadata region post firmware header copy. The > metadata region is freed only after the modem Q6 is done with fw header > authentication. > > Signed-off-by: Sibi Sankar Should this have a 'Fixes:' tag? > --- > drivers/remoteproc/qcom_q6v5_mss.c | 43 +++++++++++++++++++++++++++++++------- > 1 file changed, 35 insertions(+), 8 deletions(-) > > diff --git a/drivers/remoteproc/qcom_q6v5_mss.c b/drivers/remoteproc/qcom_q6v5_mss.c > index af217de75e4d..eb34a258b67b 100644 > --- a/drivers/remoteproc/qcom_q6v5_mss.c > +++ b/drivers/remoteproc/qcom_q6v5_mss.c > @@ -10,6 +10,7 @@ > #include > #include > #include > +#include > #include > #include > #include > @@ -932,27 +933,52 @@ static void q6v5proc_halt_axi_port(struct q6v5 *qproc, > static int q6v5_mpss_init_image(struct q6v5 *qproc, const struct firmware *fw, > const char *fw_name) > { > - unsigned long dma_attrs = DMA_ATTR_FORCE_CONTIGUOUS; > + unsigned long dma_attrs = DMA_ATTR_FORCE_CONTIGUOUS | DMA_ATTR_NO_KERNEL_MAPPING; > + unsigned long flags = VM_DMA_COHERENT | VM_FLUSH_RESET_PERMS; > + struct page **pages; > + struct page *page; > dma_addr_t phys; > void *metadata; > int mdata_perm; > int xferop_ret; > size_t size; > - void *ptr; > + void *vaddr; > + int count; > int ret; > + int i; > > metadata = qcom_mdt_read_metadata(fw, &size, fw_name, qproc->dev); > if (IS_ERR(metadata)) > return PTR_ERR(metadata); > > - ptr = dma_alloc_attrs(qproc->dev, size, &phys, GFP_KERNEL, dma_attrs); > - if (!ptr) { > - kfree(metadata); > + page = dma_alloc_attrs(qproc->dev, size, &phys, GFP_KERNEL, dma_attrs); > + if (!page) { > dev_err(qproc->dev, "failed to allocate mdt buffer\n"); > - return -ENOMEM; > + ret = -ENOMEM; > + goto free_metadata; > + } > + > + count = PAGE_ALIGN(size) >> PAGE_SHIFT; > + pages = kmalloc_array(count, sizeof(struct page *), GFP_KERNEL); > + if (!pages) { > + ret = -ENOMEM; > + goto free_metadata; > } > > - memcpy(ptr, metadata, size); > + for (i = 0; i < count; i++) > + pages[i] = nth_page(page, i); > + > + vaddr = vmap(pages, count, flags, dma_pgprot(qproc->dev, PAGE_KERNEL, dma_attrs)); > + kfree(pages); > + if (!vaddr) { > + dev_err(qproc->dev, "unable to map memory region: %pa+%zx\n", &phys, size); > + ret = -EBUSY; > + goto free_metadata; > + } > + > + memcpy(vaddr, metadata, size); > + > + vunmap(vaddr); > > /* Hypervisor mapping to access metadata by modem */ > mdata_perm = BIT(QCOM_SCM_VMID_HLOS); > @@ -982,7 +1008,8 @@ static int q6v5_mpss_init_image(struct q6v5 *qproc, const struct firmware *fw, > "mdt buffer not reclaimed system may become unstable\n"); > > free_dma_attrs: > - dma_free_attrs(qproc->dev, size, ptr, phys, dma_attrs); > + dma_free_attrs(qproc->dev, size, page, phys, dma_attrs); > +free_metadata: > kfree(metadata); > > return ret < 0 ? ret : 0; > -- > 2.7.4 >