summaryrefslogtreecommitdiff
path: root/board/brask/fw_config.c
blob: 3ee71e6a0f57f20039deb25735d89c59ffdc9d9e (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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/* Copyright 2022 The ChromiumOS Authors
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

#include "cbi.h"
#include "common.h"
#include "compile_time_macros.h"
#include "console.h"
#include "cros_board_info.h"
#include "fw_config.h"

#define CPRINTS(format, args...) cprints(CC_SYSTEM, format, ##args)

static union brask_cbi_fw_config fw_config;
BUILD_ASSERT(sizeof(fw_config) == sizeof(uint32_t));

/*
 * FW_CONFIG defaults for brask if the CBI.FW_CONFIG data is not
 * initialized.
 */
static const union brask_cbi_fw_config fw_config_defaults = {
	.audio = DB_NAU88L25B_I2S,
	.bj_power = BJ_135W,
};

/*
 * Barrel-jack power adapter ratings.
 */
static const struct {
	int voltage;
	int current;
} bj_power[] = {
	[BJ_135W] = { /* 0 - 135W (also default) */
			.voltage = 19500,
			.current = 6920
	},
	[BJ_230W] = { /* 1 - 230W */
			.voltage = 19500,
			.current = 11800
	}
};

/****************************************************************************
 * Brask FW_CONFIG access
 */
void board_init_fw_config(void)
{
	if (cbi_get_fw_config(&fw_config.raw_value)) {
		CPRINTS("CBI: Read FW_CONFIG failed, using board defaults");
		fw_config = fw_config_defaults;
	}
}

void ec_bj_power(uint32_t *voltage, uint32_t *current)
{
	unsigned int bj;

	bj = fw_config.bj_power;
	/* Out of range value defaults to 0 */
	if (bj >= ARRAY_SIZE(bj_power))
		bj = 0;
	*voltage = bj_power[bj].voltage;
	*current = bj_power[bj].current;
}