From nobody Tue May 14 18:21:12 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=fail; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org ARC-Seal: i=1; a=rsa-sha256; t=1597403040; cv=none; d=zohomail.com; s=zohoarc; b=YpOG0OoQ+s6iZAHiJ190qRgM22tduSDMxzTEl+F2cfIZUsUy+kYPHXdOXG7qJS7deM+wnkeiN+vTmwxG9KK7trtw4X6fMpsEkMavLII/qNmbn/XPsEsbPM5XScZF871Q6n5C5f4leWlVaCP/fdBtAk/EjH/Blgtdu1TG1tlpE5s= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1597403040; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:Sender:Subject:To; bh=82YNUrJPpt+U6i+zsZg8jmPLYqtlltwueOh8XQCPKmQ=; b=VxZlRQ4ksFACMrWtdPoqc8Oh7nLR9QoiuflInE2/DmNrggThibdsgmiC03CNfVAbY9dt1V0yHnu31+e3/7BBcsPJiqCHMYLsWRIu0NvHdOmz0OZ3QombkJvWDgfjmNO9Cyk4x+o4avDV7Pis+cTvU/F+u5JPZPv7bjC75Ge3FWo= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=fail; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1597403040630429.12764631446146; Fri, 14 Aug 2020 04:04:00 -0700 (PDT) Received: from localhost ([::1]:55478 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1k6XV9-00058Q-AZ for importer@patchew.org; Fri, 14 Aug 2020 07:03:59 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:43382) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1k6XSK-0003FU-Kd; Fri, 14 Aug 2020 07:01:04 -0400 Received: from mail-wr1-x441.google.com ([2a00:1450:4864:20::441]:46081) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1k6XSI-0000Jl-On; Fri, 14 Aug 2020 07:01:04 -0400 Received: by mail-wr1-x441.google.com with SMTP id f12so7946451wru.13; Fri, 14 Aug 2020 04:01:01 -0700 (PDT) Received: from localhost.localdomain (121.red-81-40-121.staticip.rima-tde.net. [81.40.121.121]) by smtp.gmail.com with ESMTPSA id 128sm14154986wmz.43.2020.08.14.04.00.58 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 14 Aug 2020 04:00:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=82YNUrJPpt+U6i+zsZg8jmPLYqtlltwueOh8XQCPKmQ=; b=tn2+V+NDZXCdbxZd3abu7KYFmH185KGG64CmAOqicWcSP9nMEp1Kr/TFIWuFXI2bNt hBV7pzS6tppiq+DopWSVbhOFkqT8m71DiscJ57l1OTvaxj7vM7IB3v76CF9pCyA2yFZo lxNPA76U3q2q1kOqP5Vy5P2jIM6cqL8pHKkzZ+TYGLI7iizfWltI9okePXw2tfG4bPHu gbhFA7VIIhMUlghHiiYd1k7BcDKeHK0tSMBM/SyCR7MB1JnwKqhobOrp0X21r9WhlNN7 WmKIUi+RyqvDVRhheCQCmT2nkgtsW1FoJIaR/51qT6Ae4L0HrnwqnEDGn4oZtFnaqi4E +8mQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:from:to:cc:subject:date:message-id :mime-version:content-transfer-encoding; bh=82YNUrJPpt+U6i+zsZg8jmPLYqtlltwueOh8XQCPKmQ=; b=Au6F5u3sLEmUPAIBU9Om3KVPETeZAKPyVteZ1T+8BdVD3xuadw6hplhrFYT6HW0mpm eXK3vk3UcinT549kvytOqtRGhNXYyCEpRj2U1sZCjU4NSAO42SdNSBLyZZJ2ONJDUmFm 7xof3TXQpQ5XO3J9grPxaU38xP1soaco9N+vmUPsd3Vi5/eiwwXwrhQEg5sAInQu9lbs lgNv+jKyDAy8GgloXIubuqnoG1yVpYpkBxwtWItaSVL/X8FdXUnoZGvxW+NSpPKHXM0r UqwCw+d+UXiokDc4kwiUuermLC3g0x7cnr9v3CZKnLhBc1f8YbMb7Q0+5FqJlLST6sR3 /dlw== X-Gm-Message-State: AOAM533OHPefskSkn8VW3tWUS5LvaRloWdUqzHCqCo40Hvql4HIpRajh Iy0ZVUKkygmDSKDghnRpfb6LHBMWmK4= X-Google-Smtp-Source: ABdhPJxfpFcuQ60gfxGquCy/VJIbQhooomzFHUveCUuTlDTVfaI9KICbzfLCYeRmsboDtnW3p1+i5g== X-Received: by 2002:adf:df08:: with SMTP id y8mr2406269wrl.152.1597402859848; Fri, 14 Aug 2020 04:00:59 -0700 (PDT) From: =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= To: qemu-devel@nongnu.org Subject: [PATCH] hw/sd/allwinner-sdhost: Use AddressSpace for DMA transfers Date: Fri, 14 Aug 2020 13:00:57 +0200 Message-Id: <20200814110057.307-1-f4bug@amsat.org> X-Mailer: git-send-email 2.21.3 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=2a00:1450:4864:20::441; envelope-from=philippe.mathieu.daude@gmail.com; helo=mail-wr1-x441.google.com X-detected-operating-system: by eggs.gnu.org: No matching host in p0f cache. That's all we know. X-Spam_score_int: 0 X-Spam_score: 0.0 X-Spam_bar: / X-Spam_report: (0.0 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_EF=-0.1, FREEMAIL_FORGED_FROMDOMAIN=1, FREEMAIL_FROM=0.001, HEADER_FROM_DIFFERENT_DOMAINS=1, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=no autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Peter Maydell , qemu-block@nongnu.org, =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= , Niek Linnenbank , Andrew Baumann , =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= , Beniamino Galvani , Michael Walle , qemu-arm@nongnu.org Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: fail (Header signature does not verify) Allow the device to execute the DMA transfers in a different AddressSpace. The A10 and H3 SoC keep using the system_memory address space, but via the proper dma_memory_access() API. Signed-off-by: Philippe Mathieu-Daud=C3=A9 Reviewed-by: Niek Linnenbank Tested-by: Niek Linnenbank --- Based-on: <20200814092346.21825-1-f4bug@amsat.org> "hw/sd: Use sdbus_read_data/sdbus_write_data for multiple bytes access" Tested with: AVOCADO_ALLOW_LARGE_STORAGE=3D1 avocado run -t machine:orangepi-pc -t mac= hine:cubieboard tests/acceptance/ --- include/hw/sd/allwinner-sdhost.h | 6 ++++++ hw/arm/allwinner-a10.c | 2 ++ hw/arm/allwinner-h3.c | 2 ++ hw/sd/allwinner-sdhost.c | 37 ++++++++++++++++++++++++++------ 4 files changed, 41 insertions(+), 6 deletions(-) diff --git a/include/hw/sd/allwinner-sdhost.h b/include/hw/sd/allwinner-sdh= ost.h index d94606a853..839732ebf3 100644 --- a/include/hw/sd/allwinner-sdhost.h +++ b/include/hw/sd/allwinner-sdhost.h @@ -71,6 +71,12 @@ typedef struct AwSdHostState { /** Interrupt output signal to notify CPU */ qemu_irq irq; =20 + /** Memory region where DMA transfers are done */ + MemoryRegion *dma_mr; + + /** Address space used internally for DMA transfers */ + AddressSpace dma_as; + /** Number of bytes left in current DMA transfer */ uint32_t transfer_cnt; =20 diff --git a/hw/arm/allwinner-a10.c b/hw/arm/allwinner-a10.c index e258463747..d404f31e02 100644 --- a/hw/arm/allwinner-a10.c +++ b/hw/arm/allwinner-a10.c @@ -155,6 +155,8 @@ static void aw_a10_realize(DeviceState *dev, Error **er= rp) } =20 /* SD/MMC */ + object_property_set_link(OBJECT(&s->mmc0), "dma-memory", + OBJECT(get_system_memory()), &error_fatal); sysbus_realize(SYS_BUS_DEVICE(&s->mmc0), &error_fatal); sysbus_mmio_map(SYS_BUS_DEVICE(&s->mmc0), 0, AW_A10_MMC0_BASE); sysbus_connect_irq(SYS_BUS_DEVICE(&s->mmc0), 0, qdev_get_gpio_in(dev, = 32)); diff --git a/hw/arm/allwinner-h3.c b/hw/arm/allwinner-h3.c index ff92ded82c..43a8d3dc48 100644 --- a/hw/arm/allwinner-h3.c +++ b/hw/arm/allwinner-h3.c @@ -349,6 +349,8 @@ static void allwinner_h3_realize(DeviceState *dev, Erro= r **errp) sysbus_mmio_map(SYS_BUS_DEVICE(&s->sid), 0, s->memmap[AW_H3_SID]); =20 /* SD/MMC */ + object_property_set_link(OBJECT(&s->mmc0), "dma-memory", + OBJECT(get_system_memory()), &error_fatal); sysbus_realize(SYS_BUS_DEVICE(&s->mmc0), &error_fatal); sysbus_mmio_map(SYS_BUS_DEVICE(&s->mmc0), 0, s->memmap[AW_H3_MMC0]); sysbus_connect_irq(SYS_BUS_DEVICE(&s->mmc0), 0, diff --git a/hw/sd/allwinner-sdhost.c b/hw/sd/allwinner-sdhost.c index f9eb92c09e..e82afb75eb 100644 --- a/hw/sd/allwinner-sdhost.c +++ b/hw/sd/allwinner-sdhost.c @@ -21,7 +21,10 @@ #include "qemu/log.h" #include "qemu/module.h" #include "qemu/units.h" +#include "qapi/error.h" #include "sysemu/blockdev.h" +#include "sysemu/dma.h" +#include "hw/qdev-properties.h" #include "hw/irq.h" #include "hw/sd/allwinner-sdhost.h" #include "migration/vmstate.h" @@ -306,7 +309,7 @@ static uint32_t allwinner_sdhost_process_desc(AwSdHostS= tate *s, uint8_t buf[1024]; =20 /* Read descriptor */ - cpu_physical_memory_read(desc_addr, desc, sizeof(*desc)); + dma_memory_read(&s->dma_as, desc_addr, desc, sizeof(*desc)); if (desc->size =3D=3D 0) { desc->size =3D klass->max_desc_size; } else if (desc->size > klass->max_desc_size) { @@ -331,22 +334,24 @@ static uint32_t allwinner_sdhost_process_desc(AwSdHos= tState *s, =20 /* Write to SD bus */ if (is_write) { - cpu_physical_memory_read((desc->addr & DESC_SIZE_MASK) + num_d= one, - buf, buf_bytes); + dma_memory_read(&s->dma_as, + (desc->addr & DESC_SIZE_MASK) + num_done, + buf, buf_bytes); sdbus_write_data(&s->sdbus, buf, buf_bytes); =20 /* Read from SD bus */ } else { sdbus_read_data(&s->sdbus, buf, buf_bytes); - cpu_physical_memory_write((desc->addr & DESC_SIZE_MASK) + num_= done, - buf, buf_bytes); + dma_memory_write(&s->dma_as, + (desc->addr & DESC_SIZE_MASK) + num_done, + buf, buf_bytes); } num_done +=3D buf_bytes; } =20 /* Clear hold flag and flush descriptor */ desc->status &=3D ~DESC_STATUS_HOLD; - cpu_physical_memory_write(desc_addr, desc, sizeof(*desc)); + dma_memory_write(&s->dma_as, desc_addr, desc, sizeof(*desc)); =20 return num_done; } @@ -721,6 +726,12 @@ static const VMStateDescription vmstate_allwinner_sdho= st =3D { } }; =20 +static Property allwinner_sdhost_properties[] =3D { + DEFINE_PROP_LINK("dma-memory", AwSdHostState, dma_mr, + TYPE_MEMORY_REGION, MemoryRegion *), + DEFINE_PROP_END_OF_LIST(), +}; + static void allwinner_sdhost_init(Object *obj) { AwSdHostState *s =3D AW_SDHOST(obj); @@ -734,6 +745,18 @@ static void allwinner_sdhost_init(Object *obj) sysbus_init_irq(SYS_BUS_DEVICE(s), &s->irq); } =20 +static void allwinner_sdhost_realize(DeviceState *dev, Error **errp) +{ + AwSdHostState *s =3D AW_SDHOST(dev); + + if (!s->dma_mr) { + error_setg(errp, TYPE_AW_SDHOST " 'dma-memory' link not set"); + return; + } + + address_space_init(&s->dma_as, s->dma_mr, "sdhost-dma"); +} + static void allwinner_sdhost_reset(DeviceState *dev) { AwSdHostState *s =3D AW_SDHOST(dev); @@ -792,6 +815,8 @@ static void allwinner_sdhost_class_init(ObjectClass *kl= ass, void *data) =20 dc->reset =3D allwinner_sdhost_reset; dc->vmsd =3D &vmstate_allwinner_sdhost; + dc->realize =3D allwinner_sdhost_realize; + device_class_set_props(dc, allwinner_sdhost_properties); } =20 static void allwinner_sdhost_sun4i_class_init(ObjectClass *klass, void *da= ta) --=20 2.21.3