component_reg_phys);
 }
 
+static inline int cxl_dport_setup_regs(struct cxl_dport *dport,
+                                      resource_size_t component_reg_phys)
+{
+       return cxl_setup_comp_regs(dport->dport_dev, &dport->comp_map,
+                                  component_reg_phys);
+}
+
 static struct cxl_port *__devm_cxl_add_port(struct device *host,
                                            struct device *uport_dev,
                                            resource_size_t component_reg_phys,
        dport->port_id = port_id;
        dport->port = port;
 
+       rc = cxl_dport_setup_regs(dport, component_reg_phys);
+       if (rc)
+               return ERR_PTR(rc);
+
        cond_cxl_root_lock(port);
        rc = add_dport(port, dport);
        cond_cxl_root_unlock(port);
 
 /**
  * struct cxl_dport - CXL downstream port
  * @dport_dev: PCI bridge or firmware device representing the downstream link
+ * @comp_map: component register capability mappings
  * @port_id: unique hardware identifier for dport in decoder target list
  * @rcrb: Data about the Root Complex Register Block layout
  * @rch: Indicate whether this dport was enumerated in RCH or VH mode
  */
 struct cxl_dport {
        struct device *dport_dev;
+       struct cxl_register_map comp_map;
        int port_id;
        struct cxl_rcrb_info rcrb;
        bool rch;