blob: 9aa2c969babf53d2c94bb7f0e402b1404bd3f4e5 [file] [log] [blame]
Peter Stuge483b7bb2009-04-14 07:40:01 +00001/*
2 * This file is part of the coreboot project.
3 *
4 * Copyright (C) 2008 Jordan Crouse <jordan@cosmicpenguin.net>
Hung-Te Lin6fe0cab2013-01-22 18:57:56 +08005 * Copyright (C) 2013 The Chromium OS Authors. All rights reserved.
Peter Stuge483b7bb2009-04-14 07:40:01 +00006 *
7 * This file is dual-licensed. You can choose between:
8 * - The GNU GPL, version 2, as published by the Free Software Foundation
9 * - The revised BSD license (without advertising clause)
10 *
11 * ---------------------------------------------------------------------------
12 * This program is free software; you can redistribute it and/or modify
13 * it under the terms of the GNU General Public License as published by
14 * the Free Software Foundation; version 2 of the License.
15 *
16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
20 *
21 * You should have received a copy of the GNU General Public License
22 * along with this program; if not, write to the Free Software
23 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA, 02110-1301 USA
24 * ---------------------------------------------------------------------------
25 * Redistribution and use in source and binary forms, with or without
26 * modification, are permitted provided that the following conditions
27 * are met:
28 * 1. Redistributions of source code must retain the above copyright
29 * notice, this list of conditions and the following disclaimer.
30 * 2. Redistributions in binary form must reproduce the above copyright
31 * notice, this list of conditions and the following disclaimer in the
32 * documentation and/or other materials provided with the distribution.
33 * 3. The name of the author may not be used to endorse or promote products
34 * derived from this software without specific prior written permission.
35 *
36 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
37 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
38 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
39 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
40 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
41 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
42 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
43 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
44 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
45 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
46 * SUCH DAMAGE.
47 * ---------------------------------------------------------------------------
48 */
49
50#ifndef _CBFS_H_
51#define _CBFS_H_
52
Hung-Te Lin6fe0cab2013-01-22 18:57:56 +080053#include <cbfs_core.h>
Peter Stuge483b7bb2009-04-14 07:40:01 +000054
Hung-Te Lin6fe0cab2013-01-22 18:57:56 +080055void *cbfs_load_optionrom(struct cbfs_media *media, uint16_t vendor,
56 uint16_t device, void * dest);
Hung-Te Lin6fe0cab2013-01-22 18:57:56 +080057void *cbfs_load_stage(struct cbfs_media *media, const char *name);
Daisuke Nojiri35890172014-09-19 09:56:15 -070058void *cbfs_load_stage_by_offset(struct cbfs_media *media, ssize_t offset);
Hung-Te Lin6fe0cab2013-01-22 18:57:56 +080059
60/* Simple buffer for streaming media. */
61struct cbfs_simple_buffer {
62 char *buffer;
63 size_t allocated;
64 size_t size;
65 size_t last_allocate;
66};
67
68void *cbfs_simple_buffer_map(struct cbfs_simple_buffer *buffer,
69 struct cbfs_media *media,
70 size_t offset, size_t count);
71
72void *cbfs_simple_buffer_unmap(struct cbfs_simple_buffer *buffer,
73 const void *address);
74
75// Utility functions
Peter Stuge483b7bb2009-04-14 07:40:01 +000076int run_address(void *f);
Hung-Te Lin6fe0cab2013-01-22 18:57:56 +080077
Hung-Te Lin6fe0cab2013-01-22 18:57:56 +080078/* Defined in individual arch / board implementation. */
79int init_default_cbfs_media(struct cbfs_media *media);
80
Aaron Durbin0f333072014-01-30 17:19:46 -060081#if defined(__PRE_RAM__)
82struct romstage_handoff;
83struct cbmem_entry;
84
Aaron Durbinde1f8902013-02-15 23:26:52 -060085#if CONFIG_RELOCATABLE_RAMSTAGE && defined(__PRE_RAM__)
86/* The cache_loaded_ramstage() and load_cached_ramstage() functions are defined
87 * to be weak so that board and chipset code may override them. Their job is to
88 * cache and load the ramstage for quick S3 resume. By default a copy of the
Aaron Durbindd4a6d22013-02-27 22:50:12 -060089 * relocated ramstage is saved using the cbmem infrastructure. These
Aaron Durbinde1f8902013-02-15 23:26:52 -060090 * functions are only valid during romstage. */
91
Aaron Durbindd4a6d22013-02-27 22:50:12 -060092/* The implementer of cache_loaded_ramstage() may use the romstage_handoff
93 * structure to store information, but note that the handoff variable can be
94 * NULL. The ramstage cbmem_entry represents the region occupied by the loaded
95 * ramstage. */
Kyösti Mälkkic7c02672014-12-26 13:28:35 +020096void cache_loaded_ramstage(struct romstage_handoff *handoff,
Aaron Durbindd4a6d22013-02-27 22:50:12 -060097 const struct cbmem_entry *ramstage, void *entry_point);
98/* Return NULL on error or entry point on success. The ramstage cbmem_entry is
99 * the region where to load the cached contents to. */
Kyösti Mälkkic7c02672014-12-26 13:28:35 +0200100void * load_cached_ramstage(struct romstage_handoff *handoff,
Aaron Durbindd4a6d22013-02-27 22:50:12 -0600101 const struct cbmem_entry *ramstage);
Aaron Durbin0f333072014-01-30 17:19:46 -0600102#else /* CONFIG_RELOCATABLE_RAMSTAGE */
103
104static inline void cache_loaded_ramstage(struct romstage_handoff *handoff,
105 const struct cbmem_entry *ramstage, void *entry_point)
106{
107}
108
109static inline void *
110load_cached_ramstage(struct romstage_handoff *handoff,
111 const struct cbmem_entry *ramstage)
112{
113 return NULL;
114}
115
Aaron Durbinde1f8902013-02-15 23:26:52 -0600116#endif /* CONFIG_RELOCATABLE_RAMSTAGE */
Aaron Durbin0f333072014-01-30 17:19:46 -0600117#endif /* defined(__PRE_RAM__) */
Aaron Durbinde1f8902013-02-15 23:26:52 -0600118
Peter Stuge483b7bb2009-04-14 07:40:01 +0000119#endif
120