blob: 86c020ee0b93d78faee661bfdb5768c5d14c5803 [file] [log] [blame]
Simon Glassb0edea32018-11-15 18:44:09 -07001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Passing basic information from SPL to U-Boot proper
4 *
5 * Copyright 2018 Google, Inc
6 */
7
Simon Glass2e931312024-08-21 10:19:13 -06008#include <bloblist.h>
Simon Glassb0edea32018-11-15 18:44:09 -07009#include <handoff.h>
Simon Glass401d1c42020-10-30 21:38:53 -060010#include <asm/global_data.h>
Simon Glassb0edea32018-11-15 18:44:09 -070011
12DECLARE_GLOBAL_DATA_PTR;
13
14void handoff_save_dram(struct spl_handoff *ho)
15{
Stefan Roesedfaf6a52020-08-12 11:55:46 +020016 struct bd_info *bd = gd->bd;
17 int i;
Simon Glassb0edea32018-11-15 18:44:09 -070018
Stefan Roesedfaf6a52020-08-12 11:55:46 +020019 ho->ram_size = gd->ram_size;
20
21 for (i = 0; i < CONFIG_NR_DRAM_BANKS; i++) {
22 ho->ram_bank[i].start = bd->bi_dram[i].start;
23 ho->ram_bank[i].size = bd->bi_dram[i].size;
Simon Glassb0edea32018-11-15 18:44:09 -070024 }
Simon Glassb0edea32018-11-15 18:44:09 -070025}
26
27void handoff_load_dram_size(struct spl_handoff *ho)
28{
29 gd->ram_size = ho->ram_size;
30}
31
32void handoff_load_dram_banks(struct spl_handoff *ho)
33{
Stefan Roesedfaf6a52020-08-12 11:55:46 +020034 struct bd_info *bd = gd->bd;
35 int i;
Simon Glassb0edea32018-11-15 18:44:09 -070036
Stefan Roesedfaf6a52020-08-12 11:55:46 +020037 for (i = 0; i < CONFIG_NR_DRAM_BANKS; i++) {
38 bd->bi_dram[i].start = ho->ram_bank[i].start;
39 bd->bi_dram[i].size = ho->ram_bank[i].size;
Simon Glassb0edea32018-11-15 18:44:09 -070040 }
Simon Glassb0edea32018-11-15 18:44:09 -070041}
Simon Glass2e931312024-08-21 10:19:13 -060042
43struct spl_handoff *handoff_get(void)
44{
45 struct spl_handoff *handoff;
46
47 handoff = bloblist_find(BLOBLISTT_U_BOOT_SPL_HANDOFF,
48 sizeof(struct spl_handoff));
49 debug("Found SPL hand-off info %p\n", handoff);
50
51 return handoff;
52}