blob: f1d9977bcb33218c2437f27840c8fe968968507d [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
wdenk67ff36c2002-11-19 23:01:07 +00002/*
3 * (C) Copyright 2002
Albert ARIBAUD60fbc8d2011-08-04 18:45:45 +02004 * Daniel Engström, Omicron Ceti AB, daniel@omicron.se
wdenk67ff36c2002-11-19 23:01:07 +00005 */
6
7#ifndef __ASM_PROCESSOR_H_
8#define __ASM_PROCESSOR_H_ 1
Graeme Russ25391d12011-02-12 15:11:30 +11009
Simon Glass9fc71c12014-11-14 20:56:29 -070010#define X86_GDT_ENTRY_SIZE 8
Graeme Russ391bb952011-12-31 10:24:36 +110011
Simon Glass9fc71c12014-11-14 20:56:29 -070012#define X86_GDT_ENTRY_NULL 0
13#define X86_GDT_ENTRY_UNUSED 1
14#define X86_GDT_ENTRY_32BIT_CS 2
15#define X86_GDT_ENTRY_32BIT_DS 3
16#define X86_GDT_ENTRY_32BIT_FS 4
17#define X86_GDT_ENTRY_16BIT_CS 5
18#define X86_GDT_ENTRY_16BIT_DS 6
19#define X86_GDT_ENTRY_16BIT_FLAT_CS 7
20#define X86_GDT_ENTRY_16BIT_FLAT_DS 8
21#define X86_GDT_NUM_ENTRIES 9
Graeme Russ391bb952011-12-31 10:24:36 +110022
23#define X86_GDT_SIZE (X86_GDT_NUM_ENTRIES * X86_GDT_ENTRY_SIZE)
Graeme Russ25391d12011-02-12 15:11:30 +110024
Simon Glassa9a44262015-04-29 22:25:59 -060025/* Length of the public header on Intel microcode blobs */
26#define UCODE_HEADER_LEN 0x30
27
Simon Glassbe36df62014-11-10 18:00:24 -070028#ifndef __ASSEMBLY__
29
Simon Glasse0e7bd02015-04-28 20:11:29 -060030/*
31 * This register is documented in (for example) the Intel Atom Processor E3800
32 * Product Family Datasheet in "PCU - Power Management Controller (PMC)".
33 *
34 * RST_CNT: Reset Control Register (RST_CNT) Offset cf9.
35 *
36 * The naming follows Intel's naming.
37 */
Simon Glass8b73e9f2016-03-11 22:06:59 -070038#define IO_PORT_RESET 0xcf9
Simon Glassf226c412014-11-12 22:42:19 -070039
Simon Glasse0e7bd02015-04-28 20:11:29 -060040enum {
41 SYS_RST = 1 << 1, /* 0 for soft reset, 1 for hard reset */
42 RST_CPU = 1 << 2, /* initiate reset */
43 FULL_RST = 1 << 3, /* full power cycle */
44};
45
Simon Glassbe36df62014-11-10 18:00:24 -070046static inline __attribute__((always_inline)) void cpu_hlt(void)
47{
48 asm("hlt");
49}
50
51static inline ulong cpu_get_sp(void)
52{
53 ulong result;
54
55 asm volatile(
56 "mov %%esp, %%eax"
57 : "=a" (result));
58 return result;
59}
60
61#endif /* __ASSEMBLY__ */
62
wdenk67ff36c2002-11-19 23:01:07 +000063#endif