7#ifndef INCLUDE_TENSTORRENT_LIB_BH_CHIP_H_
8#define INCLUDE_TENSTORRENT_LIB_BH_CHIP_H_
113#define DT_PHANDLE_OR_CHILD(node_id, name) \
114 COND_CODE_1(DT_NODE_HAS_PROP(node_id, name), (DT_PHANDLE(node_id, name)), \
115 (DT_CHILD(node_id, name)))
117#define HAS_DT_PHANDLE_OR_CHILD(node_id, name) DT_NODE_EXISTS(DT_PHANDLE_OR_CHILD(node_id, name))
118#define BH_CHIP_COUNT DT_PROP_LEN_OR(DT_PATH(chips), chips, 0)
121#define MAKE_STRUCT_FIELD(n) .n
123#define INIT_STRAP(n) MAKE_STRUCT_FIELD(DT_NODE_FULL_NAME_TOKEN(n)) = GPIO_DT_SPEC_GET(n, gpios),
125#define INIT_CHIP(n, prop, idx) \
128 .asic_reset = GPIO_DT_SPEC_GET( \
129 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), asic_reset), \
131 .spi_reset = GPIO_DT_SPEC_GET( \
132 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), spi_reset), \
134 .flash = DEVICE_DT_GET_OR_NULL( \
135 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), flash)), \
136 .jtag = DEVICE_DT_GET( \
137 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), jtag)), \
138 .arc = BH_ARC_INIT( \
139 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), arc)), \
140 .spi_mux = GPIO_DT_SPEC_GET( \
141 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), spi_mux), \
143 .pgood = GPIO_DT_SPEC_GET( \
144 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), pgood), \
146 .therm_trip = GPIO_DT_SPEC_GET( \
147 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), therm_trip), \
149 .strapping = {COND_CODE_1( \
150 HAS_DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), strapping), \
151 (DT_FOREACH_CHILD(DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), strapping), \
155 .auto_reset_timer = Z_TIMER_INITIALIZER( \
156 BH_CHIPS[idx].auto_reset_timer, \
157 bh_chip_auto_reset, NULL), \
160#define BH_CHIP_PRIMARY_INDEX DT_PROP(DT_PATH(chips), primary)
#define BH_CHIP_COUNT
Definition bh_chip.h:118
int bh_chip_write_logs(struct bh_chip *chip, char *log_data, size_t log_size)
Definition bh_chip.c:138
int bh_chip_set_fan_rpm(struct bh_chip *chip, uint16_t rpm)
Definition bh_chip.c:109
int jtag_bootrom_reset_sequence(struct bh_chip *chip, bool force_reset, uint16_t cable_power_limit)
Definition reset.c:32
void bh_chip_assert_asic_reset(const struct bh_chip *chip)
Definition bh_chip.c:152
void bh_chip_unset_straps(struct bh_chip *chip)
Definition strapping.c:47
int bh_chip_set_input_power(struct bh_chip *chip, uint16_t power)
Definition bh_chip.c:91
int therm_trip_gpio_setup(struct bh_chip *chip)
Definition bh_chip.c:201
void bh_chip_cancel_bus_transfer_clear(struct bh_chip *chip)
Definition bh_chip.c:26
int bh_chip_set_input_power_lim(struct bh_chip *chip, uint16_t max_power)
Definition bh_chip.c:100
void bh_chip_auto_reset(struct k_timer *timer)
Definition bh_chip.c:128
void bh_chip_assert_spi_reset(const struct bh_chip *chip)
Definition bh_chip.c:162
int bh_chip_set_static_info(struct bh_chip *chip, dmStaticInfo *info)
Definition bh_chip.c:78
int bh_chip_set_therm_trip_count(struct bh_chip *chip, uint16_t therm_trip_count)
Definition bh_chip.c:118
int bh_chip_reset_chip(struct bh_chip *chip, bool force_reset)
Definition bh_chip.c:172
void bh_chip_set_straps(struct bh_chip *chip)
Definition strapping.c:12
void bh_chip_cancel_bus_transfer_set(struct bh_chip *chip)
Definition bh_chip.c:21
struct bh_chip BH_CHIPS[DT_PROP_LEN_OR(DT_PATH(chips), chips, 0)]
void handle_pgood_event(struct bh_chip *chip, struct gpio_dt_spec board_fault_led)
Definition bh_chip.c:264
cm2dmMessageRet bh_chip_get_cm2dm_message(struct bh_chip *chip)
Definition bh_chip.c:31
void bh_chip_deassert_asic_reset(const struct bh_chip *chip)
Definition bh_chip.c:157
void bh_chip_deassert_spi_reset(const struct bh_chip *chip)
Definition bh_chip.c:167
int pgood_gpio_setup(struct bh_chip *chip)
Definition bh_chip.c:240
static uint16_t power
Definition cm2dm_msg.c:46
struct bh_arc arc
Definition bh_chip.h:38
struct gpio_dt_spec asic_reset
Definition bh_chip.h:28
const struct device * jtag
Definition bh_chip.h:34
const struct device * flash
Definition bh_chip.h:33
struct gpio_dt_spec spi_mux
Definition bh_chip.h:30
struct gpio_dt_spec spi_reset
Definition bh_chip.h:29
const struct bh_straps strapping
Definition bh_chip.h:36
struct gpio_dt_spec therm_trip
Definition bh_chip.h:32
struct gpio_dt_spec pgood
Definition bh_chip.h:31
uint32_t arc_hang_pc
Definition bh_chip.h:78
bool arc_wdog_triggered
Definition bh_chip.h:80
uint8_t fan_speed
Definition bh_chip.h:83
int64_t pgood_last_trip_ms
Definition bh_chip.h:69
bool pgood_severe_fault
Definition bh_chip.h:68
uint32_t dm_init_done
Definition bh_chip.h:101
uint8_t last_cm2dm_seq_num
Definition bh_chip.h:88
bool workaround_applied
Definition bh_chip.h:43
bool perst_seen
Definition bh_chip.h:100
bool last_cm2dm_seq_num_valid
Definition bh_chip.h:89
volatile bool therm_trip_triggered
Definition bh_chip.h:62
atomic_t trigger_reset
Definition bh_chip.h:58
uint16_t cable_power_limit
Definition bh_chip.h:92
uint16_t therm_trip_count
Definition bh_chip.h:63
uint32_t telemetry_heartbeat
Definition bh_chip.h:75
volatile bool pgood_fall_triggered
Definition bh_chip.h:66
volatile bool performing_reset
Definition bh_chip.h:59
uint32_t arc_start_time
Definition bh_chip.h:102
volatile bool pgood_rise_triggered
Definition bh_chip.h:67
bool arc_needs_init_msg
Definition bh_chip.h:49
unsigned int bus_cancel_flag
Definition bh_chip.h:51
uint32_t auto_reset_timeout
Definition bh_chip.h:72
bool fan_speed_forced
Definition bh_chip.h:85
struct bh_chip_data data
Definition bh_chip.h:107
struct gpio_callback therm_trip_cb
Definition bh_chip.h:108
const struct bh_chip_config config
Definition bh_chip.h:106
struct k_timer auto_reset_timer
Definition bh_chip.h:110
struct gpio_callback pgood_cb
Definition bh_chip.h:109
struct gpio_dt_spec gpio6
Definition bh_chip.h:21
struct gpio_dt_spec gpio38
Definition bh_chip.h:22
struct gpio_dt_spec gpio40
Definition bh_chip.h:24
struct gpio_dt_spec gpio39
Definition bh_chip.h:23