From patchwork Tue Jun 25 11:27:50 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jonathan Cameron X-Patchwork-Id: 167703 Delivered-To: patch@linaro.org Received: by 2002:ac9:6410:0:0:0:0:0 with SMTP id r16csp4871998ock; Tue, 25 Jun 2019 04:32:03 -0700 (PDT) X-Google-Smtp-Source: APXvYqywHAREZemVQZtFc96Nhl2ZWnpw9HO+NC8XS4UO4XfFRM1dt7KdDhXDHdaJ4cKZi+3I9oGG X-Received: by 2002:a50:a3f5:: with SMTP id t50mr40778608edb.273.1561462323846; Tue, 25 Jun 2019 04:32:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1561462323; cv=none; d=google.com; s=arc-20160816; b=bZFSToC0Vy0mw2llBWu8h4Gx8iq/rsCucS628DyDRf97+hjiPGS/jz8OmtntjNwguj qFMR7apBtfKy3FOKlnW5QFwj5RqwbK8CYzkDdlj07/B+dg71///zo8jaj/9qdx14XnuG FC13uwkAsPlwqU5Ldh7Csz7g5aZZkKyQ5alWbe+SxDqBiA/7nEPgiXtEYKOn1K8x4ibC 5/pJM4BGWFT808P5WqQBoEqru1SF4yyBj0Vtb8m1ZkLZS+qHlDY8ZtDl5KFn6SNotkz4 FSU6GuzLlXo7BGFR4vcDdUJzGAHIYSBbFKH1ixW94nl7dXlI5tyQRVf8TwDx1EzwVici amYw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:cc:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:subject :content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:to:from; bh=0Of383u8KnwHEsqWqlolo5JRT6gmT/bOwCwH6dgTb+s=; b=Q4RlUR3R5P7z/+8FFkeeuObjNo1E9y9yOorLGw/aYb0hLt8tN1ipgxSgJgNDPIFXsd 5lmnD1bQno3EStltsNGqf8WICkHt3qO5sJohY1pLgY6aW46wYUaz0AgqUSlB1hg6GjCq ofVDgLqMaJ1FviAmQNl4cjjViRaNmuumSd0XfrTR8IyY/iYFYsxdEnTj6jujZOhY2Enl UR3Xhw6arQs+ZGH4Rv5ekc6N15opeqdZeErc4d/adhyXlLsHRJ8dNGpc3PdF2QqzD0sm dky3uy5anKthYitKkJsZ/vMhdRMmDCJb7vTy0q5NM/dKhqRMliFLuwaD9FicTQ/M4qM9 tSpg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org" Return-Path: Received: from lists.gnu.org (lists.gnu.org. [209.51.188.17]) by mx.google.com with ESMTPS id 58si170548edz.364.2019.06.25.04.32.03 for (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Tue, 25 Jun 2019 04:32:03 -0700 (PDT) Received-SPF: pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; Authentication-Results: mx.google.com; spf=pass (google.com: domain of qemu-devel-bounces+patch=linaro.org@nongnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom="qemu-devel-bounces+patch=linaro.org@nongnu.org" Received: from localhost ([::1]:58992 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.86_2) (envelope-from ) id 1hfjgA-0002Hq-Pe for patch@linaro.org; Tue, 25 Jun 2019 07:32:02 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]:53742) by lists.gnu.org with esmtp (Exim 4.86_2) (envelope-from ) id 1hfjdF-000745-AE for qemu-devel@nongnu.org; Tue, 25 Jun 2019 07:29:03 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1hfjdD-0004EA-Gu for qemu-devel@nongnu.org; Tue, 25 Jun 2019 07:29:01 -0400 Received: from szxga07-in.huawei.com ([45.249.212.35]:52882 helo=huawei.com) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1hfjd7-0003xA-BG; Tue, 25 Jun 2019 07:28:55 -0400 Received: from DGGEMS406-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id 3FD502AD529BF46919CB; Tue, 25 Jun 2019 19:28:48 +0800 (CST) Received: from lhrphicprd00229.huawei.com (10.123.41.22) by DGGEMS406-HUB.china.huawei.com (10.3.19.206) with Microsoft SMTP Server id 14.3.439.0; Tue, 25 Jun 2019 19:28:41 +0800 From: Jonathan Cameron To: QEMU Developers Date: Tue, 25 Jun 2019 19:27:50 +0800 Message-ID: <20190625112752.83188-6-Jonathan.Cameron@huawei.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190625112752.83188-1-Jonathan.Cameron@huawei.com> References: <20190625112752.83188-1-Jonathan.Cameron@huawei.com> MIME-Version: 1.0 X-Originating-IP: [10.123.41.22] X-CFilter-Loop: Reflected X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-Received-From: 45.249.212.35 Subject: [Qemu-devel] [RFC PATCH 5/7] pci-bridge: CCIX capable PCIE/CCIX switch downstream port 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 , jcm@redhat.com, linuxarm@huawei.com, Auger Eric , qemu-arm , Jonathan Cameron Errors-To: qemu-devel-bounces+patch=linaro.org@nongnu.org Sender: "Qemu-devel" Note that this is simply emulation of the configuration space. Has the same issue with cut and paste code as the upstream port driver. Solution likely to be the same. Signed-off-by: Jonathan Cameron --- hw/pci-bridge/Makefile.objs | 2 +- hw/pci-bridge/ccix_downstream.c | 222 ++++++++++++++++++++++++++++++++ 2 files changed, 223 insertions(+), 1 deletion(-) -- 2.20.1 diff --git a/hw/pci-bridge/Makefile.objs b/hw/pci-bridge/Makefile.objs index e266e39fed..78a49fb90b 100644 --- a/hw/pci-bridge/Makefile.objs +++ b/hw/pci-bridge/Makefile.objs @@ -8,4 +8,4 @@ common-obj-$(CONFIG_I82801B11) += i82801b11.o common-obj-$(CONFIG_DEC_PCI) += dec.o # Sun4u common-obj-$(CONFIG_SIMBA) += simba.o -common-obj-$(CONFIG_CCIX_SWITCH) += ccix_upstream.o +common-obj-$(CONFIG_CCIX_SWITCH) += ccix_upstream.o ccix_downstream.o diff --git a/hw/pci-bridge/ccix_downstream.c b/hw/pci-bridge/ccix_downstream.c new file mode 100644 index 0000000000..92c66431e2 --- /dev/null +++ b/hw/pci-bridge/ccix_downstream.c @@ -0,0 +1,222 @@ +/* + * ccix_downstream.c + * A PCIe downstream switch port with CCIX support. + * + * Copyright (c) 2019 Jonathan Cameron + * Huawei + * Based on: xio3130_downstream.c + * Copyright (c) 2010 Isaku Yamahata + * VA Linux Systems Japan K.K. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, see . + */ + +#include "qemu/osdep.h" +#include "hw/pci/pci_ids.h" +#include "hw/pci/msi.h" +#include "hw/pci/pcie.h" +#include "hw/pci/pcie_port.h" +#include "qapi/error.h" +#include "hw/misc/ccix.h" +#include "qemu/module.h" + +/* + * No public spec is available for a CCIX downstream port so for + * now use the values from teh xio3130 pcie downstream port + */ +#define XIO3130_MSI_OFFSET 0x70 +#define XIO3130_MSI_SUPPORTED_FLAGS PCI_MSI_FLAGS_64BIT +#define XIO3130_MSI_NR_VECTOR 1 +#define XIO3130_SSVID_OFFSET 0x80 +#define XIO3130_SSVID_SVID 0 +#define XIO3130_SSVID_SSID 0 +#define XIO3130_EXP_OFFSET 0x90 +#define XIO3130_AER_OFFSET 0x100 + +#define TYPE_CCIX_DOWN_PORT "ccix-downstream-port" + +#define CCIX_DOWN_DEV(obj) OBJECT_CHECK(CCIXDownPortState, (obj), TYPE_CCIX_DOWN_PORT) + +typedef struct CCIXDownPortState { + PCIESlot parent_obj; + struct CCIXState s; +} CCIXDownPortState; + +static void ccix_downstream_write_config(PCIDevice *d, uint32_t address, + uint32_t val, int len) +{ + CCIXDownPortState *s = CCIX_DOWN_DEV(d); + + pci_bridge_write_config(d, address, val, len); + pcie_cap_flr_write_config(d, address, val, len); + pcie_cap_slot_write_config(d, address, val, len); + pcie_aer_write_config(d, address, val, len); + ccix_write_config(d, &s->s, address, val, len); +} + +static void ccix_downstream_reset(DeviceState *qdev) +{ + PCIDevice *d = PCI_DEVICE(qdev); + + pcie_cap_deverr_reset(d); + pcie_cap_slot_reset(d); + pcie_cap_arifwd_reset(d); + pci_bridge_reset(qdev); +} + +static void ccix_downstream_realize(PCIDevice *d, Error **errp) +{ + PCIEPort *p = PCIE_PORT(d); + PCIESlot *s = PCIE_SLOT(d); + CCIXDownPortState *cs = CCIX_DOWN_DEV(d); + /* Allow space for existing extended capabilities from xio3130 */ + uint32_t offset = 0x180; + int rc; + + pci_bridge_initfn(d, TYPE_PCIE_BUS); + pcie_port_init_reg(d); + + rc = msi_init(d, XIO3130_MSI_OFFSET, XIO3130_MSI_NR_VECTOR, + XIO3130_MSI_SUPPORTED_FLAGS & PCI_MSI_FLAGS_64BIT, + XIO3130_MSI_SUPPORTED_FLAGS & PCI_MSI_FLAGS_MASKBIT, + errp); + if (rc < 0) { + assert(rc == -ENOTSUP); + goto err_bridge; + } + + rc = pci_bridge_ssvid_init(d, XIO3130_SSVID_OFFSET, + XIO3130_SSVID_SVID, XIO3130_SSVID_SSID, + errp); + if (rc < 0) { + goto err_bridge; + } + + rc = pcie_cap_init(d, XIO3130_EXP_OFFSET, PCI_EXP_TYPE_DOWNSTREAM, + p->port, errp); + if (rc < 0) { + goto err_msi; + } + pcie_cap_flr_init(d); + pcie_cap_deverr_init(d); + pcie_cap_slot_init(d, s->slot); + pcie_cap_arifwd_init(d); + + pcie_chassis_create(s->chassis); + rc = pcie_chassis_add_slot(s); + if (rc < 0) { + error_setg(errp, "Can't add chassis slot, error %d", rc); + goto err_pcie_cap; + } + + rc = pcie_aer_init(d, PCI_ERR_VER, XIO3130_AER_OFFSET, + PCI_ERR_SIZEOF, errp); + if (rc < 0) { + goto err; + } + initialize_ccixstate(&cs->s, d); + ccix_set_port(&cs->s); + offset = ccix_add_prldvsec(d, &cs->s, offset); + ccix_add_tdldvsec(d, offset); + ccix_register(&cs->s); + + return; + +err: + pcie_chassis_del_slot(s); +err_pcie_cap: + pcie_cap_exit(d); +err_msi: + msi_uninit(d); +err_bridge: + pci_bridge_exitfn(d); +} + +static void ccix_downstream_exitfn(PCIDevice *d) +{ + PCIESlot *s = PCIE_SLOT(d); + + pcie_aer_exit(d); + pcie_chassis_del_slot(s); + pcie_cap_exit(d); + msi_uninit(d); + pci_bridge_exitfn(d); +} + +static Property ccix_props[] = { + DEFINE_PROP_STRING("ccix_device", CCIXDownPortState, s.ccix_dev_name), + DEFINE_PROP_BIT("primaryport", CCIXDownPortState, s.flags, PRIMARY_PORT_BIT, false), + DEFINE_PROP_UINT8("port_id", CCIXDownPortState, s.port_id, 0), + DEFINE_PROP_UINT8("num_links", CCIXDownPortState, s.num_links, 1), + DEFINE_PROP_UINT8("psam_entries", CCIXDownPortState, s.psam_entries, 0), + DEFINE_PROP_UINT8("request_agents", CCIXDownPortState, s.num_ras, 0), + DEFINE_PROP_UINT8("home_agents", CCIXDownPortState, s.num_has, 0), + DEFINE_PROP_UINT8("hsam_entries", CCIXDownPortState, s.hsam_entries, 0), + DEFINE_PROP_UINT8("rsam_entries", CCIXDownPortState, s.rsam_entries, 0), + DEFINE_PROP_END_OF_LIST(), +}; + +static const VMStateDescription vmstate_ccix_downstream = { + .name = "ccix-downstream-port", + .priority = MIG_PRI_PCI_BUS, + .version_id = 1, + .minimum_version_id = 1, + .post_load = pcie_cap_slot_post_load, + .fields = (VMStateField[]) { + VMSTATE_PCI_DEVICE(parent_obj.parent_obj.parent_obj, PCIESlot), + VMSTATE_STRUCT(parent_obj.parent_obj.parent_obj.exp.aer_log, + PCIESlot, 0, vmstate_pcie_aer_log, PCIEAERLog), + VMSTATE_END_OF_LIST() + } +}; + + +static void ccix_downstream_class_init(ObjectClass *klass, void *data) +{ + DeviceClass *dc = DEVICE_CLASS(klass); + PCIDeviceClass *k = PCI_DEVICE_CLASS(klass); + + k->is_bridge = true; + k->config_write = ccix_downstream_write_config; + k->realize = ccix_downstream_realize; + k->exit = ccix_downstream_exitfn; + /* Temp values for the RFC */ + k->vendor_id = PCI_VENDOR_ID_HUAWEI; + k->device_id = PCI_DEVICE_ID_HUAWEI_CCIX_DOWN;; + k->revision = 1; + set_bit(DEVICE_CATEGORY_BRIDGE, dc->categories); + dc->desc = "CCIX / PCIE switch downstream port"; + dc->reset = ccix_downstream_reset; + dc->vmsd = &vmstate_ccix_downstream; + dc->props = ccix_props; +} + +static const TypeInfo ccix_downstream_info = { + .name = TYPE_CCIX_DOWN_PORT, + .parent = TYPE_PCIE_SLOT, + .class_init = ccix_downstream_class_init, + .instance_size = sizeof(CCIXDownPortState), + .interfaces = (InterfaceInfo[]) { + { INTERFACE_PCIE_DEVICE }, + { } + }, +}; + +static void ccix_downstream_register_types(void) +{ + type_register_static(&ccix_downstream_info); +} + +type_init(ccix_downstream_register_types) +