]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
5.15-stable patches
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 14 Nov 2021 14:15:43 +0000 (15:15 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 14 Nov 2021 14:15:43 +0000 (15:15 +0100)
added patches:
cifs-set-a-minimum-of-120s-for-next-dns-resolution.patch
cifs-to-match-file-servers-make-sure-the-server-hostname-matches.patch
cxl-pci-fix-null-vs-err_ptr-confusion.patch
ovl-fix-filattr-copy-up-failure.patch
ovl-fix-use-after-free-in-struct-ovl_aio_req.patch
pci-aardvark-do-not-clear-status-bits-of-masked-interrupts.patch
pci-aardvark-do-not-unmask-unused-interrupts.patch
pci-aardvark-fix-checking-for-link-up-via-ltssm-state.patch
pci-aardvark-fix-configuring-reference-clock.patch
pci-aardvark-fix-reporting-data-link-layer-link-active.patch
pci-aardvark-fix-return-value-of-msi-domain-.alloc-method.patch
pci-aardvark-fix-support-for-bus-mastering-and-pci_command-on-emulated-bridge.patch
pci-aardvark-fix-support-for-pci_bridge_ctl_bus_reset-on-emulated-bridge.patch
pci-aardvark-fix-support-for-pci_rom_address1-on-emulated-bridge.patch
pci-aardvark-read-all-16-bits-from-pcie_msi_payload_reg.patch
pci-aardvark-set-pci-bridge-class-code-to-pci-bridge.patch
pci-cadence-add-cdns_plat_pcie_probe-missing-return.patch
pci-pci-bridge-emul-fix-emulation-of-w1c-bits.patch
quota-check-block-number-when-reading-the-block-in-quota-file.patch
quota-correct-error-number-in-free_dqentry.patch
xen-balloon-add-late_initcall_sync-for-initial-ballooning-done.patch

22 files changed:
queue-5.15/cifs-set-a-minimum-of-120s-for-next-dns-resolution.patch [new file with mode: 0644]
queue-5.15/cifs-to-match-file-servers-make-sure-the-server-hostname-matches.patch [new file with mode: 0644]
queue-5.15/cxl-pci-fix-null-vs-err_ptr-confusion.patch [new file with mode: 0644]
queue-5.15/ovl-fix-filattr-copy-up-failure.patch [new file with mode: 0644]
queue-5.15/ovl-fix-use-after-free-in-struct-ovl_aio_req.patch [new file with mode: 0644]
queue-5.15/pci-aardvark-do-not-clear-status-bits-of-masked-interrupts.patch [new file with mode: 0644]
queue-5.15/pci-aardvark-do-not-unmask-unused-interrupts.patch [new file with mode: 0644]
queue-5.15/pci-aardvark-fix-checking-for-link-up-via-ltssm-state.patch [new file with mode: 0644]
queue-5.15/pci-aardvark-fix-configuring-reference-clock.patch [new file with mode: 0644]
queue-5.15/pci-aardvark-fix-reporting-data-link-layer-link-active.patch [new file with mode: 0644]
queue-5.15/pci-aardvark-fix-return-value-of-msi-domain-.alloc-method.patch [new file with mode: 0644]
queue-5.15/pci-aardvark-fix-support-for-bus-mastering-and-pci_command-on-emulated-bridge.patch [new file with mode: 0644]
queue-5.15/pci-aardvark-fix-support-for-pci_bridge_ctl_bus_reset-on-emulated-bridge.patch [new file with mode: 0644]
queue-5.15/pci-aardvark-fix-support-for-pci_rom_address1-on-emulated-bridge.patch [new file with mode: 0644]
queue-5.15/pci-aardvark-read-all-16-bits-from-pcie_msi_payload_reg.patch [new file with mode: 0644]
queue-5.15/pci-aardvark-set-pci-bridge-class-code-to-pci-bridge.patch [new file with mode: 0644]
queue-5.15/pci-cadence-add-cdns_plat_pcie_probe-missing-return.patch [new file with mode: 0644]
queue-5.15/pci-pci-bridge-emul-fix-emulation-of-w1c-bits.patch [new file with mode: 0644]
queue-5.15/quota-check-block-number-when-reading-the-block-in-quota-file.patch [new file with mode: 0644]
queue-5.15/quota-correct-error-number-in-free_dqentry.patch [new file with mode: 0644]
queue-5.15/series
queue-5.15/xen-balloon-add-late_initcall_sync-for-initial-ballooning-done.patch [new file with mode: 0644]

diff --git a/queue-5.15/cifs-set-a-minimum-of-120s-for-next-dns-resolution.patch b/queue-5.15/cifs-set-a-minimum-of-120s-for-next-dns-resolution.patch
new file mode 100644 (file)
index 0000000..52e0318
--- /dev/null
@@ -0,0 +1,61 @@
+From 4ac0536f8874a903a72bddc57eb88db774261e3a Mon Sep 17 00:00:00 2001
+From: Paulo Alcantara <pc@cjr.nz>
+Date: Thu, 4 Nov 2021 13:13:28 -0300
+Subject: cifs: set a minimum of 120s for next dns resolution
+
+From: Paulo Alcantara <pc@cjr.nz>
+
+commit 4ac0536f8874a903a72bddc57eb88db774261e3a upstream.
+
+With commit 506c1da44fee ("cifs: use the expiry output of dns_query to
+schedule next resolution") and after triggering the first reconnect,
+the next async dns resolution of tcp server's hostname would be
+scheduled based on dns_resolver's key expiry default, which happens to
+default to 5s on most systems that use key.dns_resolver for upcall.
+
+As per key.dns_resolver.conf(5):
+
+       default_ttl=<number>
+              The  number  of  seconds  to  set  as the expiration on a cached
+              record.  This will be overridden if the program manages  to  re-
+              trieve  TTL  information along with the addresses (if, for exam-
+              ple, it accesses the DNS directly).  The default is  5  seconds.
+              The value must be in the range 1 to INT_MAX.
+
+Make the next async dns resolution no shorter than 120s as we do not
+want to be upcalling too often.
+
+Cc: stable@vger.kernel.org
+Fixes: 506c1da44fee ("cifs: use the expiry output of dns_query to schedule next resolution")
+Signed-off-by: Paulo Alcantara (SUSE) <pc@cjr.nz>
+Reviewed-by: Shyam Prasad N <sprasad@microsoft.com>
+Signed-off-by: Steve French <stfrench@microsoft.com>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ fs/cifs/cifsglob.h |    3 ++-
+ fs/cifs/connect.c  |    2 +-
+ 2 files changed, 3 insertions(+), 2 deletions(-)
+
+--- a/fs/cifs/cifsglob.h
++++ b/fs/cifs/cifsglob.h
+@@ -74,7 +74,8 @@
+ #define SMB_ECHO_INTERVAL_MAX 600
+ #define SMB_ECHO_INTERVAL_DEFAULT 60
+-/* dns resolution interval in seconds */
++/* dns resolution intervals in seconds */
++#define SMB_DNS_RESOLVE_INTERVAL_MIN     120
+ #define SMB_DNS_RESOLVE_INTERVAL_DEFAULT 600
+ /* maximum number of PDUs in one compound */
+--- a/fs/cifs/connect.c
++++ b/fs/cifs/connect.c
+@@ -115,7 +115,7 @@ static int reconn_set_ipaddr_from_hostna
+                        * To make sure we don't use the cached entry, retry 1s
+                        * after expiry.
+                        */
+-                      ttl = (expiry - now + 1);
++                      ttl = max_t(unsigned long, expiry - now, SMB_DNS_RESOLVE_INTERVAL_MIN) + 1;
+       }
+       rc = !rc ? -1 : 0;
diff --git a/queue-5.15/cifs-to-match-file-servers-make-sure-the-server-hostname-matches.patch b/queue-5.15/cifs-to-match-file-servers-make-sure-the-server-hostname-matches.patch
new file mode 100644 (file)
index 0000000..5704563
--- /dev/null
@@ -0,0 +1,126 @@
+From 7be3248f313930ff3d3436d4e9ddbe9fccc1f541 Mon Sep 17 00:00:00 2001
+From: Shyam Prasad N <sprasad@microsoft.com>
+Date: Thu, 14 Oct 2021 11:52:39 +0000
+Subject: cifs: To match file servers, make sure the server hostname matches
+
+From: Shyam Prasad N <sprasad@microsoft.com>
+
+commit 7be3248f313930ff3d3436d4e9ddbe9fccc1f541 upstream.
+
+We generally rely on a bunch of factors to differentiate between servers.
+For example, IP address, port etc.
+
+For certain server types (like Azure), it is important to make sure
+that the server hostname matches too, even if the both hostnames currently
+resolve to the same IP address.
+
+Signed-off-by: Shyam Prasad N <sprasad@microsoft.com>
+Cc: stable@vger.kernel.org
+Signed-off-by: Steve French <stfrench@microsoft.com>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ fs/cifs/connect.c    |   19 +++++++++++--------
+ fs/cifs/fs_context.c |    8 ++++++++
+ fs/cifs/fs_context.h |    1 +
+ 3 files changed, 20 insertions(+), 8 deletions(-)
+
+--- a/fs/cifs/connect.c
++++ b/fs/cifs/connect.c
+@@ -794,7 +794,6 @@ static void clean_demultiplex_info(struc
+                */
+       }
+-      kfree(server->hostname);
+       kfree(server);
+       length = atomic_dec_return(&tcpSesAllocCount);
+@@ -1235,6 +1234,9 @@ static int match_server(struct TCP_Serve
+       if (!net_eq(cifs_net_ns(server), current->nsproxy->net_ns))
+               return 0;
++      if (strcasecmp(server->hostname, ctx->server_hostname))
++              return 0;
++
+       if (!match_address(server, addr,
+                          (struct sockaddr *)&ctx->srcaddr))
+               return 0;
+@@ -1336,6 +1338,7 @@ cifs_put_tcp_session(struct TCP_Server_I
+       kfree(server->session_key.response);
+       server->session_key.response = NULL;
+       server->session_key.len = 0;
++      kfree(server->hostname);
+       task = xchg(&server->tsk, NULL);
+       if (task)
+@@ -1361,14 +1364,15 @@ cifs_get_tcp_session(struct smb3_fs_cont
+               goto out_err;
+       }
++      tcp_ses->hostname = kstrdup(ctx->server_hostname, GFP_KERNEL);
++      if (!tcp_ses->hostname) {
++              rc = -ENOMEM;
++              goto out_err;
++      }
++
+       tcp_ses->ops = ctx->ops;
+       tcp_ses->vals = ctx->vals;
+       cifs_set_net_ns(tcp_ses, get_net(current->nsproxy->net_ns));
+-      tcp_ses->hostname = extract_hostname(ctx->UNC);
+-      if (IS_ERR(tcp_ses->hostname)) {
+-              rc = PTR_ERR(tcp_ses->hostname);
+-              goto out_err_crypto_release;
+-      }
+       tcp_ses->conn_id = atomic_inc_return(&tcpSesNextId);
+       tcp_ses->noblockcnt = ctx->rootfs;
+@@ -1497,8 +1501,7 @@ out_err_crypto_release:
+ out_err:
+       if (tcp_ses) {
+-              if (!IS_ERR(tcp_ses->hostname))
+-                      kfree(tcp_ses->hostname);
++              kfree(tcp_ses->hostname);
+               if (tcp_ses->ssocket)
+                       sock_release(tcp_ses->ssocket);
+               kfree(tcp_ses);
+--- a/fs/cifs/fs_context.c
++++ b/fs/cifs/fs_context.c
+@@ -318,6 +318,7 @@ smb3_fs_context_dup(struct smb3_fs_conte
+       DUP_CTX_STR(mount_options);
+       DUP_CTX_STR(username);
+       DUP_CTX_STR(password);
++      DUP_CTX_STR(server_hostname);
+       DUP_CTX_STR(UNC);
+       DUP_CTX_STR(source);
+       DUP_CTX_STR(domainname);
+@@ -456,6 +457,11 @@ smb3_parse_devname(const char *devname,
+       if (!pos)
+               return -EINVAL;
++      /* record the server hostname */
++      ctx->server_hostname = kstrndup(devname + 2, pos - devname - 2, GFP_KERNEL);
++      if (!ctx->server_hostname)
++              return -ENOMEM;
++
+       /* skip past delimiter */
+       ++pos;
+@@ -1496,6 +1502,8 @@ smb3_cleanup_fs_context_contents(struct
+       ctx->username = NULL;
+       kfree_sensitive(ctx->password);
+       ctx->password = NULL;
++      kfree(ctx->server_hostname);
++      ctx->server_hostname = NULL;
+       kfree(ctx->UNC);
+       ctx->UNC = NULL;
+       kfree(ctx->source);
+--- a/fs/cifs/fs_context.h
++++ b/fs/cifs/fs_context.h
+@@ -166,6 +166,7 @@ struct smb3_fs_context {
+       char *password;
+       char *domainname;
+       char *source;
++      char *server_hostname;
+       char *UNC;
+       char *nodename;
+       char *iocharset;  /* local code page for mapping to and from Unicode */
diff --git a/queue-5.15/cxl-pci-fix-null-vs-err_ptr-confusion.patch b/queue-5.15/cxl-pci-fix-null-vs-err_ptr-confusion.patch
new file mode 100644 (file)
index 0000000..67dbfce
--- /dev/null
@@ -0,0 +1,36 @@
+From ca76a3a8052b71c0334d5c094859cfa340c290a8 Mon Sep 17 00:00:00 2001
+From: Dan Williams <dan.j.williams@intel.com>
+Date: Fri, 15 Oct 2021 14:29:58 -0700
+Subject: cxl/pci: Fix NULL vs ERR_PTR confusion
+
+From: Dan Williams <dan.j.williams@intel.com>
+
+commit ca76a3a8052b71c0334d5c094859cfa340c290a8 upstream.
+
+cxl_pci_map_regblock() may return an ERR_PTR(), but cxl_pci_setup_regs()
+is only prepared for NULL as the error case. Pick the minimal fix for
+-stable backport purposes and just have cxl_pci_map_regblock() return
+NULL for errors.
+
+Fixes: f8a7e8c29be8 ("cxl/pci: Reserve all device regions at once")
+Cc: <stable@vger.kernel.org>
+Reviewed-by: Ira Weiny <ira.weiny@intel.com>
+Reviewed-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
+Link: https://lore.kernel.org/r/163433325724.834522.17809774578178224149.stgit@dwillia2-desk3.amr.corp.intel.com
+Signed-off-by: Dan Williams <dan.j.williams@intel.com>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/cxl/pci.c |    2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+--- a/drivers/cxl/pci.c
++++ b/drivers/cxl/pci.c
+@@ -972,7 +972,7 @@ static void __iomem *cxl_mem_map_regbloc
+       if (pci_resource_len(pdev, bar) < offset) {
+               dev_err(dev, "BAR%d: %pr: too small (offset: %#llx)\n", bar,
+                       &pdev->resource[bar], (unsigned long long)offset);
+-              return IOMEM_ERR_PTR(-ENXIO);
++              return NULL;
+       }
+       addr = pci_iomap(pdev, bar, 0);
diff --git a/queue-5.15/ovl-fix-filattr-copy-up-failure.patch b/queue-5.15/ovl-fix-filattr-copy-up-failure.patch
new file mode 100644 (file)
index 0000000..7972d11
--- /dev/null
@@ -0,0 +1,110 @@
+From 5b0a414d06c3ed2097e32ef7944a4abb644b89bd Mon Sep 17 00:00:00 2001
+From: Miklos Szeredi <mszeredi@redhat.com>
+Date: Thu, 4 Nov 2021 14:04:52 +0100
+Subject: ovl: fix filattr copy-up failure
+
+From: Miklos Szeredi <mszeredi@redhat.com>
+
+commit 5b0a414d06c3ed2097e32ef7944a4abb644b89bd upstream.
+
+This regression can be reproduced with ntfs-3g and overlayfs:
+
+  mkdir lower upper work overlay
+  dd if=/dev/zero of=ntfs.raw bs=1M count=2
+  mkntfs -F ntfs.raw
+  mount ntfs.raw lower
+  touch lower/file.txt
+  mount -t overlay -o lowerdir=lower,upperdir=upper,workdir=work - overlay
+  mv overlay/file.txt overlay/file2.txt
+
+mv fails and (misleadingly) prints
+
+  mv: cannot move 'overlay/file.txt' to a subdirectory of itself, 'overlay/file2.txt'
+
+The reason is that ovl_copy_fileattr() is triggered due to S_NOATIME being
+set on all inodes (by fuse) regardless of fileattr.
+
+ovl_copy_fileattr() tries to retrieve file attributes from lower file, but
+that fails because filesystem does not support this ioctl (this should fail
+with ENOTTY, but ntfs-3g return EINVAL instead).  This failure is
+propagated to origial operation (in this case rename) that triggered the
+copy-up.
+
+The fix is to ignore ENOTTY and EINVAL errors from fileattr_get() in copy
+up.  This also requires turning the internal ENOIOCTLCMD into ENOTTY.
+
+As a further measure to prevent unnecessary failures, only try the
+fileattr_get/set on upper if there are any flags to copy up.
+
+Side note: a number of filesystems set S_NOATIME (and sometimes other inode
+flags) irrespective of fileattr flags.  This causes unnecessary calls
+during copy up, which might lead to a performance issue, especially if
+latency is high.  To fix this, the kernel would need to differentiate
+between the two cases.  E.g. introduce SB_NOATIME_UPDATE, a per-sb variant
+of S_NOATIME.  SB_NOATIME doesn't work, because that's interpreted as
+"filesystem doesn't store an atime attribute"
+
+Reported-and-tested-by: Kevin Locke <kevin@kevinlocke.name>
+Fixes: 72db82115d2b ("ovl: copy up sync/noatime fileattr flags")
+Cc: <stable@vger.kernel.org> # v5.15
+Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ fs/overlayfs/copy_up.c |   23 ++++++++++++++++++-----
+ fs/overlayfs/inode.c   |    5 ++++-
+ 2 files changed, 22 insertions(+), 6 deletions(-)
+
+--- a/fs/overlayfs/copy_up.c
++++ b/fs/overlayfs/copy_up.c
+@@ -140,12 +140,14 @@ static int ovl_copy_fileattr(struct inod
+       int err;
+       err = ovl_real_fileattr_get(old, &oldfa);
+-      if (err)
+-              return err;
+-
+-      err = ovl_real_fileattr_get(new, &newfa);
+-      if (err)
++      if (err) {
++              /* Ntfs-3g returns -EINVAL for "no fileattr support" */
++              if (err == -ENOTTY || err == -EINVAL)
++                      return 0;
++              pr_warn("failed to retrieve lower fileattr (%pd2, err=%i)\n",
++                      old, err);
+               return err;
++      }
+       /*
+        * We cannot set immutable and append-only flags on upper inode,
+@@ -159,6 +161,17 @@ static int ovl_copy_fileattr(struct inod
+                       return err;
+       }
++      /* Don't bother copying flags if none are set */
++      if (!(oldfa.flags & OVL_COPY_FS_FLAGS_MASK))
++              return 0;
++
++      err = ovl_real_fileattr_get(new, &newfa);
++      if (err) {
++              pr_warn("failed to retrieve upper fileattr (%pd2, err=%i)\n",
++                      new, err);
++              return err;
++      }
++
+       BUILD_BUG_ON(OVL_COPY_FS_FLAGS_MASK & ~FS_COMMON_FL);
+       newfa.flags &= ~OVL_COPY_FS_FLAGS_MASK;
+       newfa.flags |= (oldfa.flags & OVL_COPY_FS_FLAGS_MASK);
+--- a/fs/overlayfs/inode.c
++++ b/fs/overlayfs/inode.c
+@@ -610,7 +610,10 @@ int ovl_real_fileattr_get(struct path *r
+       if (err)
+               return err;
+-      return vfs_fileattr_get(realpath->dentry, fa);
++      err = vfs_fileattr_get(realpath->dentry, fa);
++      if (err == -ENOIOCTLCMD)
++              err = -ENOTTY;
++      return err;
+ }
+ int ovl_fileattr_get(struct dentry *dentry, struct fileattr *fa)
diff --git a/queue-5.15/ovl-fix-use-after-free-in-struct-ovl_aio_req.patch b/queue-5.15/ovl-fix-use-after-free-in-struct-ovl_aio_req.patch
new file mode 100644 (file)
index 0000000..aee443a
--- /dev/null
@@ -0,0 +1,92 @@
+From 9a254403760041528bc8f69fe2f5e1ef86950991 Mon Sep 17 00:00:00 2001
+From: yangerkun <yangerkun@huawei.com>
+Date: Thu, 30 Sep 2021 11:22:28 +0800
+Subject: ovl: fix use after free in struct ovl_aio_req
+
+From: yangerkun <yangerkun@huawei.com>
+
+commit 9a254403760041528bc8f69fe2f5e1ef86950991 upstream.
+
+Example for triggering use after free in a overlay on ext4 setup:
+
+aio_read
+  ovl_read_iter
+    vfs_iter_read
+      ext4_file_read_iter
+        ext4_dio_read_iter
+          iomap_dio_rw -> -EIOCBQUEUED
+          /*
+          * Here IO is completed in a separate thread,
+          * ovl_aio_cleanup_handler() frees aio_req which has iocb embedded
+          */
+          file_accessed(iocb->ki_filp); /**BOOM**/
+
+Fix by introducing a refcount in ovl_aio_req similarly to aio_kiocb.  This
+guarantees that iocb is only freed after vfs_read/write_iter() returns on
+underlying fs.
+
+Fixes: 2406a307ac7d ("ovl: implement async IO routines")
+Signed-off-by: yangerkun <yangerkun@huawei.com>
+Link: https://lore.kernel.org/r/20210930032228.3199690-3-yangerkun@huawei.com/
+Cc: <stable@vger.kernel.org> # v5.6
+Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ fs/overlayfs/file.c |   16 ++++++++++++++--
+ 1 file changed, 14 insertions(+), 2 deletions(-)
+
+--- a/fs/overlayfs/file.c
++++ b/fs/overlayfs/file.c
+@@ -17,6 +17,7 @@
+ struct ovl_aio_req {
+       struct kiocb iocb;
++      refcount_t ref;
+       struct kiocb *orig_iocb;
+       struct fd fd;
+ };
+@@ -252,6 +253,14 @@ static rwf_t ovl_iocb_to_rwf(int ifl)
+       return flags;
+ }
++static inline void ovl_aio_put(struct ovl_aio_req *aio_req)
++{
++      if (refcount_dec_and_test(&aio_req->ref)) {
++              fdput(aio_req->fd);
++              kmem_cache_free(ovl_aio_request_cachep, aio_req);
++      }
++}
++
+ static void ovl_aio_cleanup_handler(struct ovl_aio_req *aio_req)
+ {
+       struct kiocb *iocb = &aio_req->iocb;
+@@ -268,8 +277,7 @@ static void ovl_aio_cleanup_handler(stru
+       }
+       orig_iocb->ki_pos = iocb->ki_pos;
+-      fdput(aio_req->fd);
+-      kmem_cache_free(ovl_aio_request_cachep, aio_req);
++      ovl_aio_put(aio_req);
+ }
+ static void ovl_aio_rw_complete(struct kiocb *iocb, long res, long res2)
+@@ -319,7 +327,9 @@ static ssize_t ovl_read_iter(struct kioc
+               aio_req->orig_iocb = iocb;
+               kiocb_clone(&aio_req->iocb, iocb, real.file);
+               aio_req->iocb.ki_complete = ovl_aio_rw_complete;
++              refcount_set(&aio_req->ref, 2);
+               ret = vfs_iocb_iter_read(real.file, &aio_req->iocb, iter);
++              ovl_aio_put(aio_req);
+               if (ret != -EIOCBQUEUED)
+                       ovl_aio_cleanup_handler(aio_req);
+       }
+@@ -390,7 +400,9 @@ static ssize_t ovl_write_iter(struct kio
+               kiocb_clone(&aio_req->iocb, iocb, real.file);
+               aio_req->iocb.ki_flags = ifl;
+               aio_req->iocb.ki_complete = ovl_aio_rw_complete;
++              refcount_set(&aio_req->ref, 2);
+               ret = vfs_iocb_iter_write(real.file, &aio_req->iocb, iter);
++              ovl_aio_put(aio_req);
+               if (ret != -EIOCBQUEUED)
+                       ovl_aio_cleanup_handler(aio_req);
+       }
diff --git a/queue-5.15/pci-aardvark-do-not-clear-status-bits-of-masked-interrupts.patch b/queue-5.15/pci-aardvark-do-not-clear-status-bits-of-masked-interrupts.patch
new file mode 100644 (file)
index 0000000..44a7feb
--- /dev/null
@@ -0,0 +1,51 @@
+From a7ca6d7fa3c02c032db5440ff392d96c04684c21 Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Pali=20Roh=C3=A1r?= <pali@kernel.org>
+Date: Tue, 5 Oct 2021 20:09:45 +0200
+Subject: PCI: aardvark: Do not clear status bits of masked interrupts
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Pali Rohár <pali@kernel.org>
+
+commit a7ca6d7fa3c02c032db5440ff392d96c04684c21 upstream.
+
+The PCIE_ISR1_REG says which interrupts are currently set / active,
+including those which are masked.
+
+The driver currently reads this register and looks if some unmasked
+interrupts are active, and if not, it clears status bits of _all_
+interrupts, including the masked ones.
+
+This is incorrect, since, for example, some drivers may poll these bits.
+
+Remove this clearing, and also remove this early return statement
+completely, since it does not change functionality in any way.
+
+Link: https://lore.kernel.org/r/20211005180952.6812-7-kabel@kernel.org
+Fixes: 8c39d710363c ("PCI: aardvark: Add Aardvark PCI host controller driver")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Reviewed-by: Marek Behún <kabel@kernel.org>
+Cc: stable@vger.kernel.org
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/pci-aardvark.c |    6 ------
+ 1 file changed, 6 deletions(-)
+
+--- a/drivers/pci/controller/pci-aardvark.c
++++ b/drivers/pci/controller/pci-aardvark.c
+@@ -1286,12 +1286,6 @@ static void advk_pcie_handle_int(struct
+       isr1_mask = advk_readl(pcie, PCIE_ISR1_MASK_REG);
+       isr1_status = isr1_val & ((~isr1_mask) & PCIE_ISR1_ALL_MASK);
+-      if (!isr0_status && !isr1_status) {
+-              advk_writel(pcie, isr0_val, PCIE_ISR0_REG);
+-              advk_writel(pcie, isr1_val, PCIE_ISR1_REG);
+-              return;
+-      }
+-
+       /* Process MSI interrupts */
+       if (isr0_status & PCIE_ISR0_MSI_INT_PENDING)
+               advk_pcie_handle_msi(pcie);
diff --git a/queue-5.15/pci-aardvark-do-not-unmask-unused-interrupts.patch b/queue-5.15/pci-aardvark-do-not-unmask-unused-interrupts.patch
new file mode 100644 (file)
index 0000000..bd53be2
--- /dev/null
@@ -0,0 +1,56 @@
+From 1fb95d7d3c7a926b002fe8a6bd27a1cb428b46dc Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Pali=20Roh=C3=A1r?= <pali@kernel.org>
+Date: Tue, 5 Oct 2021 20:09:46 +0200
+Subject: PCI: aardvark: Do not unmask unused interrupts
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Pali Rohár <pali@kernel.org>
+
+commit 1fb95d7d3c7a926b002fe8a6bd27a1cb428b46dc upstream.
+
+There are lot of undocumented interrupt bits. To prevent unwanted
+spurious interrupts, fix all *_ALL_MASK macros to define all interrupt
+bits, so that driver can properly mask all interrupts, including those
+which are undocumented.
+
+Link: https://lore.kernel.org/r/20211005180952.6812-8-kabel@kernel.org
+Fixes: 8c39d710363c ("PCI: aardvark: Add Aardvark PCI host controller driver")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Reviewed-by: Marek Behún <kabel@kernel.org>
+Cc: stable@vger.kernel.org
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/pci-aardvark.c |    6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+--- a/drivers/pci/controller/pci-aardvark.c
++++ b/drivers/pci/controller/pci-aardvark.c
+@@ -106,13 +106,13 @@
+ #define     PCIE_ISR0_MSI_INT_PENDING         BIT(24)
+ #define     PCIE_ISR0_INTX_ASSERT(val)                BIT(16 + (val))
+ #define     PCIE_ISR0_INTX_DEASSERT(val)      BIT(20 + (val))
+-#define           PCIE_ISR0_ALL_MASK                  GENMASK(26, 0)
++#define     PCIE_ISR0_ALL_MASK                        GENMASK(31, 0)
+ #define PCIE_ISR1_REG                         (CONTROL_BASE_ADDR + 0x48)
+ #define PCIE_ISR1_MASK_REG                    (CONTROL_BASE_ADDR + 0x4C)
+ #define     PCIE_ISR1_POWER_STATE_CHANGE      BIT(4)
+ #define     PCIE_ISR1_FLUSH                   BIT(5)
+ #define     PCIE_ISR1_INTX_ASSERT(val)                BIT(8 + (val))
+-#define     PCIE_ISR1_ALL_MASK                        GENMASK(11, 4)
++#define     PCIE_ISR1_ALL_MASK                        GENMASK(31, 0)
+ #define PCIE_MSI_ADDR_LOW_REG                 (CONTROL_BASE_ADDR + 0x50)
+ #define PCIE_MSI_ADDR_HIGH_REG                        (CONTROL_BASE_ADDR + 0x54)
+ #define PCIE_MSI_STATUS_REG                   (CONTROL_BASE_ADDR + 0x58)
+@@ -240,7 +240,7 @@ enum {
+ #define     PCIE_IRQ_MSI_INT2_DET             BIT(21)
+ #define     PCIE_IRQ_RC_DBELL_DET             BIT(22)
+ #define     PCIE_IRQ_EP_STATUS                        BIT(23)
+-#define     PCIE_IRQ_ALL_MASK                 0xfff0fb
++#define     PCIE_IRQ_ALL_MASK                 GENMASK(31, 0)
+ #define     PCIE_IRQ_ENABLE_INTS_MASK         PCIE_IRQ_CORE_INT
+ /* Transaction types */
diff --git a/queue-5.15/pci-aardvark-fix-checking-for-link-up-via-ltssm-state.patch b/queue-5.15/pci-aardvark-fix-checking-for-link-up-via-ltssm-state.patch
new file mode 100644 (file)
index 0000000..ddf6101
--- /dev/null
@@ -0,0 +1,148 @@
+From 661c399a651c11aaf83c45cbfe0b4a1fb7bc3179 Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Pali=20Roh=C3=A1r?= <pali@kernel.org>
+Date: Tue, 5 Oct 2021 20:09:51 +0200
+Subject: PCI: aardvark: Fix checking for link up via LTSSM state
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Pali Rohár <pali@kernel.org>
+
+commit 661c399a651c11aaf83c45cbfe0b4a1fb7bc3179 upstream.
+
+Current implementation of advk_pcie_link_up() is wrong as it marks also
+link disabled or hot reset states as link up.
+
+Fix it by marking link up only to those states which are defined in PCIe
+Base specification 3.0, Table 4-14: Link Status Mapped to the LTSSM.
+
+To simplify implementation, Define macros for every LTSSM state which
+aardvark hardware can return in CFG_REG register.
+
+Fix also checking for link training according to the same Table 4-14.
+Define a new function advk_pcie_link_training() for this purpose.
+
+Link: https://lore.kernel.org/r/20211005180952.6812-13-kabel@kernel.org
+Fixes: 8c39d710363c ("PCI: aardvark: Add Aardvark PCI host controller driver")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Reviewed-by: Marek Behún <kabel@kernel.org>
+Cc: stable@vger.kernel.org
+Cc: Remi Pommarel <repk@triplefau.lt>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/pci-aardvark.c |   76 +++++++++++++++++++++++++++++++---
+ 1 file changed, 70 insertions(+), 6 deletions(-)
+
+--- a/drivers/pci/controller/pci-aardvark.c
++++ b/drivers/pci/controller/pci-aardvark.c
+@@ -164,8 +164,50 @@
+ #define CFG_REG                                       (LMI_BASE_ADDR + 0x0)
+ #define     LTSSM_SHIFT                               24
+ #define     LTSSM_MASK                                0x3f
+-#define     LTSSM_L0                          0x10
+ #define     RC_BAR_CONFIG                     0x300
++
++/* LTSSM values in CFG_REG */
++enum {
++      LTSSM_DETECT_QUIET                      = 0x0,
++      LTSSM_DETECT_ACTIVE                     = 0x1,
++      LTSSM_POLLING_ACTIVE                    = 0x2,
++      LTSSM_POLLING_COMPLIANCE                = 0x3,
++      LTSSM_POLLING_CONFIGURATION             = 0x4,
++      LTSSM_CONFIG_LINKWIDTH_START            = 0x5,
++      LTSSM_CONFIG_LINKWIDTH_ACCEPT           = 0x6,
++      LTSSM_CONFIG_LANENUM_ACCEPT             = 0x7,
++      LTSSM_CONFIG_LANENUM_WAIT               = 0x8,
++      LTSSM_CONFIG_COMPLETE                   = 0x9,
++      LTSSM_CONFIG_IDLE                       = 0xa,
++      LTSSM_RECOVERY_RCVR_LOCK                = 0xb,
++      LTSSM_RECOVERY_SPEED                    = 0xc,
++      LTSSM_RECOVERY_RCVR_CFG                 = 0xd,
++      LTSSM_RECOVERY_IDLE                     = 0xe,
++      LTSSM_L0                                = 0x10,
++      LTSSM_RX_L0S_ENTRY                      = 0x11,
++      LTSSM_RX_L0S_IDLE                       = 0x12,
++      LTSSM_RX_L0S_FTS                        = 0x13,
++      LTSSM_TX_L0S_ENTRY                      = 0x14,
++      LTSSM_TX_L0S_IDLE                       = 0x15,
++      LTSSM_TX_L0S_FTS                        = 0x16,
++      LTSSM_L1_ENTRY                          = 0x17,
++      LTSSM_L1_IDLE                           = 0x18,
++      LTSSM_L2_IDLE                           = 0x19,
++      LTSSM_L2_TRANSMIT_WAKE                  = 0x1a,
++      LTSSM_DISABLED                          = 0x20,
++      LTSSM_LOOPBACK_ENTRY_MASTER             = 0x21,
++      LTSSM_LOOPBACK_ACTIVE_MASTER            = 0x22,
++      LTSSM_LOOPBACK_EXIT_MASTER              = 0x23,
++      LTSSM_LOOPBACK_ENTRY_SLAVE              = 0x24,
++      LTSSM_LOOPBACK_ACTIVE_SLAVE             = 0x25,
++      LTSSM_LOOPBACK_EXIT_SLAVE               = 0x26,
++      LTSSM_HOT_RESET                         = 0x27,
++      LTSSM_RECOVERY_EQUALIZATION_PHASE0      = 0x28,
++      LTSSM_RECOVERY_EQUALIZATION_PHASE1      = 0x29,
++      LTSSM_RECOVERY_EQUALIZATION_PHASE2      = 0x2a,
++      LTSSM_RECOVERY_EQUALIZATION_PHASE3      = 0x2b,
++};
++
+ #define VENDOR_ID_REG                         (LMI_BASE_ADDR + 0x44)
+ /* PCIe core controller registers */
+@@ -262,13 +304,35 @@ static inline u16 advk_read16(struct adv
+       return advk_readl(pcie, (reg & ~0x3)) >> ((reg & 0x3) * 8);
+ }
+-static int advk_pcie_link_up(struct advk_pcie *pcie)
++static u8 advk_pcie_ltssm_state(struct advk_pcie *pcie)
+ {
+-      u32 val, ltssm_state;
++      u32 val;
++      u8 ltssm_state;
+       val = advk_readl(pcie, CFG_REG);
+       ltssm_state = (val >> LTSSM_SHIFT) & LTSSM_MASK;
+-      return ltssm_state >= LTSSM_L0;
++      return ltssm_state;
++}
++
++static inline bool advk_pcie_link_up(struct advk_pcie *pcie)
++{
++      /* check if LTSSM is in normal operation - some L* state */
++      u8 ltssm_state = advk_pcie_ltssm_state(pcie);
++      return ltssm_state >= LTSSM_L0 && ltssm_state < LTSSM_DISABLED;
++}
++
++static inline bool advk_pcie_link_training(struct advk_pcie *pcie)
++{
++      /*
++       * According to PCIe Base specification 3.0, Table 4-14: Link
++       * Status Mapped to the LTSSM is Link Training mapped to LTSSM
++       * Configuration and Recovery states.
++       */
++      u8 ltssm_state = advk_pcie_ltssm_state(pcie);
++      return ((ltssm_state >= LTSSM_CONFIG_LINKWIDTH_START &&
++               ltssm_state < LTSSM_L0) ||
++              (ltssm_state >= LTSSM_RECOVERY_EQUALIZATION_PHASE0 &&
++               ltssm_state <= LTSSM_RECOVERY_EQUALIZATION_PHASE3));
+ }
+ static int advk_pcie_wait_for_link(struct advk_pcie *pcie)
+@@ -291,7 +355,7 @@ static void advk_pcie_wait_for_retrain(s
+       size_t retries;
+       for (retries = 0; retries < RETRAIN_WAIT_MAX_RETRIES; ++retries) {
+-              if (!advk_pcie_link_up(pcie))
++              if (advk_pcie_link_training(pcie))
+                       break;
+               udelay(RETRAIN_WAIT_USLEEP_US);
+       }
+@@ -738,7 +802,7 @@ advk_pci_bridge_emul_pcie_conf_read(stru
+               /* u32 contains both PCI_EXP_LNKCTL and PCI_EXP_LNKSTA */
+               u32 val = advk_readl(pcie, PCIE_CORE_PCIEXP_CAP + reg) &
+                       ~(PCI_EXP_LNKSTA_LT << 16);
+-              if (!advk_pcie_link_up(pcie))
++              if (advk_pcie_link_training(pcie))
+                       val |= (PCI_EXP_LNKSTA_LT << 16);
+               *value = val;
+               return PCI_BRIDGE_EMUL_HANDLED;
diff --git a/queue-5.15/pci-aardvark-fix-configuring-reference-clock.patch b/queue-5.15/pci-aardvark-fix-configuring-reference-clock.patch
new file mode 100644 (file)
index 0000000..273c8f8
--- /dev/null
@@ -0,0 +1,68 @@
+From 46ef6090dbf590711cb12680b6eafde5fa21fe87 Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Pali=20Roh=C3=A1r?= <pali@kernel.org>
+Date: Tue, 5 Oct 2021 20:09:44 +0200
+Subject: PCI: aardvark: Fix configuring Reference clock
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Pali Rohár <pali@kernel.org>
+
+commit 46ef6090dbf590711cb12680b6eafde5fa21fe87 upstream.
+
+Commit 366697018c9a ("PCI: aardvark: Add PHY support") introduced
+configuration of PCIe Reference clock via PCIE_CORE_REF_CLK_REG register,
+but did it incorrectly.
+
+PCIe Reference clock differential pair is routed from system board to
+endpoint card, so on CPU side it has output direction. Therefore it is
+required to enable transmitting and disable receiving.
+
+Default configuration according to Armada 3700 Functional Specifications is
+enabled receiver part and disabled transmitter.
+
+We need this change because otherwise PCIe Reference clock is configured to
+some undefined state when differential pair is used for both transmitting
+and receiving.
+
+Fix this by disabling receiver part.
+
+Link: https://lore.kernel.org/r/20211005180952.6812-6-kabel@kernel.org
+Fixes: 366697018c9a ("PCI: aardvark: Add PHY support")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Reviewed-by: Marek Behún <kabel@kernel.org>
+Cc: stable@vger.kernel.org
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/pci-aardvark.c |    9 ++++++++-
+ 1 file changed, 8 insertions(+), 1 deletion(-)
+
+--- a/drivers/pci/controller/pci-aardvark.c
++++ b/drivers/pci/controller/pci-aardvark.c
+@@ -99,6 +99,7 @@
+ #define     PCIE_CORE_CTRL2_MSI_ENABLE                BIT(10)
+ #define PCIE_CORE_REF_CLK_REG                 (CONTROL_BASE_ADDR + 0x14)
+ #define     PCIE_CORE_REF_CLK_TX_ENABLE               BIT(1)
++#define     PCIE_CORE_REF_CLK_RX_ENABLE               BIT(2)
+ #define PCIE_MSG_LOG_REG                      (CONTROL_BASE_ADDR + 0x30)
+ #define PCIE_ISR0_REG                         (CONTROL_BASE_ADDR + 0x40)
+ #define PCIE_MSG_PM_PME_MASK                  BIT(7)
+@@ -529,9 +530,15 @@ static void advk_pcie_setup_hw(struct ad
+       u32 reg;
+       int i;
+-      /* Enable TX */
++      /*
++       * Configure PCIe Reference clock. Direction is from the PCIe
++       * controller to the endpoint card, so enable transmitting of
++       * Reference clock differential signal off-chip and disable
++       * receiving off-chip differential signal.
++       */
+       reg = advk_readl(pcie, PCIE_CORE_REF_CLK_REG);
+       reg |= PCIE_CORE_REF_CLK_TX_ENABLE;
++      reg &= ~PCIE_CORE_REF_CLK_RX_ENABLE;
+       advk_writel(pcie, reg, PCIE_CORE_REF_CLK_REG);
+       /* Set to Direct mode */
diff --git a/queue-5.15/pci-aardvark-fix-reporting-data-link-layer-link-active.patch b/queue-5.15/pci-aardvark-fix-reporting-data-link-layer-link-active.patch
new file mode 100644 (file)
index 0000000..fea08f9
--- /dev/null
@@ -0,0 +1,87 @@
+From 2b650b7ff20eb7ea8ef9031d20fb657286ab90cc Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Pali=20Roh=C3=A1r?= <pali@kernel.org>
+Date: Tue, 5 Oct 2021 20:09:52 +0200
+Subject: PCI: aardvark: Fix reporting Data Link Layer Link Active
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Pali Rohár <pali@kernel.org>
+
+commit 2b650b7ff20eb7ea8ef9031d20fb657286ab90cc upstream.
+
+Add support for reporting PCI_EXP_LNKSTA_DLLLA bit in Link Control register
+on emulated bridge via current LTSSM state. Also correctly indicate DLLLA
+capability via PCI_EXP_LNKCAP_DLLLARC bit in Link Control Capability
+register.
+
+Link: https://lore.kernel.org/r/20211005180952.6812-14-kabel@kernel.org
+Fixes: 8a3ebd8de328 ("PCI: aardvark: Implement emulated root PCI bridge config space")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Reviewed-by: Marek Behún <kabel@kernel.org>
+Cc: stable@vger.kernel.org
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/pci-aardvark.c |   29 ++++++++++++++++++++++++++++-
+ 1 file changed, 28 insertions(+), 1 deletion(-)
+
+--- a/drivers/pci/controller/pci-aardvark.c
++++ b/drivers/pci/controller/pci-aardvark.c
+@@ -321,6 +321,20 @@ static inline bool advk_pcie_link_up(str
+       return ltssm_state >= LTSSM_L0 && ltssm_state < LTSSM_DISABLED;
+ }
++static inline bool advk_pcie_link_active(struct advk_pcie *pcie)
++{
++      /*
++       * According to PCIe Base specification 3.0, Table 4-14: Link
++       * Status Mapped to the LTSSM, and 4.2.6.3.6 Configuration.Idle
++       * is Link Up mapped to LTSSM Configuration.Idle, Recovery, L0,
++       * L0s, L1 and L2 states. And according to 3.2.1. Data Link
++       * Control and Management State Machine Rules is DL Up status
++       * reported in DL Active state.
++       */
++      u8 ltssm_state = advk_pcie_ltssm_state(pcie);
++      return ltssm_state >= LTSSM_CONFIG_IDLE && ltssm_state < LTSSM_DISABLED;
++}
++
+ static inline bool advk_pcie_link_training(struct advk_pcie *pcie)
+ {
+       /*
+@@ -798,12 +812,26 @@ advk_pci_bridge_emul_pcie_conf_read(stru
+               return PCI_BRIDGE_EMUL_HANDLED;
+       }
++      case PCI_EXP_LNKCAP: {
++              u32 val = advk_readl(pcie, PCIE_CORE_PCIEXP_CAP + reg);
++              /*
++               * PCI_EXP_LNKCAP_DLLLARC bit is hardwired in aardvark HW to 0.
++               * But support for PCI_EXP_LNKSTA_DLLLA is emulated via ltssm
++               * state so explicitly enable PCI_EXP_LNKCAP_DLLLARC flag.
++               */
++              val |= PCI_EXP_LNKCAP_DLLLARC;
++              *value = val;
++              return PCI_BRIDGE_EMUL_HANDLED;
++      }
++
+       case PCI_EXP_LNKCTL: {
+               /* u32 contains both PCI_EXP_LNKCTL and PCI_EXP_LNKSTA */
+               u32 val = advk_readl(pcie, PCIE_CORE_PCIEXP_CAP + reg) &
+                       ~(PCI_EXP_LNKSTA_LT << 16);
+               if (advk_pcie_link_training(pcie))
+                       val |= (PCI_EXP_LNKSTA_LT << 16);
++              if (advk_pcie_link_active(pcie))
++                      val |= (PCI_EXP_LNKSTA_DLLLA << 16);
+               *value = val;
+               return PCI_BRIDGE_EMUL_HANDLED;
+       }
+@@ -811,7 +839,6 @@ advk_pci_bridge_emul_pcie_conf_read(stru
+       case PCI_CAP_LIST_ID:
+       case PCI_EXP_DEVCAP:
+       case PCI_EXP_DEVCTL:
+-      case PCI_EXP_LNKCAP:
+               *value = advk_readl(pcie, PCIE_CORE_PCIEXP_CAP + reg);
+               return PCI_BRIDGE_EMUL_HANDLED;
+       default:
diff --git a/queue-5.15/pci-aardvark-fix-return-value-of-msi-domain-.alloc-method.patch b/queue-5.15/pci-aardvark-fix-return-value-of-msi-domain-.alloc-method.patch
new file mode 100644 (file)
index 0000000..2c2ce24
--- /dev/null
@@ -0,0 +1,44 @@
+From e4313be1599d397625c14fb7826996813622decf Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Marek=20Beh=C3=BAn?= <kabel@kernel.org>
+Date: Thu, 28 Oct 2021 20:56:54 +0200
+Subject: PCI: aardvark: Fix return value of MSI domain .alloc() method
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Marek Behún <kabel@kernel.org>
+
+commit e4313be1599d397625c14fb7826996813622decf upstream.
+
+MSI domain callback .alloc() (implemented by advk_msi_irq_domain_alloc()
+function) should return zero on success, since non-zero value indicates
+failure.
+
+When the driver was converted to generic MSI API in commit f21a8b1b6837
+("PCI: aardvark: Move to MSI handling using generic MSI support"), it
+was converted so that it returns hwirq number.
+
+Fix this.
+
+Link: https://lore.kernel.org/r/20211028185659.20329-3-kabel@kernel.org
+Fixes: f21a8b1b6837 ("PCI: aardvark: Move to MSI handling using generic MSI support")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Cc: stable@vger.kernel.org
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/pci-aardvark.c |    2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+--- a/drivers/pci/controller/pci-aardvark.c
++++ b/drivers/pci/controller/pci-aardvark.c
+@@ -1180,7 +1180,7 @@ static int advk_msi_irq_domain_alloc(str
+                                   domain->host_data, handle_simple_irq,
+                                   NULL, NULL);
+-      return hwirq;
++      return 0;
+ }
+ static void advk_msi_irq_domain_free(struct irq_domain *domain,
diff --git a/queue-5.15/pci-aardvark-fix-support-for-bus-mastering-and-pci_command-on-emulated-bridge.patch b/queue-5.15/pci-aardvark-fix-support-for-bus-mastering-and-pci_command-on-emulated-bridge.patch
new file mode 100644 (file)
index 0000000..8fb74dc
--- /dev/null
@@ -0,0 +1,131 @@
+From 771153fc884f566a89af2d30033b7f3bc6e24e84 Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Pali=20Roh=C3=A1r?= <pali@kernel.org>
+Date: Thu, 28 Oct 2021 20:56:56 +0200
+Subject: PCI: aardvark: Fix support for bus mastering and PCI_COMMAND on emulated bridge
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Pali Rohár <pali@kernel.org>
+
+commit 771153fc884f566a89af2d30033b7f3bc6e24e84 upstream.
+
+From very vague, ambiguous and incomplete information from Marvell we
+deduced that the 32-bit Aardvark register at address 0x4
+(PCIE_CORE_CMD_STATUS_REG), which is not documented for Root Complex mode
+in the Functional Specification (only for Endpoint mode), controls two
+16-bit PCIe registers: Command Register and Status Registers of PCIe Root
+Port.
+
+This means that bit 2 controls bus mastering and forwarding of memory and
+I/O requests in the upstream direction. According to PCI specifications
+bits [0:2] of Command Register, this should be by default disabled on
+reset. So explicitly disable these bits at early setup of the Aardvark
+driver.
+
+Remove code which unconditionally enables all 3 bits and let kernel code
+(via pci_set_master() function) to handle bus mastering of Root PCIe
+Bridge via emulated PCI_COMMAND on emulated bridge.
+
+Link: https://lore.kernel.org/r/20211028185659.20329-5-kabel@kernel.org
+Fixes: 8a3ebd8de328 ("PCI: aardvark: Implement emulated root PCI bridge config space")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Cc: stable@vger.kernel.org # b2a56469d550 ("PCI: aardvark: Add FIXME comment for PCIE_CORE_CMD_STATUS_REG access")
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/pci-aardvark.c |   54 +++++++++++++++++++++++-----------
+ 1 file changed, 38 insertions(+), 16 deletions(-)
+
+--- a/drivers/pci/controller/pci-aardvark.c
++++ b/drivers/pci/controller/pci-aardvark.c
+@@ -31,9 +31,6 @@
+ /* PCIe core registers */
+ #define PCIE_CORE_DEV_ID_REG                                  0x0
+ #define PCIE_CORE_CMD_STATUS_REG                              0x4
+-#define     PCIE_CORE_CMD_IO_ACCESS_EN                                BIT(0)
+-#define     PCIE_CORE_CMD_MEM_ACCESS_EN                               BIT(1)
+-#define     PCIE_CORE_CMD_MEM_IO_REQ_EN                               BIT(2)
+ #define PCIE_CORE_DEV_REV_REG                                 0x8
+ #define PCIE_CORE_PCIEXP_CAP                                  0xc0
+ #define PCIE_CORE_ERR_CAPCTL_REG                              0x118
+@@ -563,6 +560,11 @@ static void advk_pcie_setup_hw(struct ad
+       reg = (PCI_VENDOR_ID_MARVELL << 16) | PCI_VENDOR_ID_MARVELL;
+       advk_writel(pcie, reg, VENDOR_ID_REG);
++      /* Disable Root Bridge I/O space, memory space and bus mastering */
++      reg = advk_readl(pcie, PCIE_CORE_CMD_STATUS_REG);
++      reg &= ~(PCI_COMMAND_IO | PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER);
++      advk_writel(pcie, reg, PCIE_CORE_CMD_STATUS_REG);
++
+       /* Set Advanced Error Capabilities and Control PF0 register */
+       reg = PCIE_CORE_ERR_CAPCTL_ECRC_CHK_TX |
+               PCIE_CORE_ERR_CAPCTL_ECRC_CHK_TX_EN |
+@@ -660,19 +662,6 @@ static void advk_pcie_setup_hw(struct ad
+               advk_pcie_disable_ob_win(pcie, i);
+       advk_pcie_train_link(pcie);
+-
+-      /*
+-       * FIXME: The following register update is suspicious. This register is
+-       * applicable only when the PCI controller is configured for Endpoint
+-       * mode, not as a Root Complex. But apparently when this code is
+-       * removed, some cards stop working. This should be investigated and
+-       * a comment explaining this should be put here.
+-       */
+-      reg = advk_readl(pcie, PCIE_CORE_CMD_STATUS_REG);
+-      reg |= PCIE_CORE_CMD_MEM_ACCESS_EN |
+-              PCIE_CORE_CMD_IO_ACCESS_EN |
+-              PCIE_CORE_CMD_MEM_IO_REQ_EN;
+-      advk_writel(pcie, reg, PCIE_CORE_CMD_STATUS_REG);
+ }
+ static int advk_pcie_check_pio_status(struct advk_pcie *pcie, bool allow_crs, u32 *val)
+@@ -793,6 +782,37 @@ static int advk_pcie_wait_pio(struct adv
+       return -ETIMEDOUT;
+ }
++static pci_bridge_emul_read_status_t
++advk_pci_bridge_emul_base_conf_read(struct pci_bridge_emul *bridge,
++                                  int reg, u32 *value)
++{
++      struct advk_pcie *pcie = bridge->data;
++
++      switch (reg) {
++      case PCI_COMMAND:
++              *value = advk_readl(pcie, PCIE_CORE_CMD_STATUS_REG);
++              return PCI_BRIDGE_EMUL_HANDLED;
++
++      default:
++              return PCI_BRIDGE_EMUL_NOT_HANDLED;
++      }
++}
++
++static void
++advk_pci_bridge_emul_base_conf_write(struct pci_bridge_emul *bridge,
++                                   int reg, u32 old, u32 new, u32 mask)
++{
++      struct advk_pcie *pcie = bridge->data;
++
++      switch (reg) {
++      case PCI_COMMAND:
++              advk_writel(pcie, new, PCIE_CORE_CMD_STATUS_REG);
++              break;
++
++      default:
++              break;
++      }
++}
+ static pci_bridge_emul_read_status_t
+ advk_pci_bridge_emul_pcie_conf_read(struct pci_bridge_emul *bridge,
+@@ -893,6 +913,8 @@ advk_pci_bridge_emul_pcie_conf_write(str
+ }
+ static struct pci_bridge_emul_ops advk_pci_bridge_emul_ops = {
++      .read_base = advk_pci_bridge_emul_base_conf_read,
++      .write_base = advk_pci_bridge_emul_base_conf_write,
+       .read_pcie = advk_pci_bridge_emul_pcie_conf_read,
+       .write_pcie = advk_pci_bridge_emul_pcie_conf_write,
+ };
diff --git a/queue-5.15/pci-aardvark-fix-support-for-pci_bridge_ctl_bus_reset-on-emulated-bridge.patch b/queue-5.15/pci-aardvark-fix-support-for-pci_bridge_ctl_bus_reset-on-emulated-bridge.patch
new file mode 100644 (file)
index 0000000..660b8bc
--- /dev/null
@@ -0,0 +1,77 @@
+From bc4fac42e5f8460af09c0a7f2f1915be09e20c71 Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Pali=20Roh=C3=A1r?= <pali@kernel.org>
+Date: Thu, 28 Oct 2021 20:56:58 +0200
+Subject: PCI: aardvark: Fix support for PCI_BRIDGE_CTL_BUS_RESET on emulated bridge
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Pali Rohár <pali@kernel.org>
+
+commit bc4fac42e5f8460af09c0a7f2f1915be09e20c71 upstream.
+
+Aardvark supports PCIe Hot Reset via PCIE_CORE_CTRL1_REG.
+
+Use it for implementing PCI_BRIDGE_CTL_BUS_RESET bit of PCI_BRIDGE_CONTROL
+register on emulated bridge.
+
+With this, the function pci_reset_secondary_bus() starts working and can
+reset connected PCIe card. Custom userspace script [1] which uses setpci
+can trigger PCIe Hot Reset and reset the card manually.
+
+[1] https://alexforencich.com/wiki/en/pcie/hot-reset-linux
+
+Link: https://lore.kernel.org/r/20211028185659.20329-7-kabel@kernel.org
+Fixes: 8a3ebd8de328 ("PCI: aardvark: Implement emulated root PCI bridge config space")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Cc: stable@vger.kernel.org
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/pci-aardvark.c |   27 +++++++++++++++++++++++++++
+ 1 file changed, 27 insertions(+)
+
+--- a/drivers/pci/controller/pci-aardvark.c
++++ b/drivers/pci/controller/pci-aardvark.c
+@@ -793,6 +793,22 @@ advk_pci_bridge_emul_base_conf_read(stru
+               *value = advk_readl(pcie, PCIE_CORE_CMD_STATUS_REG);
+               return PCI_BRIDGE_EMUL_HANDLED;
++      case PCI_INTERRUPT_LINE: {
++              /*
++               * From the whole 32bit register we support reading from HW only
++               * one bit: PCI_BRIDGE_CTL_BUS_RESET.
++               * Other bits are retrieved only from emulated config buffer.
++               */
++              __le32 *cfgspace = (__le32 *)&bridge->conf;
++              u32 val = le32_to_cpu(cfgspace[PCI_INTERRUPT_LINE / 4]);
++              if (advk_readl(pcie, PCIE_CORE_CTRL1_REG) & HOT_RESET_GEN)
++                      val |= PCI_BRIDGE_CTL_BUS_RESET << 16;
++              else
++                      val &= ~(PCI_BRIDGE_CTL_BUS_RESET << 16);
++              *value = val;
++              return PCI_BRIDGE_EMUL_HANDLED;
++      }
++
+       default:
+               return PCI_BRIDGE_EMUL_NOT_HANDLED;
+       }
+@@ -809,6 +825,17 @@ advk_pci_bridge_emul_base_conf_write(str
+               advk_writel(pcie, new, PCIE_CORE_CMD_STATUS_REG);
+               break;
++      case PCI_INTERRUPT_LINE:
++              if (mask & (PCI_BRIDGE_CTL_BUS_RESET << 16)) {
++                      u32 val = advk_readl(pcie, PCIE_CORE_CTRL1_REG);
++                      if (new & (PCI_BRIDGE_CTL_BUS_RESET << 16))
++                              val |= HOT_RESET_GEN;
++                      else
++                              val &= ~HOT_RESET_GEN;
++                      advk_writel(pcie, val, PCIE_CORE_CTRL1_REG);
++              }
++              break;
++
+       default:
+               break;
+       }
diff --git a/queue-5.15/pci-aardvark-fix-support-for-pci_rom_address1-on-emulated-bridge.patch b/queue-5.15/pci-aardvark-fix-support-for-pci_rom_address1-on-emulated-bridge.patch
new file mode 100644 (file)
index 0000000..e693f27
--- /dev/null
@@ -0,0 +1,57 @@
+From 239edf686c14a9ff926dec2f350289ed7adfefe2 Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Pali=20Roh=C3=A1r?= <pali@kernel.org>
+Date: Thu, 28 Oct 2021 20:56:59 +0200
+Subject: PCI: aardvark: Fix support for PCI_ROM_ADDRESS1 on emulated bridge
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Pali Rohár <pali@kernel.org>
+
+commit 239edf686c14a9ff926dec2f350289ed7adfefe2 upstream.
+
+This register is exported at address offset 0x30.
+
+Link: https://lore.kernel.org/r/20211028185659.20329-8-kabel@kernel.org
+Fixes: 8a3ebd8de328 ("PCI: aardvark: Implement emulated root PCI bridge config space")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Cc: stable@vger.kernel.org
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/pci-aardvark.c |    9 +++++++++
+ 1 file changed, 9 insertions(+)
+
+--- a/drivers/pci/controller/pci-aardvark.c
++++ b/drivers/pci/controller/pci-aardvark.c
+@@ -32,6 +32,7 @@
+ #define PCIE_CORE_DEV_ID_REG                                  0x0
+ #define PCIE_CORE_CMD_STATUS_REG                              0x4
+ #define PCIE_CORE_DEV_REV_REG                                 0x8
++#define PCIE_CORE_EXP_ROM_BAR_REG                             0x30
+ #define PCIE_CORE_PCIEXP_CAP                                  0xc0
+ #define PCIE_CORE_ERR_CAPCTL_REG                              0x118
+ #define     PCIE_CORE_ERR_CAPCTL_ECRC_CHK_TX                  BIT(5)
+@@ -813,6 +814,10 @@ advk_pci_bridge_emul_base_conf_read(stru
+               *value = advk_readl(pcie, PCIE_CORE_CMD_STATUS_REG);
+               return PCI_BRIDGE_EMUL_HANDLED;
++      case PCI_ROM_ADDRESS1:
++              *value = advk_readl(pcie, PCIE_CORE_EXP_ROM_BAR_REG);
++              return PCI_BRIDGE_EMUL_HANDLED;
++
+       case PCI_INTERRUPT_LINE: {
+               /*
+                * From the whole 32bit register we support reading from HW only
+@@ -845,6 +850,10 @@ advk_pci_bridge_emul_base_conf_write(str
+               advk_writel(pcie, new, PCIE_CORE_CMD_STATUS_REG);
+               break;
++      case PCI_ROM_ADDRESS1:
++              advk_writel(pcie, new, PCIE_CORE_EXP_ROM_BAR_REG);
++              break;
++
+       case PCI_INTERRUPT_LINE:
+               if (mask & (PCI_BRIDGE_CTL_BUS_RESET << 16)) {
+                       u32 val = advk_readl(pcie, PCIE_CORE_CTRL1_REG);
diff --git a/queue-5.15/pci-aardvark-read-all-16-bits-from-pcie_msi_payload_reg.patch b/queue-5.15/pci-aardvark-read-all-16-bits-from-pcie_msi_payload_reg.patch
new file mode 100644 (file)
index 0000000..af461bd
--- /dev/null
@@ -0,0 +1,51 @@
+From 95997723b6402cd6c53e0f9e7ac640ec64eaaff8 Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Marek=20Beh=C3=BAn?= <kabel@kernel.org>
+Date: Thu, 28 Oct 2021 20:56:55 +0200
+Subject: PCI: aardvark: Read all 16-bits from PCIE_MSI_PAYLOAD_REG
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Marek Behún <kabel@kernel.org>
+
+commit 95997723b6402cd6c53e0f9e7ac640ec64eaaff8 upstream.
+
+The PCIE_MSI_PAYLOAD_REG contains 16-bit MSI number, not only lower
+8 bits. Fix reading content of this register and add a comment
+describing the access to this register.
+
+Link: https://lore.kernel.org/r/20211028185659.20329-4-kabel@kernel.org
+Fixes: 8c39d710363c ("PCI: aardvark: Add Aardvark PCI host controller driver")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Cc: stable@vger.kernel.org
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/pci-aardvark.c |    7 ++++++-
+ 1 file changed, 6 insertions(+), 1 deletion(-)
+
+--- a/drivers/pci/controller/pci-aardvark.c
++++ b/drivers/pci/controller/pci-aardvark.c
+@@ -119,6 +119,7 @@
+ #define PCIE_MSI_STATUS_REG                   (CONTROL_BASE_ADDR + 0x58)
+ #define PCIE_MSI_MASK_REG                     (CONTROL_BASE_ADDR + 0x5C)
+ #define PCIE_MSI_PAYLOAD_REG                  (CONTROL_BASE_ADDR + 0x9C)
++#define     PCIE_MSI_DATA_MASK                        GENMASK(15, 0)
+ /* PCIe window configuration */
+ #define OB_WIN_BASE_ADDR                      0x4c00
+@@ -1361,8 +1362,12 @@ static void advk_pcie_handle_msi(struct
+               if (!(BIT(msi_idx) & msi_status))
+                       continue;
++              /*
++               * msi_idx contains bits [4:0] of the msi_data and msi_data
++               * contains 16bit MSI interrupt number
++               */
+               advk_writel(pcie, BIT(msi_idx), PCIE_MSI_STATUS_REG);
+-              msi_data = advk_readl(pcie, PCIE_MSI_PAYLOAD_REG) & 0xFF;
++              msi_data = advk_readl(pcie, PCIE_MSI_PAYLOAD_REG) & PCIE_MSI_DATA_MASK;
+               generic_handle_irq(msi_data);
+       }
diff --git a/queue-5.15/pci-aardvark-set-pci-bridge-class-code-to-pci-bridge.patch b/queue-5.15/pci-aardvark-set-pci-bridge-class-code-to-pci-bridge.patch
new file mode 100644 (file)
index 0000000..fb58414
--- /dev/null
@@ -0,0 +1,64 @@
+From 84e1b4045dc887b78bdc87d92927093dc3a465aa Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Pali=20Roh=C3=A1r?= <pali@kernel.org>
+Date: Thu, 28 Oct 2021 20:56:57 +0200
+Subject: PCI: aardvark: Set PCI Bridge Class Code to PCI Bridge
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Pali Rohár <pali@kernel.org>
+
+commit 84e1b4045dc887b78bdc87d92927093dc3a465aa upstream.
+
+Aardvark controller has something like config space of a Root Port
+available at offset 0x0 of internal registers - these registers are used
+for implementation of the emulated bridge.
+
+The default value of Class Code of this bridge corresponds to a RAID Mass
+storage controller, though. (This is probably intended for when the
+controller is used as Endpoint.)
+
+Change the Class Code to correspond to a PCI Bridge.
+
+Add comment explaining this change.
+
+Link: https://lore.kernel.org/r/20211028185659.20329-6-kabel@kernel.org
+Fixes: 8a3ebd8de328 ("PCI: aardvark: Implement emulated root PCI bridge config space")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Cc: stable@vger.kernel.org
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/pci-aardvark.c |   20 ++++++++++++++++++++
+ 1 file changed, 20 insertions(+)
+
+--- a/drivers/pci/controller/pci-aardvark.c
++++ b/drivers/pci/controller/pci-aardvark.c
+@@ -560,6 +560,26 @@ static void advk_pcie_setup_hw(struct ad
+       reg = (PCI_VENDOR_ID_MARVELL << 16) | PCI_VENDOR_ID_MARVELL;
+       advk_writel(pcie, reg, VENDOR_ID_REG);
++      /*
++       * Change Class Code of PCI Bridge device to PCI Bridge (0x600400),
++       * because the default value is Mass storage controller (0x010400).
++       *
++       * Note that this Aardvark PCI Bridge does not have compliant Type 1
++       * Configuration Space and it even cannot be accessed via Aardvark's
++       * PCI config space access method. Something like config space is
++       * available in internal Aardvark registers starting at offset 0x0
++       * and is reported as Type 0. In range 0x10 - 0x34 it has totally
++       * different registers.
++       *
++       * Therefore driver uses emulation of PCI Bridge which emulates
++       * access to configuration space via internal Aardvark registers or
++       * emulated configuration buffer.
++       */
++      reg = advk_readl(pcie, PCIE_CORE_DEV_REV_REG);
++      reg &= ~0xffffff00;
++      reg |= (PCI_CLASS_BRIDGE_PCI << 8) << 8;
++      advk_writel(pcie, reg, PCIE_CORE_DEV_REV_REG);
++
+       /* Disable Root Bridge I/O space, memory space and bus mastering */
+       reg = advk_readl(pcie, PCIE_CORE_CMD_STATUS_REG);
+       reg &= ~(PCI_COMMAND_IO | PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER);
diff --git a/queue-5.15/pci-cadence-add-cdns_plat_pcie_probe-missing-return.patch b/queue-5.15/pci-cadence-add-cdns_plat_pcie_probe-missing-return.patch
new file mode 100644 (file)
index 0000000..062a74c
--- /dev/null
@@ -0,0 +1,35 @@
+From 27cd7e3c9bb1ae13bc16f08138edd6e4df3cd211 Mon Sep 17 00:00:00 2001
+From: Li Chen <lchen@ambarella.com>
+Date: Thu, 21 Oct 2021 02:50:19 +0000
+Subject: PCI: cadence: Add cdns_plat_pcie_probe() missing return
+
+From: Li Chen <lchen@ambarella.com>
+
+commit 27cd7e3c9bb1ae13bc16f08138edd6e4df3cd211 upstream.
+
+When cdns_plat_pcie_probe() succeeds, return success instead of falling
+into the error handling code.
+
+Fixes: bd22885aa188 ("PCI: cadence: Refactor driver to use as a core library")
+Link: https://lore.kernel.org/r/DM6PR19MB40271B93057D949310F0B0EDA0BF9@DM6PR19MB4027.namprd19.prod.outlook.com
+Signed-off-by: Xuliang Zhang <xlzhanga@ambarella.com>
+Signed-off-by: Li Chen <lchen@ambarella.com>
+Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
+Reviewed-by: Bjorn Helgaas <bhelgaas@google.com>
+Cc: stable@vger.kernel.org
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/controller/cadence/pcie-cadence-plat.c |    2 ++
+ 1 file changed, 2 insertions(+)
+
+--- a/drivers/pci/controller/cadence/pcie-cadence-plat.c
++++ b/drivers/pci/controller/cadence/pcie-cadence-plat.c
+@@ -127,6 +127,8 @@ static int cdns_plat_pcie_probe(struct p
+                       goto err_init;
+       }
++      return 0;
++
+  err_init:
+  err_get_sync:
+       pm_runtime_put_sync(dev);
diff --git a/queue-5.15/pci-pci-bridge-emul-fix-emulation-of-w1c-bits.patch b/queue-5.15/pci-pci-bridge-emul-fix-emulation-of-w1c-bits.patch
new file mode 100644 (file)
index 0000000..f534298
--- /dev/null
@@ -0,0 +1,62 @@
+From 7a41ae80bdcb17e14dd7d83239b8a0cf368f18be Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Marek=20Beh=C3=BAn?= <kabel@kernel.org>
+Date: Thu, 28 Oct 2021 20:56:53 +0200
+Subject: PCI: pci-bridge-emul: Fix emulation of W1C bits
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Marek Behún <kabel@kernel.org>
+
+commit 7a41ae80bdcb17e14dd7d83239b8a0cf368f18be upstream.
+
+The pci_bridge_emul_conf_write() function correctly clears W1C bits in
+cfgspace cache, but it does not inform the underlying implementation
+about the clear request: the .write_op() method is given the value with
+these bits cleared.
+
+This is wrong if the .write_op() needs to know which bits were requested
+to be cleared.
+
+Fix the value to be passed into the .write_op() method to have requested
+W1C bits set, so that it can clear them.
+
+Both pci-bridge-emul users (mvebu and aardvark) are compatible with this
+change.
+
+Link: https://lore.kernel.org/r/20211028185659.20329-2-kabel@kernel.org
+Fixes: 23a5fba4d941 ("PCI: Introduce PCI bridge emulated config space common logic")
+Signed-off-by: Pali Rohár <pali@kernel.org>
+Signed-off-by: Marek Behún <kabel@kernel.org>
+Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
+Cc: stable@vger.kernel.org
+Cc: Russell King <rmk+kernel@armlinux.org.uk>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ drivers/pci/pci-bridge-emul.c |   13 +++++++++++++
+ 1 file changed, 13 insertions(+)
+
+--- a/drivers/pci/pci-bridge-emul.c
++++ b/drivers/pci/pci-bridge-emul.c
+@@ -431,8 +431,21 @@ int pci_bridge_emul_conf_write(struct pc
+       /* Clear the W1C bits */
+       new &= ~((value << shift) & (behavior[reg / 4].w1c & mask));
++      /* Save the new value with the cleared W1C bits into the cfgspace */
+       cfgspace[reg / 4] = cpu_to_le32(new);
++      /*
++       * Clear the W1C bits not specified by the write mask, so that the
++       * write_op() does not clear them.
++       */
++      new &= ~(behavior[reg / 4].w1c & ~mask);
++
++      /*
++       * Set the W1C bits specified by the write mask, so that write_op()
++       * knows about that they are to be cleared.
++       */
++      new |= (value << shift) & (behavior[reg / 4].w1c & mask);
++
+       if (write_op)
+               write_op(bridge, reg, old, new, mask);
diff --git a/queue-5.15/quota-check-block-number-when-reading-the-block-in-quota-file.patch b/queue-5.15/quota-check-block-number-when-reading-the-block-in-quota-file.patch
new file mode 100644 (file)
index 0000000..d0d4054
--- /dev/null
@@ -0,0 +1,54 @@
+From 9bf3d20331295b1ecb81f4ed9ef358c51699a050 Mon Sep 17 00:00:00 2001
+From: Zhang Yi <yi.zhang@huawei.com>
+Date: Fri, 8 Oct 2021 17:38:20 +0800
+Subject: quota: check block number when reading the block in quota file
+
+From: Zhang Yi <yi.zhang@huawei.com>
+
+commit 9bf3d20331295b1ecb81f4ed9ef358c51699a050 upstream.
+
+The block number in the quota tree on disk should be smaller than the
+v2_disk_dqinfo.dqi_blocks. If the quota file was corrupted, we may be
+allocating an 'allocated' block and that would lead to a loop in a tree,
+which will probably trigger oops later. This patch adds a check for the
+block number in the quota tree to prevent such potential issue.
+
+Link: https://lore.kernel.org/r/20211008093821.1001186-2-yi.zhang@huawei.com
+Signed-off-by: Zhang Yi <yi.zhang@huawei.com>
+Cc: stable@kernel.org
+Signed-off-by: Jan Kara <jack@suse.cz>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ fs/quota/quota_tree.c |   14 ++++++++++++++
+ 1 file changed, 14 insertions(+)
+
+--- a/fs/quota/quota_tree.c
++++ b/fs/quota/quota_tree.c
+@@ -479,6 +479,13 @@ static int remove_tree(struct qtree_mem_
+               goto out_buf;
+       }
+       newblk = le32_to_cpu(ref[get_index(info, dquot->dq_id, depth)]);
++      if (newblk < QT_TREEOFF || newblk >= info->dqi_blocks) {
++              quota_error(dquot->dq_sb, "Getting block too big (%u >= %u)",
++                          newblk, info->dqi_blocks);
++              ret = -EUCLEAN;
++              goto out_buf;
++      }
++
+       if (depth == info->dqi_qtree_depth - 1) {
+               ret = free_dqentry(info, dquot, newblk);
+               newblk = 0;
+@@ -578,6 +585,13 @@ static loff_t find_tree_dqentry(struct q
+       blk = le32_to_cpu(ref[get_index(info, dquot->dq_id, depth)]);
+       if (!blk)       /* No reference? */
+               goto out_buf;
++      if (blk < QT_TREEOFF || blk >= info->dqi_blocks) {
++              quota_error(dquot->dq_sb, "Getting block too big (%u >= %u)",
++                          blk, info->dqi_blocks);
++              ret = -EUCLEAN;
++              goto out_buf;
++      }
++
+       if (depth < info->dqi_qtree_depth - 1)
+               ret = find_tree_dqentry(info, dquot, blk, depth+1);
+       else
diff --git a/queue-5.15/quota-correct-error-number-in-free_dqentry.patch b/queue-5.15/quota-correct-error-number-in-free_dqentry.patch
new file mode 100644 (file)
index 0000000..a131cb5
--- /dev/null
@@ -0,0 +1,32 @@
+From d0e36a62bd4c60c09acc40e06ba4831a4d0bc75b Mon Sep 17 00:00:00 2001
+From: Zhang Yi <yi.zhang@huawei.com>
+Date: Fri, 8 Oct 2021 17:38:21 +0800
+Subject: quota: correct error number in free_dqentry()
+
+From: Zhang Yi <yi.zhang@huawei.com>
+
+commit d0e36a62bd4c60c09acc40e06ba4831a4d0bc75b upstream.
+
+Fix the error path in free_dqentry(), pass out the error number if the
+block to free is not correct.
+
+Fixes: 1ccd14b9c271 ("quota: Split off quota tree handling into a separate file")
+Link: https://lore.kernel.org/r/20211008093821.1001186-3-yi.zhang@huawei.com
+Signed-off-by: Zhang Yi <yi.zhang@huawei.com>
+Cc: stable@kernel.org
+Signed-off-by: Jan Kara <jack@suse.cz>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ fs/quota/quota_tree.c |    1 +
+ 1 file changed, 1 insertion(+)
+
+--- a/fs/quota/quota_tree.c
++++ b/fs/quota/quota_tree.c
+@@ -414,6 +414,7 @@ static int free_dqentry(struct qtree_mem
+               quota_error(dquot->dq_sb, "Quota structure has offset to "
+                       "other block (%u) than it should (%u)", blk,
+                       (uint)(dquot->dq_off >> info->dqi_blocksize_bits));
++              ret = -EIO;
+               goto out_buf;
+       }
+       ret = read_blk(info, blk, buf);
index 739413331f7707ec2de42f0edd5c4e4c88d3dea6..80c277ac502008a389add254a2a5166b7e43df12 100644 (file)
@@ -134,3 +134,24 @@ io_uring-honour-zeroes-as-io-wq-worker-limits.patch
 ring-buffer-protect-ring_buffer_reset-from-reentrancy.patch
 serial-core-fix-initializing-and-restoring-termios-speed.patch
 ifb-fix-building-without-config_net_cls_act.patch
+xen-balloon-add-late_initcall_sync-for-initial-ballooning-done.patch
+ovl-fix-use-after-free-in-struct-ovl_aio_req.patch
+ovl-fix-filattr-copy-up-failure.patch
+pci-pci-bridge-emul-fix-emulation-of-w1c-bits.patch
+pci-cadence-add-cdns_plat_pcie_probe-missing-return.patch
+cxl-pci-fix-null-vs-err_ptr-confusion.patch
+pci-aardvark-do-not-clear-status-bits-of-masked-interrupts.patch
+pci-aardvark-fix-checking-for-link-up-via-ltssm-state.patch
+pci-aardvark-do-not-unmask-unused-interrupts.patch
+pci-aardvark-fix-reporting-data-link-layer-link-active.patch
+pci-aardvark-fix-configuring-reference-clock.patch
+pci-aardvark-fix-return-value-of-msi-domain-.alloc-method.patch
+pci-aardvark-read-all-16-bits-from-pcie_msi_payload_reg.patch
+pci-aardvark-fix-support-for-bus-mastering-and-pci_command-on-emulated-bridge.patch
+pci-aardvark-fix-support-for-pci_bridge_ctl_bus_reset-on-emulated-bridge.patch
+pci-aardvark-set-pci-bridge-class-code-to-pci-bridge.patch
+pci-aardvark-fix-support-for-pci_rom_address1-on-emulated-bridge.patch
+quota-check-block-number-when-reading-the-block-in-quota-file.patch
+quota-correct-error-number-in-free_dqentry.patch
+cifs-to-match-file-servers-make-sure-the-server-hostname-matches.patch
+cifs-set-a-minimum-of-120s-for-next-dns-resolution.patch
diff --git a/queue-5.15/xen-balloon-add-late_initcall_sync-for-initial-ballooning-done.patch b/queue-5.15/xen-balloon-add-late_initcall_sync-for-initial-ballooning-done.patch
new file mode 100644 (file)
index 0000000..03ef580
--- /dev/null
@@ -0,0 +1,245 @@
+From 40fdea0284bb20814399da0484a658a96c735d90 Mon Sep 17 00:00:00 2001
+From: Juergen Gross <jgross@suse.com>
+Date: Tue, 2 Nov 2021 10:19:44 +0100
+Subject: xen/balloon: add late_initcall_sync() for initial ballooning done
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+From: Juergen Gross <jgross@suse.com>
+
+commit 40fdea0284bb20814399da0484a658a96c735d90 upstream.
+
+When running as PVH or HVM guest with actual memory < max memory the
+hypervisor is using "populate on demand" in order to allow the guest
+to balloon down from its maximum memory size. For this to work
+correctly the guest must not touch more memory pages than its target
+memory size as otherwise the PoD cache will be exhausted and the guest
+is crashed as a result of that.
+
+In extreme cases ballooning down might not be finished today before
+the init process is started, which can consume lots of memory.
+
+In order to avoid random boot crashes in such cases, add a late init
+call to wait for ballooning down having finished for PVH/HVM guests.
+
+Warn on console if initial ballooning fails, panic() after stalling
+for more than 3 minutes per default. Add a module parameter for
+changing this timeout.
+
+[boris: replaced pr_info() with pr_notice()]
+
+Cc: <stable@vger.kernel.org>
+Reported-by: Marek Marczykowski-Górecki <marmarek@invisiblethingslab.com>
+Signed-off-by: Juergen Gross <jgross@suse.com>
+Link: https://lore.kernel.org/r/20211102091944.17487-1-jgross@suse.com
+Reviewed-by: Boris Ostrovsky <boris.ostrovsky@oracle.com>
+Signed-off-by: Boris Ostrovsky <boris.ostrovsky@oracle.com>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ Documentation/admin-guide/kernel-parameters.txt |    7 +
+ drivers/xen/balloon.c                           |   86 +++++++++++++++++-------
+ 2 files changed, 70 insertions(+), 23 deletions(-)
+
+--- a/Documentation/admin-guide/kernel-parameters.txt
++++ b/Documentation/admin-guide/kernel-parameters.txt
+@@ -6349,6 +6349,13 @@
+                       improve timer resolution at the expense of processing
+                       more timer interrupts.
++      xen.balloon_boot_timeout= [XEN]
++                      The time (in seconds) to wait before giving up to boot
++                      in case initial ballooning fails to free enough memory.
++                      Applies only when running as HVM or PVH guest and
++                      started with less memory configured than allowed at
++                      max. Default is 180.
++
+       xen.event_eoi_delay=    [XEN]
+                       How long to delay EOI handling in case of event
+                       storms (jiffies). Default is 10.
+--- a/drivers/xen/balloon.c
++++ b/drivers/xen/balloon.c
+@@ -58,6 +58,7 @@
+ #include <linux/percpu-defs.h>
+ #include <linux/slab.h>
+ #include <linux/sysctl.h>
++#include <linux/moduleparam.h>
+ #include <asm/page.h>
+ #include <asm/tlb.h>
+@@ -73,6 +74,12 @@
+ #include <xen/page.h>
+ #include <xen/mem-reservation.h>
++#undef MODULE_PARAM_PREFIX
++#define MODULE_PARAM_PREFIX "xen."
++
++static uint __read_mostly balloon_boot_timeout = 180;
++module_param(balloon_boot_timeout, uint, 0444);
++
+ static int xen_hotplug_unpopulated;
+ #ifdef CONFIG_XEN_BALLOON_MEMORY_HOTPLUG
+@@ -125,12 +132,12 @@ static struct ctl_table xen_root[] = {
+  * BP_ECANCELED: error, balloon operation canceled.
+  */
+-enum bp_state {
++static enum bp_state {
+       BP_DONE,
+       BP_WAIT,
+       BP_EAGAIN,
+       BP_ECANCELED
+-};
++} balloon_state = BP_DONE;
+ /* Main waiting point for xen-balloon thread. */
+ static DECLARE_WAIT_QUEUE_HEAD(balloon_thread_wq);
+@@ -199,18 +206,15 @@ static struct page *balloon_next_page(st
+       return list_entry(next, struct page, lru);
+ }
+-static enum bp_state update_schedule(enum bp_state state)
++static void update_schedule(void)
+ {
+-      if (state == BP_WAIT)
+-              return BP_WAIT;
+-
+-      if (state == BP_ECANCELED)
+-              return BP_ECANCELED;
++      if (balloon_state == BP_WAIT || balloon_state == BP_ECANCELED)
++              return;
+-      if (state == BP_DONE) {
++      if (balloon_state == BP_DONE) {
+               balloon_stats.schedule_delay = 1;
+               balloon_stats.retry_count = 1;
+-              return BP_DONE;
++              return;
+       }
+       ++balloon_stats.retry_count;
+@@ -219,7 +223,8 @@ static enum bp_state update_schedule(enu
+                       balloon_stats.retry_count > balloon_stats.max_retry_count) {
+               balloon_stats.schedule_delay = 1;
+               balloon_stats.retry_count = 1;
+-              return BP_ECANCELED;
++              balloon_state = BP_ECANCELED;
++              return;
+       }
+       balloon_stats.schedule_delay <<= 1;
+@@ -227,7 +232,7 @@ static enum bp_state update_schedule(enu
+       if (balloon_stats.schedule_delay > balloon_stats.max_schedule_delay)
+               balloon_stats.schedule_delay = balloon_stats.max_schedule_delay;
+-      return BP_EAGAIN;
++      balloon_state = BP_EAGAIN;
+ }
+ #ifdef CONFIG_XEN_BALLOON_MEMORY_HOTPLUG
+@@ -494,9 +499,9 @@ static enum bp_state decrease_reservatio
+  * Stop waiting if either state is BP_DONE and ballooning action is
+  * needed, or if the credit has changed while state is not BP_DONE.
+  */
+-static bool balloon_thread_cond(enum bp_state state, long credit)
++static bool balloon_thread_cond(long credit)
+ {
+-      if (state == BP_DONE)
++      if (balloon_state == BP_DONE)
+               credit = 0;
+       return current_credit() != credit || kthread_should_stop();
+@@ -510,13 +515,12 @@ static bool balloon_thread_cond(enum bp_
+  */
+ static int balloon_thread(void *unused)
+ {
+-      enum bp_state state = BP_DONE;
+       long credit;
+       unsigned long timeout;
+       set_freezable();
+       for (;;) {
+-              switch (state) {
++              switch (balloon_state) {
+               case BP_DONE:
+               case BP_ECANCELED:
+                       timeout = 3600 * HZ;
+@@ -532,7 +536,7 @@ static int balloon_thread(void *unused)
+               credit = current_credit();
+               wait_event_freezable_timeout(balloon_thread_wq,
+-                      balloon_thread_cond(state, credit), timeout);
++                      balloon_thread_cond(credit), timeout);
+               if (kthread_should_stop())
+                       return 0;
+@@ -543,22 +547,23 @@ static int balloon_thread(void *unused)
+               if (credit > 0) {
+                       if (balloon_is_inflated())
+-                              state = increase_reservation(credit);
++                              balloon_state = increase_reservation(credit);
+                       else
+-                              state = reserve_additional_memory();
++                              balloon_state = reserve_additional_memory();
+               }
+               if (credit < 0) {
+                       long n_pages;
+                       n_pages = min(-credit, si_mem_available());
+-                      state = decrease_reservation(n_pages, GFP_BALLOON);
+-                      if (state == BP_DONE && n_pages != -credit &&
++                      balloon_state = decrease_reservation(n_pages,
++                                                           GFP_BALLOON);
++                      if (balloon_state == BP_DONE && n_pages != -credit &&
+                           n_pages < totalreserve_pages)
+-                              state = BP_EAGAIN;
++                              balloon_state = BP_EAGAIN;
+               }
+-              state = update_schedule(state);
++              update_schedule();
+               mutex_unlock(&balloon_mutex);
+@@ -765,3 +770,38 @@ static int __init balloon_init(void)
+       return 0;
+ }
+ subsys_initcall(balloon_init);
++
++static int __init balloon_wait_finish(void)
++{
++      long credit, last_credit = 0;
++      unsigned long last_changed = 0;
++
++      if (!xen_domain())
++              return -ENODEV;
++
++      /* PV guests don't need to wait. */
++      if (xen_pv_domain() || !current_credit())
++              return 0;
++
++      pr_notice("Waiting for initial ballooning down having finished.\n");
++
++      while ((credit = current_credit()) < 0) {
++              if (credit != last_credit) {
++                      last_changed = jiffies;
++                      last_credit = credit;
++              }
++              if (balloon_state == BP_ECANCELED) {
++                      pr_warn_once("Initial ballooning failed, %ld pages need to be freed.\n",
++                                   -credit);
++                      if (jiffies - last_changed >= HZ * balloon_boot_timeout)
++                              panic("Initial ballooning failed!\n");
++              }
++
++              schedule_timeout_interruptible(HZ / 10);
++      }
++
++      pr_notice("Initial ballooning down finished.\n");
++
++      return 0;
++}
++late_initcall_sync(balloon_wait_finish);