blob: 0f263a92f1c00ac592a1021b9975e600cbf5c872 [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 */
David Brazdilb856be62020-03-25 10:14:55 +000025bool boot_flow_get_params(struct boot_params *p, const struct fdt *fdt)
Andrew Scullc3771072019-09-19 13:30:42 +010026{
Andrew Scull6c9a4ab2020-01-27 17:09:12 +000027 struct string memory = STRING_INIT("memory");
Andrew Scull48929fd2020-01-28 10:39:10 +000028 struct string device_memory = STRING_INIT("device-memory");
Andrew Scull6c9a4ab2020-01-27 17:09:12 +000029
Andrew Scullc3771072019-09-19 13:30:42 +010030 p->mem_ranges_count = 0;
31 p->kernel_arg = plat_boot_flow_get_kernel_arg();
32
David Brazdilb856be62020-03-25 10:14:55 +000033 return plat_boot_flow_get_initrd_range(fdt, &p->initrd_begin,
Andrew Scullc3771072019-09-19 13:30:42 +010034 &p->initrd_end) &&
David Brazdilb856be62020-03-25 10:14:55 +000035 fdt_find_cpus(fdt, p->cpu_ids, &p->cpu_count) &&
36 fdt_find_memory_ranges(fdt, &memory, p->mem_ranges,
Andrew Scull48929fd2020-01-28 10:39:10 +000037 &p->mem_ranges_count, MAX_MEM_RANGES) &&
David Brazdilb856be62020-03-25 10:14:55 +000038 fdt_find_memory_ranges(fdt, &device_memory, p->device_mem_ranges,
39 &p->device_mem_ranges_count,
40 MAX_DEVICE_MEM_RANGES);
Andrew Scullc3771072019-09-19 13:30:42 +010041}
42
43/**
Andrew Scullc3771072019-09-19 13:30:42 +010044 * Takes action on any updates that were generated.
45 */
46bool boot_flow_update(struct mm_stage1_locked stage1_locked,
David Brazdile6f83222019-09-23 14:47:37 +010047 const struct manifest *manifest,
Andrew Scull9c251d32019-09-19 13:30:42 +010048 struct boot_params_update *p, struct memiter *cpio,
49 struct mpool *ppool)
Andrew Scullc3771072019-09-19 13:30:42 +010050{
David Brazdile6f83222019-09-23 14:47:37 +010051 return plat_boot_flow_update(stage1_locked, manifest, p, cpio, ppool);
Andrew Scullc3771072019-09-19 13:30:42 +010052}