aboutsummaryrefslogtreecommitdiffstats
path: root/roms/skiboot/hdata/hdata.h
diff options
context:
space:
mode:
authorAngelos Mouzakitis <a.mouzakitis@virtualopensystems.com>2023-10-10 14:33:42 +0000
committerAngelos Mouzakitis <a.mouzakitis@virtualopensystems.com>2023-10-10 14:33:42 +0000
commitaf1a266670d040d2f4083ff309d732d648afba2a (patch)
tree2fc46203448ddcc6f81546d379abfaeb323575e9 /roms/skiboot/hdata/hdata.h
parente02cda008591317b1625707ff8e115a4841aa889 (diff)
Add submodule dependency filesHEADmaster
Change-Id: Iaf8d18082d3991dec7c0ebbea540f092188eb4ec
Diffstat (limited to 'roms/skiboot/hdata/hdata.h')
-rw-r--r--roms/skiboot/hdata/hdata.h55
1 files changed, 55 insertions, 0 deletions
diff --git a/roms/skiboot/hdata/hdata.h b/roms/skiboot/hdata/hdata.h
new file mode 100644
index 000000000..6aad82932
--- /dev/null
+++ b/roms/skiboot/hdata/hdata.h
@@ -0,0 +1,55 @@
+// SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
+/* Copyright 2013-2018 IBM Corp. */
+
+#ifndef __HDATA_H
+#define __HDATA_H
+
+#include <processor.h>
+#include "hdif.h"
+#include "spira.h"
+
+struct dt_node;
+
+extern void memory_parse(void);
+extern bool pcia_parse(void);
+extern void fsp_parse(void);
+extern void bmc_parse(void);
+extern void io_parse(void);
+extern void dt_init_vpd_node(void);
+extern struct dt_node *dt_add_vpd_node(const struct HDIF_common_hdr *hdr,
+ int indx_fru, int indx_vpd);
+extern void vpd_parse(void);
+extern void vpd_data_parse(struct dt_node *node,
+ const void *fruvpd, u32 fruvpd_sz);
+
+extern struct dt_node *find_xscom_for_chip(uint32_t chip_id);
+extern uint32_t pcid_to_chip_id(uint32_t proc_chip_id);
+extern uint32_t pcid_to_topology_idx(uint32_t proc_chip_id);
+extern uint32_t get_xscom_id(const struct sppcrd_chip_info *cinfo);
+
+extern struct dt_node *add_core_common(struct dt_node *cpus,
+ const struct sppcia_cpu_cache *cache,
+ const struct sppcia_cpu_timebase *tb,
+ uint32_t int_server, bool okay);
+extern void add_core_attr(struct dt_node *cpu, uint32_t attr);
+extern uint32_t add_core_cache_info(struct dt_node *cpus,
+ const struct sppcia_cpu_cache *cache,
+ uint32_t int_server, int okay);
+extern const struct slca_entry *slca_get_entry(uint16_t slca_index);
+extern const char *slca_get_vpd_name(uint16_t slca_index);
+extern const char *slca_get_loc_code_index(uint16_t slca_index);
+extern void slca_vpd_add_loc_code(struct dt_node *node, uint16_t slca_index);
+extern void slca_dt_add_sai_node(void);
+extern void dt_add_proc_vendor(struct dt_node *proc_node,
+ const void *mvpd, unsigned int mvpd_sz);
+
+extern bool hservices_from_hdat(const void *fdt, size_t size);
+int parse_i2c_devs(const struct HDIF_common_hdr *hdr, int idata_index,
+ struct dt_node *xscom);
+extern void node_stb_parse(void);
+
+/* used to look up the device-tree node representing a slot */
+struct dt_node *find_slot_entry_node(struct dt_node *root, u32 entry_id);
+
+#endif /* __HDATA_H */
+