summaryrefslogtreecommitdiff
path: root/arch/x86/include/asm/post.h
blob: b203dc99b063b5b4ae097a4d4e064a2bc5f5226e (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
/*
 * Copyright (c) 2014 Google, Inc
 *
 * SPDX-License-Identifier:	GPL-2.0+
 */

#ifndef _post_h
#define _post_h

/* port to use for post codes */
#define POST_PORT		0x80

/* post codes which represent various stages of init */
#define POST_START		0x1e
#define POST_CAR_START		0x1f
#define POST_CAR_SIPI		0x20
#define POST_CAR_MTRR		0x21
#define POST_CAR_UNCACHEABLE	0x22
#define POST_CAR_BASE_ADDRESS	0x23
#define POST_CAR_MASK		0x24
#define POST_CAR_FILL		0x25
#define POST_CAR_ROM_CACHE	0x26
#define POST_CAR_MRC_CACHE	0x27
#define POST_CAR_CPU_CACHE	0x28
#define POST_START_STACK	0x29
#define POST_START_DONE		0x2a
#define POST_CPU_INIT		0x2b

/* Output a post code using al - value must be 0 to 0xff */
#ifdef __ASSEMBLY__
#define post_code(value) \
	movb	$value, %al; \
	outb	%al, $POST_PORT
#else
#include <asm/io.h>

static inline void post_code(int code)
{
	outb(code, POST_PORT);
}
#endif

#endif