blob: 6d2ae5dfe7b0337e6ea4886b47a308bcd0c6681c [file] [log] [blame]
Simon Glass245561d2014-11-12 22:42:09 -07001/*
2 * Copyright (c) 2014 Google, Inc
3 *
4 * SPDX-License-Identifier: GPL-2.0+
5 */
6
7#ifndef _post_h
8#define _post_h
9
10/* port to use for post codes */
11#define POST_PORT 0x80
12
13/* post codes which represent various stages of init */
14#define POST_START 0x1e
15#define POST_CAR_START 0x1f
Simon Glass98f139b2014-11-12 22:42:10 -070016#define POST_CAR_SIPI 0x20
17#define POST_CAR_MTRR 0x21
18#define POST_CAR_UNCACHEABLE 0x22
19#define POST_CAR_BASE_ADDRESS 0x23
20#define POST_CAR_MASK 0x24
21#define POST_CAR_FILL 0x25
22#define POST_CAR_ROM_CACHE 0x26
23#define POST_CAR_MRC_CACHE 0x27
24#define POST_CAR_CPU_CACHE 0x28
Simon Glass245561d2014-11-12 22:42:09 -070025#define POST_START_STACK 0x29
26#define POST_START_DONE 0x2a
Simon Glass98f139b2014-11-12 22:42:10 -070027#define POST_CPU_INIT 0x2b
Simon Glass30580fc2014-11-12 22:42:23 -070028#define POST_EARLY_INIT 0x2c
29#define POST_CPU_INFO 0x2d
Simon Glass268eefd2014-11-12 22:42:28 -070030#define POST_PRE_MRC 0x2e
31#define POST_MRC 0x2f
32#define POST_DRAM 0x2f
Simon Glass3121dbd2014-11-24 21:18:15 -070033#define POST_LAPIC 0x30
Simon Glass268eefd2014-11-12 22:42:28 -070034
35#define POST_RAM_FAILURE 0xea
Simon Glass245561d2014-11-12 22:42:09 -070036
37/* Output a post code using al - value must be 0 to 0xff */
38#ifdef __ASSEMBLY__
39#define post_code(value) \
40 movb $value, %al; \
41 outb %al, $POST_PORT
42#else
Simon Glass98f139b2014-11-12 22:42:10 -070043#include <asm/io.h>
44
Simon Glass245561d2014-11-12 22:42:09 -070045static inline void post_code(int code)
46{
47 outb(code, POST_PORT);
48}
49#endif
50
51#endif