summaryrefslogtreecommitdiff
path: root/chip/max32660/system_chip.c
blob: 07127dc8c5834e72e3ca5ac9fdfa804d178e6dd3 (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
/* Copyright 2019 The Chromium OS Authors. All rights reserved.
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

/* MAX32660 System module for Chrome EC */

#include "clock.h"
#include "common.h"
#include "console.h"
#include "cpu.h"
#include "host_command.h"
#include "panic.h"
#include "system.h"
#include "task.h"
#include "timer.h"
#include "util.h"
#include "registers.h"
#include "gcr_regs.h"

/* Console output macros */
#define CPUTS(outstr) cputs(CC_SYSTEM, outstr)
#define CPRINTS(format, args...) cprints(CC_SYSTEM, format, ##args)

void chip_pre_init(void)
{
}

void system_pre_init(void)
{
}

void system_reset(int flags)
{
	MXC_GCR->rstr0 = MXC_F_GCR_RSTR0_SYSTEM;
	while (1)
		;
}

void system_hibernate(uint32_t seconds, uint32_t microseconds)
{
	/* chip specific standby mode */
	CPRINTS("TODO: implement %s()", __func__);
}

const char *system_get_chip_vendor(void)
{
	return "maxim";
}

const char *system_get_chip_name(void)
{
	return "max32660";
}

const char *system_get_chip_revision(void)
{
	return "A1";
}

int system_get_bbram(enum system_bbram_idx idx, uint8_t *value)
{
	return EC_ERROR_UNIMPLEMENTED;
}