u16             vfn;            /* virtual function number */
        u16             pchid;          /* physical channel ID */
        u16             maxstbl;        /* Maximum store block size */
+       u16             rid;            /* RID as supplied by firmware */
        u8              pfgid;          /* function group ID */
        u8              pft;            /* pci function type */
        u8              port;
 ----------------------------------------------------------------------------- */
 /* Base stuff */
 struct zpci_dev *zpci_create_device(u32 fid, u32 fh, enum zpci_state state);
+int zpci_add_device(struct zpci_dev *zdev);
 int zpci_enable_device(struct zpci_dev *);
 int zpci_disable_device(struct zpci_dev *);
 int zpci_scan_configured_device(struct zpci_dev *zdev, u32 fh);
 int zpci_deconfigure_device(struct zpci_dev *zdev);
 void zpci_device_reserved(struct zpci_dev *zdev);
 bool zpci_is_device_configured(struct zpci_dev *zdev);
+int zpci_scan_devices(void);
 
 int zpci_hot_reset_device(struct zpci_dev *zdev);
 int zpci_register_ioat(struct zpci_dev *, u8, u64, u64, u64, u8 *);
 
 /* CLP */
 int clp_setup_writeback_mio(void);
-int clp_scan_pci_devices(void);
+int clp_scan_pci_devices(struct list_head *scan_list);
 int clp_query_pci_fn(struct zpci_dev *zdev);
 int clp_enable_fh(struct zpci_dev *zdev, u32 *fh, u8 nr_dma_as);
 int clp_disable_fh(struct zpci_dev *zdev, u32 *fh);
 
 #include <linux/pci.h>
 #include <linux/printk.h>
 #include <linux/lockdep.h>
+#include <linux/list_sort.h>
 
 #include <asm/isc.h>
 #include <asm/airq.h>
        struct zpci_dev *zdev;
        int rc;
 
-       zpci_dbg(1, "add fid:%x, fh:%x, c:%d\n", fid, fh, state);
        zdev = kzalloc(sizeof(*zdev), GFP_KERNEL);
        if (!zdev)
                return ERR_PTR(-ENOMEM);
        mutex_init(&zdev->fmb_lock);
        mutex_init(&zdev->kzdev_lock);
 
+       return zdev;
+
+error:
+       zpci_dbg(0, "crt fid:%x, rc:%d\n", fid, rc);
+       kfree(zdev);
+       return ERR_PTR(rc);
+}
+
+int zpci_add_device(struct zpci_dev *zdev)
+{
+       int rc;
+
+       zpci_dbg(1, "add fid:%x, fh:%x, c:%d\n", zdev->fid, zdev->fh, zdev->state);
        rc = zpci_init_iommu(zdev);
        if (rc)
                goto error;
        spin_lock(&zpci_list_lock);
        list_add_tail(&zdev->entry, &zpci_list);
        spin_unlock(&zpci_list_lock);
-
-       return zdev;
+       return 0;
 
 error_destroy_iommu:
        zpci_destroy_iommu(zdev);
 error:
-       zpci_dbg(0, "add fid:%x, rc:%d\n", fid, rc);
-       kfree(zdev);
-       return ERR_PTR(rc);
+       zpci_dbg(0, "add fid:%x, rc:%d\n", zdev->fid, rc);
+       return rc;
 }
 
 bool zpci_is_device_configured(struct zpci_dev *zdev)
        return s390_pci_initialized;
 }
 
+static int zpci_cmp_rid(void *priv, const struct list_head *a,
+                       const struct list_head *b)
+{
+       struct zpci_dev *za = container_of(a, struct zpci_dev, entry);
+       struct zpci_dev *zb = container_of(b, struct zpci_dev, entry);
+
+       /*
+        * PCI functions without RID available maintain original order
+        * between themselves but sort before those with RID.
+        */
+       if (za->rid == zb->rid)
+               return za->rid_available > zb->rid_available;
+       /*
+        * PCI functions with RID sort by RID ascending.
+        */
+       return za->rid > zb->rid;
+}
+
+static void zpci_add_devices(struct list_head *scan_list)
+{
+       struct zpci_dev *zdev, *tmp;
+
+       list_sort(NULL, scan_list, &zpci_cmp_rid);
+       list_for_each_entry_safe(zdev, tmp, scan_list, entry) {
+               list_del_init(&zdev->entry);
+               zpci_add_device(zdev);
+       }
+}
+
+int zpci_scan_devices(void)
+{
+       LIST_HEAD(scan_list);
+       int rc;
+
+       rc = clp_scan_pci_devices(&scan_list);
+       if (rc)
+               return rc;
+
+       zpci_add_devices(&scan_list);
+       zpci_bus_scan_busses();
+       return 0;
+}
+
 static int __init pci_base_init(void)
 {
        int rc;
        if (rc)
                goto out_irq;
 
-       rc = clp_scan_pci_devices();
+       rc = zpci_scan_devices();
        if (rc)
                goto out_find;
-       zpci_bus_scan_busses();
 
        s390_pci_initialized = 1;
        return 0;
 
        zdev->port = response->port;
        zdev->uid = response->uid;
        zdev->fmb_length = sizeof(u32) * response->fmb_len;
-       zdev->rid_available = response->rid_avail;
        zdev->is_physfn = response->is_physfn;
+       zdev->rid_available = response->rid_avail;
+       if (zdev->rid_available)
+               zdev->rid = response->rid;
        if (!s390_pci_no_rid && zdev->rid_available)
                zdev->devfn = response->rid & ZPCI_RID_MASK_DEVFN;
 
 
 static void __clp_add(struct clp_fh_list_entry *entry, void *data)
 {
+       struct list_head *scan_list = data;
        struct zpci_dev *zdev;
 
        if (!entry->vendor_id)
                zpci_zdev_put(zdev);
                return;
        }
-       zpci_create_device(entry->fid, entry->fh, entry->config_state);
+       zdev = zpci_create_device(entry->fid, entry->fh, entry->config_state);
+       list_add_tail(&zdev->entry, scan_list);
 }
 
-int clp_scan_pci_devices(void)
+int clp_scan_pci_devices(struct list_head *scan_list)
 {
        struct clp_req_rsp_list_pci *rrb;
        int rc;
        if (!rrb)
                return -ENOMEM;
 
-       rc = clp_list_pci(rrb, NULL, __clp_add);
+       rc = clp_list_pci(rrb, scan_list, __clp_add);
 
        clp_free_block(rrb);
        return rc;
 
                        zdev = zpci_create_device(ccdf->fid, ccdf->fh, ZPCI_FN_STATE_CONFIGURED);
                        if (IS_ERR(zdev))
                                break;
+                       zpci_add_device(zdev);
                } else {
                        /* the configuration request may be stale */
                        if (zdev->state != ZPCI_FN_STATE_STANDBY)
                zpci_scan_configured_device(zdev, ccdf->fh);
                break;
        case 0x0302: /* Reserved -> Standby */
-               if (!zdev)
-                       zpci_create_device(ccdf->fid, ccdf->fh, ZPCI_FN_STATE_STANDBY);
-               else
+               if (!zdev) {
+                       zdev = zpci_create_device(ccdf->fid, ccdf->fh, ZPCI_FN_STATE_STANDBY);
+                       if (IS_ERR(zdev))
+                               break;
+                       zpci_add_device(zdev);
+               } else {
                        zpci_update_fh(zdev, ccdf->fh);
+               }
                break;
        case 0x0303: /* Deconfiguration requested */
                if (zdev) {
                break;
        case 0x0306: /* 0x308 or 0x302 for multiple devices */
                zpci_remove_reserved_devices();
-               clp_scan_pci_devices();
+               zpci_scan_devices();
                break;
        case 0x0308: /* Standby -> Reserved */
                if (!zdev)