blob: afafb30c147feb4c63831b4faf1591cb92cf753c [file] [log] [blame]
Bin Meng2922b3e2014-12-12 21:05:28 +08001/*
2 * Copyright (C) 2013, Intel Corporation
3 * Copyright (C) 2014, Bin Meng <bmeng.cn@gmail.com>
4 *
5 * SPDX-License-Identifier: Intel
6 */
7
8#ifndef __FSP_API_H__
9#define __FSP_API_H__
10
Simon Glass457191e2015-01-27 22:13:37 -070011#include <linux/linkage.h>
12
Bin Meng2922b3e2014-12-12 21:05:28 +080013/*
Bin Menga0c94dc2015-12-10 22:02:59 -080014 * FSP common configuration structure.
15 * This needs to be included in the platform-specific struct fsp_config_data.
16 */
17struct fsp_cfg_common {
18 struct fsp_header *fsp_hdr;
19 u32 stack_top;
20 u32 boot_mode;
21};
22
23/*
Bin Meng2922b3e2014-12-12 21:05:28 +080024 * FspInit continuation function prototype.
25 * Control will be returned to this callback function after FspInit API call.
26 */
27typedef void (*fsp_continuation_f)(u32 status, void *hob_list);
28
Bin Mengdb60d862014-12-17 15:50:49 +080029struct fsp_init_params {
Bin Meng2922b3e2014-12-12 21:05:28 +080030 /* Non-volatile storage buffer pointer */
31 void *nvs_buf;
32 /* Runtime buffer pointer */
33 void *rt_buf;
34 /* Continuation function address */
35 fsp_continuation_f continuation;
36};
37
Bin Mengdb60d862014-12-17 15:50:49 +080038struct common_buf {
Bin Meng2922b3e2014-12-12 21:05:28 +080039 /*
40 * Stack top pointer used by the bootloader. The new stack frame will be
41 * set up at this location after FspInit API call.
42 */
Bin Meng40745a02015-12-10 22:02:57 -080043 u32 stack_top;
Bin Meng2922b3e2014-12-12 21:05:28 +080044 u32 boot_mode; /* Current system boot mode */
45 void *upd_data; /* User platform configuraiton data region */
46 u32 reserved[7]; /* Reserved */
47};
48
Bin Mengdb60d862014-12-17 15:50:49 +080049enum fsp_phase {
Bin Meng2922b3e2014-12-12 21:05:28 +080050 /* Notification code for post PCI enuermation */
51 INIT_PHASE_PCI = 0x20,
52 /* Notification code before transfering control to the payload */
53 INIT_PHASE_BOOT = 0x40
54};
55
Bin Mengdb60d862014-12-17 15:50:49 +080056struct fsp_notify_params {
Bin Meng2922b3e2014-12-12 21:05:28 +080057 /* Notification phase used for NotifyPhase API */
Bin Mengdb60d862014-12-17 15:50:49 +080058 enum fsp_phase phase;
Bin Meng2922b3e2014-12-12 21:05:28 +080059};
60
Bin Meng2922b3e2014-12-12 21:05:28 +080061/* FspInit API function prototype */
Simon Glass457191e2015-01-27 22:13:37 -070062typedef asmlinkage u32 (*fsp_init_f)(struct fsp_init_params *params);
Bin Meng2922b3e2014-12-12 21:05:28 +080063
64/* FspNotify API function prototype */
Simon Glass457191e2015-01-27 22:13:37 -070065typedef asmlinkage u32 (*fsp_notify_f)(struct fsp_notify_params *params);
Bin Meng2922b3e2014-12-12 21:05:28 +080066
67#endif