From nobody Thu Feb 02 07:39:44 2023 X-Original-To: dev-commits-src-branches@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4P6rKD6NnSz3c9CC; Thu, 2 Feb 2023 07:39:44 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4P6rKD5jbRz3CsD; Thu, 2 Feb 2023 07:39:44 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1675323584; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=JJ+0XB1tkt36wnor8KpLOJuxm13y/0hRy0moeBuGwqs=; b=Ad+MyctUcCH/qinkTrD/hcSafQkyNRKOAcBQ1km8osTn80wW0JuutkPwbQoATEZ3dzzwm/ 8N/c2Remle1mA7+IOWY8V0tFzJ6UFLOg1rAfva0ikxHlxEhXrI3Mq3fRWYYJnYgsePxerT O/Ff3SzFVMkZY49RIb74WCkzggY2uBKbPAIg9vMS7wr9tkOrPCe/FLW0v0COHLi1GOEcIs yNopv4U213wwZMytJJtJBp3utwS46EHcUve1rlV6rQtpz4wWxgGunp5i+ftF4TCW7yCGjn fMO302pCO5u21qUwUlxYr+glSAzYg0QyJCPdBhUOck64VnBt8uDj5kd+DsMzSQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1675323584; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=JJ+0XB1tkt36wnor8KpLOJuxm13y/0hRy0moeBuGwqs=; b=ed/tQLhWOpXGC8ABxsTQSgbkvybmSUj1u0+Jj18NldfvzmsowVtTMm7LvzLjukUVkRd9A5 lcT4R+PtKnAVzHFfQLQUghfyjEnGXydfox7cUEEZxMfFOECqa8VrtSBMhxgLH3SbUMcaC9 6vSZPhS/sn1uVNi+0w8HI53691X7spAwBZXRuctJ05K3kN12K8vz90lpdE9tnigqkjlkxs q78jarxbIzirDiltlg3ZHmAs334xQZ5V04q+UeRMzBZmKGKYI/MBgiQSQihCH7ZSXxTNxA 012ntPDtjMEf/eOpKPNruKPvAuAZubjoDjIAxNIdBTHhF4wn+ZGXx3P7K5qOVQ== ARC-Authentication-Results: i=1; mx1.freebsd.org; none ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1675323584; a=rsa-sha256; cv=none; b=lYK+fACElb2MUxRiXDR4yZXecq0F3a5CWYoxGqAVB9eEg+BKa3S5ps1ZrCQ/9LJodAqj40 r1pOY6gc4TbKbbrOM09DNSE9MtNMIszs5lqLj/5ghObWYotkiaGtZFHoa30xZ3vwNctmcl UR0VkoSP1/DuNlGiLd/m6v2KATkd7AlB+vS6yicWQs51UJfJ5hG3mQYXMDWpGZJCdGt1Zr HqFecDAbicR7fgGAPar+U2qWZIRw8Du/V5naBHEK6zUzPYXiJ+ihkr0mPNamhH/LISp18x joDNC79hmdCWBijlspf2oCmXCmYEZWy+e+7OGvTt6u05fe2/JExqND7M2i6mPw== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4P6rKD4ptkzlwt; Thu, 2 Feb 2023 07:39:44 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.16.1/8.16.1) with ESMTP id 3127diYY062321; Thu, 2 Feb 2023 07:39:44 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.16.1/8.16.1/Submit) id 3127diG3062320; Thu, 2 Feb 2023 07:39:44 GMT (envelope-from git) Date: Thu, 2 Feb 2023 07:39:44 GMT Message-Id: <202302020739.3127diG3062320@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org From: Navdeep Parhar Subject: git: dde4103a465b - stable/13 - pciconf(8): Decode ACS extended capability. List-Id: Commits to the stable branches of the FreeBSD src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-branches List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-dev-commits-src-branches@freebsd.org X-BeenThere: dev-commits-src-branches@freebsd.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: np X-Git-Repository: src X-Git-Refname: refs/heads/stable/13 X-Git-Reftype: branch X-Git-Commit: dde4103a465bd8021eafabc159942c60a9473625 Auto-Submitted: auto-generated X-ThisMailContainsUnwantedMimeParts: N The branch stable/13 has been updated by np: URL: https://cgit.FreeBSD.org/src/commit/?id=dde4103a465bd8021eafabc159942c60a9473625 commit dde4103a465bd8021eafabc159942c60a9473625 Author: Navdeep Parhar AuthorDate: 2022-11-04 19:30:09 +0000 Commit: Navdeep Parhar CommitDate: 2023-02-02 07:21:59 +0000 pciconf(8): Decode ACS extended capability. Sponsored by: Chelsio Communications Reviewed by: kib@ Differential Revision: https://reviews.freebsd.org/D37271 (cherry picked from commit 118cfb829f355a4545f079f12bab5ea8e41fe214) --- usr.sbin/pciconf/cap.c | 61 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 61 insertions(+) diff --git a/usr.sbin/pciconf/cap.c b/usr.sbin/pciconf/cap.c index eae53acbd250..3d28fe9bc331 100644 --- a/usr.sbin/pciconf/cap.c +++ b/usr.sbin/pciconf/cap.c @@ -1016,6 +1016,64 @@ ecap_sriov(int fd, struct pci_conf *p, uint16_t ptr, uint8_t ver) print_bar(fd, p, "iov bar ", ptr + PCIR_SRIOV_BAR(i)); } +static const char * +check_avail_and_state(u_int cap, u_int capbit, u_int ctl, u_int ctlbit) +{ + + if (cap & capbit) + return (ctl & ctlbit ? "enabled" : "disabled"); + else + return "unavailable"; +} + +static void +ecap_acs(int fd, struct pci_conf *p, uint16_t ptr, uint8_t ver) +{ + uint16_t acs_cap, acs_ctl; + static const char *const acc[] = { "access enabled", "blocking enabled", + "redirect enabled", "reserved" }; + + printf("ACS %d ", ver); + if (ver != 1) { + printf("\n"); + return; + } + +#define CHECK_AVAIL_STATE(bit) \ + check_avail_and_state(acs_cap, bit, acs_ctl, bit##_ENABLE) + + acs_cap = read_config(fd, &p->pc_sel, ptr + PCIR_ACS_CAP, 2); + acs_ctl = read_config(fd, &p->pc_sel, ptr + PCIR_ACS_CTL, 2); + printf("Source Validation %s, Translation Blocking %s\n", + CHECK_AVAIL_STATE(PCIM_ACS_SOURCE_VALIDATION), + CHECK_AVAIL_STATE(PCIM_ACS_TRANSLATION_BLOCKING)); + + printf(" "); + printf("P2P Req Redirect %s, P2P Cmpl Redirect %s\n", + CHECK_AVAIL_STATE(PCIM_ACS_P2P_REQ_REDIRECT), + CHECK_AVAIL_STATE(PCIM_ACS_P2P_CMP_REDIRECT)); + printf(" "); + printf("P2P Upstream Forwarding %s, P2P Egress Control %s\n", + CHECK_AVAIL_STATE(PCIM_ACS_P2P_UPSTREAM_FORWARDING), + CHECK_AVAIL_STATE(PCIM_ACS_P2P_EGRESS_CTL)); + printf(" "); + printf("P2P Direct Translated %s, Enhanced Capability %s\n", + CHECK_AVAIL_STATE(PCIM_ACS_P2P_DIRECT_TRANSLATED), + acs_ctl & PCIM_ACS_ENHANCED_CAP ? "available" : "unavailable"); +#undef CHECK_AVAIL_STATE + + if (acs_cap & PCIM_ACS_ENHANCED_CAP) { + printf(" "); + printf("I/O Req Blocking %s, Unclaimed Req Redirect Control %s\n", + check_enabled(acs_ctl & PCIM_ACS_IO_REQ_BLOCKING_ENABLE), + check_enabled(acs_ctl & PCIM_ACS_UNCLAIMED_REQ_REDIRECT_CTL)); + printf(" "); + printf("DSP BAR %s, USP BAR %s\n", + acc[(acs_cap & PCIM_ACS_DSP_MEM_TGT_ACC_CTL) >> 8], + acc[(acs_cap & PCIM_ACS_USP_MEM_TGT_ACC_CTL) >> 10]); + } +} + static struct { uint16_t id; const char *name; @@ -1099,6 +1157,9 @@ list_ecaps(int fd, struct pci_conf *p) case PCIZ_SRIOV: ecap_sriov(fd, p, ptr, PCI_EXTCAP_VER(ecap)); break; + case PCIZ_ACS: + ecap_acs(fd, p, ptr, PCI_EXTCAP_VER(ecap)); + break; default: name = "unknown"; for (i = 0; ecap_names[i].name != NULL; i++)