Andrey Petrov | 9de55cc | 2016-02-25 14:19:07 -0800 | [diff] [blame] | 1 | /* |
| 2 | * This file is part of the coreboot project. |
| 3 | * |
Lee Leahy | 47bd2d9 | 2016-07-24 18:12:16 -0700 | [diff] [blame] | 4 | * Copyright (C) 2015-2016 Intel Corp. |
Andrey Petrov | 9de55cc | 2016-02-25 14:19:07 -0800 | [diff] [blame] | 5 | * (Written by Andrey Petrov <andrey.petrov@intel.com> for Intel Corp.) |
| 6 | * |
| 7 | * This program is free software; you can redistribute it and/or modify |
| 8 | * it under the terms of the GNU General Public License as published by |
| 9 | * the Free Software Foundation; either version 2 of the License, or |
| 10 | * (at your option) any later version. |
| 11 | */ |
| 12 | |
| 13 | #include <arch/cpu.h> |
Lee Leahy | 806fa24 | 2016-08-01 13:55:02 -0700 | [diff] [blame^] | 14 | #include <bootstate.h> |
Andrey Petrov | 9de55cc | 2016-02-25 14:19:07 -0800 | [diff] [blame] | 15 | #include <console/console.h> |
| 16 | #include <fsp/api.h> |
| 17 | #include <fsp/util.h> |
Lee Leahy | 806fa24 | 2016-08-01 13:55:02 -0700 | [diff] [blame^] | 18 | #include <soc/intel/common/util.h> |
Andrey Petrov | 9de55cc | 2016-02-25 14:19:07 -0800 | [diff] [blame] | 19 | #include <string.h> |
Alexandru Gagniuc | 010225c | 2016-05-06 08:22:45 -0700 | [diff] [blame] | 20 | #include <timestamp.h> |
Andrey Petrov | 9de55cc | 2016-02-25 14:19:07 -0800 | [diff] [blame] | 21 | |
Lee Leahy | 806fa24 | 2016-08-01 13:55:02 -0700 | [diff] [blame^] | 22 | static void fsp_notify(enum fsp_notify_phase phase) |
Andrey Petrov | 9de55cc | 2016-02-25 14:19:07 -0800 | [diff] [blame] | 23 | { |
Alexandru Gagniuc | 010225c | 2016-05-06 08:22:45 -0700 | [diff] [blame] | 24 | enum fsp_status ret; |
Andrey Petrov | 9de55cc | 2016-02-25 14:19:07 -0800 | [diff] [blame] | 25 | fsp_notify_fn fspnotify; |
| 26 | struct fsp_notify_params notify_params = { .phase = phase }; |
| 27 | |
Lee Leahy | 9671faa | 2016-07-24 18:18:52 -0700 | [diff] [blame] | 28 | if (!fsps_hdr.notify_phase_entry_offset) |
| 29 | die("Notify_phase_entry_offset is zero!\n"); |
Andrey Petrov | 9de55cc | 2016-02-25 14:19:07 -0800 | [diff] [blame] | 30 | |
| 31 | fspnotify = (void*) (fsps_hdr.image_base + |
| 32 | fsps_hdr.notify_phase_entry_offset); |
Lee Leahy | 672df16 | 2016-07-24 18:21:13 -0700 | [diff] [blame] | 33 | fsp_before_debug_notify(fspnotify, ¬ify_params); |
Andrey Petrov | 9de55cc | 2016-02-25 14:19:07 -0800 | [diff] [blame] | 34 | |
Alexandru Gagniuc | c4ea8f7 | 2016-05-23 12:16:58 -0700 | [diff] [blame] | 35 | if (phase == AFTER_PCI_ENUM) { |
Alexandru Gagniuc | 010225c | 2016-05-06 08:22:45 -0700 | [diff] [blame] | 36 | timestamp_add_now(TS_FSP_BEFORE_ENUMERATE); |
Alexandru Gagniuc | c4ea8f7 | 2016-05-23 12:16:58 -0700 | [diff] [blame] | 37 | post_code(POST_FSP_NOTIFY_BEFORE_ENUMERATE); |
| 38 | } else if (phase == READY_TO_BOOT) { |
Alexandru Gagniuc | 010225c | 2016-05-06 08:22:45 -0700 | [diff] [blame] | 39 | timestamp_add_now(TS_FSP_BEFORE_FINALIZE); |
Alexandru Gagniuc | c4ea8f7 | 2016-05-23 12:16:58 -0700 | [diff] [blame] | 40 | post_code(POST_FSP_NOTIFY_BEFORE_FINALIZE); |
| 41 | } |
Alexandru Gagniuc | 010225c | 2016-05-06 08:22:45 -0700 | [diff] [blame] | 42 | |
| 43 | ret = fspnotify(¬ify_params); |
| 44 | |
Alexandru Gagniuc | c4ea8f7 | 2016-05-23 12:16:58 -0700 | [diff] [blame] | 45 | if (phase == AFTER_PCI_ENUM) { |
Alexandru Gagniuc | 010225c | 2016-05-06 08:22:45 -0700 | [diff] [blame] | 46 | timestamp_add_now(TS_FSP_AFTER_ENUMERATE); |
Alexandru Gagniuc | c4ea8f7 | 2016-05-23 12:16:58 -0700 | [diff] [blame] | 47 | post_code(POST_FSP_NOTIFY_BEFORE_ENUMERATE); |
| 48 | } else if (phase == READY_TO_BOOT) { |
Alexandru Gagniuc | 010225c | 2016-05-06 08:22:45 -0700 | [diff] [blame] | 49 | timestamp_add_now(TS_FSP_AFTER_FINALIZE); |
Alexandru Gagniuc | c4ea8f7 | 2016-05-23 12:16:58 -0700 | [diff] [blame] | 50 | post_code(POST_FSP_NOTIFY_BEFORE_FINALIZE); |
| 51 | } |
Lee Leahy | 672df16 | 2016-07-24 18:21:13 -0700 | [diff] [blame] | 52 | fsp_debug_after_notify(ret); |
Alexandru Gagniuc | 010225c | 2016-05-06 08:22:45 -0700 | [diff] [blame] | 53 | |
Lee Leahy | 9671faa | 2016-07-24 18:18:52 -0700 | [diff] [blame] | 54 | /* Handle any errors returned by FspNotify */ |
| 55 | fsp_handle_reset(ret); |
| 56 | if (ret != FSP_SUCCESS) { |
| 57 | printk(BIOS_SPEW, "FspNotify returned 0x%08x\n", ret); |
| 58 | die("FspNotify returned an error!\n"); |
| 59 | } |
Lee Leahy | 806fa24 | 2016-08-01 13:55:02 -0700 | [diff] [blame^] | 60 | |
| 61 | /* Allow the platform to run something after FspNotify */ |
| 62 | platform_fsp_notify_status(phase); |
| 63 | } |
| 64 | |
| 65 | static void fsp_notify_dummy(void *arg) |
| 66 | { |
| 67 | enum fsp_notify_phase phase = (uint32_t)arg; |
| 68 | |
| 69 | /* Display the MTRRs */ |
| 70 | if (IS_ENABLED(CONFIG_DISPLAY_MTRRS)) |
| 71 | soc_display_mtrrs(); |
| 72 | |
| 73 | fsp_notify(phase); |
| 74 | if (phase == READY_TO_BOOT) |
| 75 | fsp_notify(END_OF_FIRMWARE); |
| 76 | } |
| 77 | |
| 78 | BOOT_STATE_INIT_ENTRY(BS_DEV_RESOURCES, BS_ON_EXIT, fsp_notify_dummy, |
| 79 | (void *) AFTER_PCI_ENUM); |
| 80 | BOOT_STATE_INIT_ENTRY(BS_PAYLOAD_LOAD, BS_ON_EXIT, fsp_notify_dummy, |
| 81 | (void *) READY_TO_BOOT); |
| 82 | BOOT_STATE_INIT_ENTRY(BS_OS_RESUME, BS_ON_ENTRY, fsp_notify_dummy, |
| 83 | (void *) READY_TO_BOOT); |
| 84 | |
| 85 | __attribute__((weak)) void platform_fsp_notify_status( |
| 86 | enum fsp_notify_phase phase) |
| 87 | { |
Andrey Petrov | 9de55cc | 2016-02-25 14:19:07 -0800 | [diff] [blame] | 88 | } |