TT Zephyr Platforms 19.6.0-rc1
Tenstorrent Firmware
Loading...
Searching...
No Matches
aiclk_ppm.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2024 Tenstorrent AI ULC
3 * SPDX-License-Identifier: Apache-2.0
4 */
5
6#ifndef AICLK_PPM_H
7#define AICLK_PPM_H
8
9#include <stdint.h>
10#include <stdbool.h>
11
33
47
55
73
74void aiclk_update_busy(void);
75void SetAiclkArbMax(enum aiclk_arb_max arb_max, float freq);
76void SetAiclkArbMin(enum aiclk_arb_min arb_min, float freq);
77void EnableArbMax(enum aiclk_arb_max arb_max, bool enable);
78void EnableArbMin(enum aiclk_arb_min arb_min, bool enable);
79void CalculateTargAiclk(void);
80void DecreaseAiclk(void);
81void IncreaseAiclk(void);
82void InitArbMaxVoltage(void);
83float GetThrottlerArbMax(enum aiclk_arb_max arb_max);
94#endif
union aiclk_targ_freq_info get_targ_aiclk_info(void)
Definition aiclk_ppm.c:404
aiclk_arb_min
AICLK minimum frequency arbiters.
Definition aiclk_ppm.h:42
@ aiclk_arb_min_fmin
Definition aiclk_ppm.h:43
@ aiclk_arb_min_busy
Definition aiclk_ppm.h:44
@ aiclk_arb_min_count
Definition aiclk_ppm.h:45
void InitArbMaxVoltage(void)
Definition aiclk_ppm.c:194
uint32_t get_aiclk_effective_arb_max(enum aiclk_arb_max *effective_max_arb)
Definition aiclk_ppm.c:306
uint32_t get_aiclk_effective_arb_min(enum aiclk_arb_min *effective_min_arb)
Definition aiclk_ppm.c:288
uint32_t get_enabled_arb_max_bitmask(void)
Definition aiclk_ppm.c:338
uint32_t GetAiclkTarg(void)
Definition aiclk_ppm.c:264
uint32_t get_enabled_arb_min_bitmask(void)
Definition aiclk_ppm.c:324
aiclk_arb_max
AICLK maximum frequency arbiters.
Definition aiclk_ppm.h:20
@ aiclk_arb_max_thm
Definition aiclk_ppm.h:25
@ aiclk_arb_max_count
Definition aiclk_ppm.h:31
@ aiclk_arb_max_board_power
Definition aiclk_ppm.h:26
@ aiclk_arb_max_gddr_thm
Definition aiclk_ppm.h:28
@ aiclk_arb_max_doppler_critical
Definition aiclk_ppm.h:30
@ aiclk_arb_max_doppler_slow
Definition aiclk_ppm.h:29
@ aiclk_arb_max_voltage
Definition aiclk_ppm.h:27
@ aiclk_arb_max_tdp
Definition aiclk_ppm.h:22
@ aiclk_arb_max_fmax
Definition aiclk_ppm.h:21
@ aiclk_arb_max_tdc
Definition aiclk_ppm.h:24
@ aiclk_arb_max_fast_tdc
Definition aiclk_ppm.h:23
void SetAiclkArbMin(enum aiclk_arb_min arb_min, float freq)
Definition aiclk_ppm.c:76
void EnableArbMin(enum aiclk_arb_min arb_min, bool enable)
Definition aiclk_ppm.c:86
uint32_t GetMaxAiclkForVoltage(uint32_t voltage)
Definition aiclk_ppm.c:170
uint32_t GetAiclkFmax(void)
Definition aiclk_ppm.c:274
float GetThrottlerArbMax(enum aiclk_arb_max arb_max)
Definition aiclk_ppm.c:164
void EnableArbMax(enum aiclk_arb_max arb_max, bool enable)
Definition aiclk_ppm.c:81
uint8_t ForceAiclk(uint32_t freq)
Definition aiclk_ppm.c:242
targ_freq_reason
Definition aiclk_ppm.h:48
@ limit_reason_max_arb
Definition aiclk_ppm.h:50
@ limit_reason_sweep
Definition aiclk_ppm.h:52
@ limit_reason_min_arb
Definition aiclk_ppm.h:49
@ limit_reason_fmin
Definition aiclk_ppm.h:51
@ limit_reason_forced
Definition aiclk_ppm.h:53
void IncreaseAiclk(void)
Definition aiclk_ppm.c:153
void CalculateTargAiclk(void)
Definition aiclk_ppm.c:91
uint32_t GetAiclkFmin(void)
Definition aiclk_ppm.c:269
void aiclk_update_busy(void)
Definition aiclk_ppm.c:279
void SetAiclkArbMax(enum aiclk_arb_max arb_max, float freq)
Definition aiclk_ppm.c:71
void DecreaseAiclk(void)
Definition aiclk_ppm.c:142
__UINT32_TYPE__ uint32_t
__UINT8_TYPE__ uint8_t
Information about the target AICLK frequency decision.
Definition aiclk_ppm.h:62
enum targ_freq_reason reason
Definition aiclk_ppm.h:70
uint32_t u32_all
Definition aiclk_ppm.h:63
uint32_t arbiter
Definition aiclk_ppm.h:68