aboutsummaryrefslogtreecommitdiff
path: root/src/arm/windows/windows-arm-init.h
blob: 76cc51e3c02a434c0644ac5e5b5239f26555df75 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#pragma once

/* List of known and supported Windows on Arm SoCs/chips. */
enum woa_chip_name {
	woa_chip_name_microsoft_sq_1 = 0,
	woa_chip_name_microsoft_sq_2 = 1,
	woa_chip_name_unknown = 2,
	woa_chip_name_last = woa_chip_name_unknown
};

/* Topology information hard-coded by SoC/chip name */
struct core_info_by_chip_name {
	enum cpuinfo_uarch uarch;
	uint64_t frequency; /* Hz */
};

/* SoC/chip info that's currently not readable by logical system information,
 * but can be read from registry.
 */
struct woa_chip_info {
	char* chip_name_string;
	enum woa_chip_name chip_name;
	struct core_info_by_chip_name uarchs[woa_chip_name_last];
};

bool get_core_uarch_for_efficiency(
	enum woa_chip_name chip, BYTE EfficiencyClass,
	enum cpuinfo_uarch* uarch, uint64_t* frequency);

bool cpu_info_init_by_logical_sys_info(
	const struct woa_chip_info *chip_info,
	enum cpuinfo_vendor vendor);