TT-System-Firmware APIs 19.10.99
Tenstorrent Firmware
Loading...
Searching...
No Matches
bh_chip.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2024 Tenstorrent AI ULC
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#ifndef INCLUDE_TENSTORRENT_LIB_BH_CHIP_H_
8#define INCLUDE_TENSTORRENT_LIB_BH_CHIP_H_
9
10#include "bh_arc.h"
11
12#include <zephyr/kernel.h>
13#include <zephyr/device.h>
14#include <zephyr/drivers/gpio.h>
15
16#ifdef __cplusplus
17extern "C" {
18#endif
19
26
33 const struct device *flash;
34 const struct device *jtag;
35
36 const struct bh_straps strapping;
37
38 struct bh_arc arc;
39};
40
42 /* Flag set when bootrom has been loaded and the arc_soft_reset sequence can be appled. */
44
45 /*
46 * Flag set when need to send or receive 1 time info to chip.
47 * Could be used for static data or config of peripherals.
48 */
50
51 unsigned int bus_cancel_flag;
52
53 /*
54 * notify the main thread to apply reset sequence
55 * also used during initial workaround application to invoke a reset as soon
56 * as the workaround has been applied
57 */
59 volatile bool performing_reset;
60
61 /* notify the main thread to handle therm trip */
62 volatile bool therm_trip_triggered;
64
65 /* notify the main thread to handle pgood events */
66 volatile bool pgood_fall_triggered;
67 volatile bool pgood_rise_triggered;
70
71 /* Max allowable time between pings from SMC in ms */
73
74 /* Keep track of telemetry heartbeat for autoreset */
76
77 /* Tracks program counter during last ARC hang */
79 /* Was ARC watchdog triggered? */
81
82 /* Requested fan speed in %. */
84 /* Is that a forced or automatic fan speed? */
86
87 /* Last seen CM2DM message sequence number, to know if the current message is a repeat. */
90
91 /* Cable power limit detected at boot, written to scratch register during resets. */
93
94 /*
95 * Per-chip DMC init timing
96 * perst_seen flags whether dm_init_done should be tracked.
97 * dm_init_done is in DMC clock cycles
98 * arc_start_time is ASIC refclk counter read over JTAG (see jtag_bootrom_soft_reset_arc).
99 */
103};
104
112
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)))
116
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)
119extern struct bh_chip BH_CHIPS[BH_CHIP_COUNT];
120
121#define MAKE_STRUCT_FIELD(n) .n
122
123#define INIT_STRAP(n) MAKE_STRUCT_FIELD(DT_NODE_FULL_NAME_TOKEN(n)) = GPIO_DT_SPEC_GET(n, gpios),
124
125#define INIT_CHIP(n, prop, idx) \
126 { \
127 .config = { \
128 .asic_reset = GPIO_DT_SPEC_GET( \
129 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), asic_reset), \
130 gpios), \
131 .spi_reset = GPIO_DT_SPEC_GET( \
132 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), spi_reset), \
133 gpios), \
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), \
142 gpios), \
143 .pgood = GPIO_DT_SPEC_GET( \
144 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), pgood), \
145 gpios), \
146 .therm_trip = GPIO_DT_SPEC_GET( \
147 DT_PHANDLE_OR_CHILD(DT_PHANDLE_BY_IDX(n, prop, idx), therm_trip), \
148 gpios), \
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), \
152 INIT_STRAP)), \
153 ())}, \
154 }, \
155 .auto_reset_timer = Z_TIMER_INITIALIZER( \
156 BH_CHIPS[idx].auto_reset_timer, \
157 bh_chip_auto_reset, NULL), \
158 },
159
160#define BH_CHIP_PRIMARY_INDEX DT_PROP(DT_PATH(chips), primary)
161
162int jtag_bootrom_reset_sequence(struct bh_chip *chip, bool force_reset, uint16_t cable_power_limit);
163
166
168int bh_chip_set_static_info(struct bh_chip *chip, dmStaticInfo *info);
170int bh_chip_set_input_power_lim(struct bh_chip *chip, uint16_t max_power);
171int bh_chip_set_fan_rpm(struct bh_chip *chip, uint16_t rpm);
172int bh_chip_set_therm_trip_count(struct bh_chip *chip, uint16_t therm_trip_count);
173int bh_chip_write_logs(struct bh_chip *chip, char *log_data, size_t log_size);
174
175void bh_chip_auto_reset(struct k_timer *timer);
176
177void bh_chip_assert_asic_reset(const struct bh_chip *chip);
178void bh_chip_deassert_asic_reset(const struct bh_chip *chip);
179
180void bh_chip_set_straps(struct bh_chip *chip);
181void bh_chip_unset_straps(struct bh_chip *chip);
182
183void bh_chip_assert_spi_reset(const struct bh_chip *chip);
184void bh_chip_deassert_spi_reset(const struct bh_chip *chip);
185
186int bh_chip_reset_chip(struct bh_chip *chip, bool force_reset);
187
188int therm_trip_gpio_setup(struct bh_chip *chip);
189int pgood_gpio_setup(struct bh_chip *chip);
190
191void handle_pgood_event(struct bh_chip *chip, struct gpio_dt_spec board_fault_led);
192
193#ifdef __cplusplus
194}
195#endif
196
197#endif /* INCLUDE_TENSTORRENT_LIB_BH_CHIP_H_ */
long atomic_t
#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
__UINT32_TYPE__ uint32_t
__UINT8_TYPE__ uint8_t
__UINT16_TYPE__ uint16_t
__INT64_TYPE__ int64_t
Definition bh_arc.h:63
Definition bh_chip.h:27
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
Definition bh_chip.h:41
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
Definition bh_chip.h:105
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
Definition bh_chip.h:20
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
Definition bh_arc.h:68
Definition bh_arc.h:34