@@ -5842,9 +5842,15 @@ static void phb4_probe_stack(struct dt_node *stk_node, uint32_t pec_index,
dt_add_property_cells(np, "ibm,phb-stack", stk_node->phandle);
dt_add_property_cells(np, "ibm,phb-stack-index", stk_index);
dt_add_property_cells(np, "ibm,chip-id", gcid);
- if (dt_has_node_property(stk_node, "ibm,hub-id", NULL))
- dt_add_property_cells(np, "ibm,hub-id",
- dt_prop_get_u32(stk_node, "ibm,hub-id"));
+
+ /* read the hub-id out of the pbcq node */
+ if (dt_has_node_property(stk_node->parent, "ibm,hub-id", NULL)) {
+ uint32_t hub_id;
+
+ hub_id = dt_prop_get_u32(stk_node->parent, "ibm,hub-id");
+ dt_add_property_cells(np, "ibm,hub-id", hub_id);
+ }
+
if (dt_has_node_property(stk_node, "ibm,loc-code", NULL)) {
const char *lc = dt_prop_get(stk_node, "ibm,loc-code");
dt_add_property_string(np, "ibm,loc-code", lc);
The hub-id is stored in the PBCQ node rather than the stack node so we never add it to the PHB node. This breaks the lxvpd slot lookup code since the hub-id is encoded in the VPD record that we need to find the slot information. Signed-off-by: Oliver O'Halloran <oohall@gmail.com> --- hw/phb4.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-)