blob: 7783fe20c9832bf90d0095c5bc8d6a5f048e9a60 [file] [log] [blame]
// SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
/* Copyright 2013-2019 IBM Corp. */
#ifndef __ASTBMC_H
#define __ASTBMC_H
#include <platform.h>
#define ST_LOC_PHB(chip_id, phb_idx) ((chip_id) << 16 | (phb_idx))
#define ST_LOC_DEVFN(dev, fn) ((dev) << 3 | (fn))
/*
* NPU groups are used to allocate device numbers. There is a 1 to 1
* correlation between a NPU group and a physical GPU. Links within a group
* are allocated as functions within a device, so groups must be numbered
* sequentially starting at 0.
*/
#define ST_LOC_NPU_GROUP(group_id) (group_id << 3)
struct slot_table_entry {
enum slot_table_etype {
st_end, /* End of list */
st_phb,
st_pluggable_slot,
st_builtin_dev,
st_npu_slot
} etype;
uint32_t location;
const char *name;
const struct slot_table_entry *children;
uint8_t power_limit;
};
/*
* Helper to reduce the noise in the PHB table
*/
#define ST_PHB_ENTRY(chip_id, phb_id, child_table) \
{ \
.etype = st_phb, \
.location = ST_LOC_PHB(chip_id, phb_id), \
.children = child_table \
}
/*
* For the most part the "table" isn't really a table and only contains
* a single real entry and the etype = st_end terminator. In these cases
* we can use these helpers. If you need something special in the slot
* table for each slot (e.g. power limit, devfn != 0) then you need to
* define the actual structure.
*/
#define ST_BUILTIN_DEV(st_name, slot_name, ...) \
static struct slot_table_entry st_name[] = \
{ \
{ \
.etype = st_pluggable_slot, \
.name = slot_name, \
##__VA_ARGS__ \
}, \
{ .etype = st_end }, \
}
#define ST_PLUGGABLE(st_name, slot_name, ...) \
static struct slot_table_entry st_name[] = \
{ \
{ \
.etype = st_pluggable_slot, \
.name = slot_name, \
##__VA_ARGS__ \
}, \
{ .etype = st_end }, \
}
#define SW_PLUGGABLE(slot_name, port, ...) \
{ \
.etype = st_pluggable_slot, \
.name = slot_name, \
.location = ST_LOC_DEVFN(port, 0), \
##__VA_ARGS__ \
}
#define SW_BUILTIN(slot_name, port, ...) \
{ \
.etype = st_builtin_dev, \
.name = slot_name, \
.location = ST_LOC_DEVFN(port, 0), \
##__VA_ARGS__ \
}
extern const struct bmc_hw_config bmc_hw_ast2400;
extern const struct bmc_hw_config bmc_hw_ast2500;
extern const struct bmc_hw_config bmc_hw_ast2600;
extern const struct bmc_platform bmc_plat_ast2400_ami;
extern const struct bmc_platform bmc_plat_ast2500_ami;
extern const struct bmc_platform bmc_plat_ast2500_openbmc;
extern const struct bmc_platform bmc_plat_ast2600_openbmc;
extern void astbmc_early_init(void);
extern int64_t astbmc_ipmi_reboot(void);
extern int64_t astbmc_ipmi_power_down(uint64_t request);
#ifdef CONFIG_PLDM
extern int astbmc_pldm_init(void);
extern int pnor_pldm_init(void);
#endif
extern void astbmc_init(void);
extern void astbmc_ext_irq_serirq_cpld(unsigned int chip_id);
extern int pnor_init(void);
extern void check_all_slot_table(void);
extern void astbmc_exit(void);
extern void astbmc_seeprom_update(void);
extern void slot_table_init(const struct slot_table_entry *top_table);
extern void slot_table_get_slot_info(struct phb *phb, struct pci_device * pd);
void slot_table_add_slot_info(struct pci_device *pd,
const struct slot_table_entry *ent);
void dt_slot_get_slot_info(struct phb *phb, struct pci_device *pd);
#endif /* __ASTBMC_H */