blob: 834f74607ebd8b048c3742b11f02fbb95b431a06 [file] [log] [blame]
David Brazdil0dbb41f2019-09-09 18:03:35 +01001/*
2 * Copyright 2019 The Hafnium Authors.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * https://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include "hf/boot_flow.h"
18#include "hf/dlog.h"
19#include "hf/fdt_handler.h"
20#include "hf/plat/boot_flow.h"
21
22/**
Andrew Scullc3771072019-09-19 13:30:42 +010023 * Extract the boot parameters from the FDT and the boot-flow driver.
24 */
25static bool boot_params_init(struct boot_params *p,
26 const struct fdt_node *fdt_root)
27{
28 p->mem_ranges_count = 0;
29 p->kernel_arg = plat_boot_flow_get_kernel_arg();
30
31 return plat_boot_flow_get_initrd_range(fdt_root, &p->initrd_begin,
32 &p->initrd_end) &&
33 fdt_find_cpus(fdt_root, p->cpu_ids, &p->cpu_count) &&
34 fdt_find_memory_ranges(fdt_root, p);
35}
36
37/**
David Brazdil0dbb41f2019-09-09 18:03:35 +010038 * Parses information from FDT needed to initialize Hafnium.
39 * FDT is mapped at the beginning and unmapped before exiting the function.
40 */
Andrew Scull3c257452019-11-26 13:32:50 +000041bool boot_flow_init(const struct fdt_node *fdt_root, struct manifest *manifest,
42 struct boot_params *boot_params)
David Brazdil0dbb41f2019-09-09 18:03:35 +010043{
David Brazdil0dbb41f2019-09-09 18:03:35 +010044 enum manifest_return_code manifest_ret;
45
46 /* Get the memory map from the FDT. */
David Brazdil0dbb41f2019-09-09 18:03:35 +010047
Andrew Scull3c257452019-11-26 13:32:50 +000048 manifest_ret = manifest_init(manifest, fdt_root);
David Brazdil0dbb41f2019-09-09 18:03:35 +010049 if (manifest_ret != MANIFEST_SUCCESS) {
50 dlog("Could not parse manifest: %s.\n",
51 manifest_strerror(manifest_ret));
Andrew Scull3c257452019-11-26 13:32:50 +000052 return false;
David Brazdil0dbb41f2019-09-09 18:03:35 +010053 }
54
Andrew Scull3c257452019-11-26 13:32:50 +000055 if (!boot_params_init(boot_params, fdt_root)) {
David Brazdil0dbb41f2019-09-09 18:03:35 +010056 dlog("Could not parse boot params.\n");
Andrew Scull3c257452019-11-26 13:32:50 +000057 return false;
David Brazdil0dbb41f2019-09-09 18:03:35 +010058 }
59
Andrew Scull3c257452019-11-26 13:32:50 +000060 return true;
David Brazdil0dbb41f2019-09-09 18:03:35 +010061}
Andrew Scullc3771072019-09-19 13:30:42 +010062
63/**
64 * Takes action on any updates that were generated.
65 */
66bool boot_flow_update(struct mm_stage1_locked stage1_locked,
David Brazdile6f83222019-09-23 14:47:37 +010067 const struct manifest *manifest,
Andrew Scull9c251d32019-09-19 13:30:42 +010068 struct boot_params_update *p, struct memiter *cpio,
69 struct mpool *ppool)
Andrew Scullc3771072019-09-19 13:30:42 +010070{
David Brazdile6f83222019-09-23 14:47:37 +010071 return plat_boot_flow_update(stage1_locked, manifest, p, cpio, ppool);
Andrew Scullc3771072019-09-19 13:30:42 +010072}