This region is used to store the timestamps from bootblock and verstage when cbmem is not yet initialized. Once cbmem is setup, the timestamps from this region can be retrieved and filled up properly in cbmem. In order to achieve this a new Kconfig option is introduced HAS_TIMESTAMP_REGION. This is to maintain compatbility with older boards which do not use this region. BUG=chrome-os-partner:32973 BRANCH=None TEST=cbmem -t and verified timestamps on ryu Change-Id: I4d78653c0595523eeeb02115423e7fecceea5e1e Signed-off-by: Furquan Shaikh <furquan@google.com> Reviewed-on: https://chromium-review.googlesource.com/223348 Reviewed-by: Aaron Durbin <adurbin@chromium.org> Reviewed-by: Patrick Georgi <pgeorgi@chromium.org> Tested-by: Furquan Shaikh <furquan@chromium.org> Commit-Queue: Furquan Shaikh <furquan@chromium.org>
84 lines
2.3 KiB
C
84 lines
2.3 KiB
C
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* Copyright 2014 Google Inc.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; version 2 of the License.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA, 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef __SYMBOLS_H
|
|
#define __SYMBOLS_H
|
|
|
|
#include <types.h>
|
|
|
|
extern u8 _sram[];
|
|
extern u8 _esram[];
|
|
#define _sram_size (_esram - _sram)
|
|
|
|
extern u8 _dram[];
|
|
|
|
extern u8 _timestamp[];
|
|
extern u8 _etimestamp[];
|
|
#define _timestamp_size (_etimestamp - _timestamp)
|
|
|
|
extern u8 _preram_cbmem_console[];
|
|
extern u8 _epreram_cbmem_console[];
|
|
#define _preram_cbmem_console_size \
|
|
(_epreram_cbmem_console - _preram_cbmem_console)
|
|
|
|
extern u8 _stack[];
|
|
extern u8 _estack[];
|
|
#define _stack_size (_estack - _stack)
|
|
|
|
extern u8 _cbfs_cache[];
|
|
extern u8 _ecbfs_cache[];
|
|
#define _cbfs_cache_size (_ecbfs_cache - _cbfs_cache)
|
|
|
|
extern u8 _payload[];
|
|
extern u8 _epayload[];
|
|
#define _payload_size (_epayload - _payload)
|
|
|
|
/* Careful: _e<stage> and _<stage>_size only defined for the current stage! */
|
|
extern u8 _bootblock[];
|
|
extern u8 _ebootblock[];
|
|
#define _bootblock_size (_ebootblock - _bootblock)
|
|
|
|
extern u8 _romstage[];
|
|
extern u8 _eromstage[];
|
|
#define _romstage_size (_eromstage - _romstage)
|
|
|
|
extern u8 _ramstage[];
|
|
extern u8 _eramstage[];
|
|
#define _ramstage_size (_eramstage - _ramstage)
|
|
|
|
/* "program" always refers to the current execution unit, except for x86 ROM. */
|
|
extern u8 _program[];
|
|
extern u8 _eprogram[];
|
|
#define _program_size (_eprogram - _program)
|
|
|
|
/* Arch-specific, move to <arch/symbols.h> if they become too many. */
|
|
|
|
extern u8 _ttb[];
|
|
extern u8 _ettb[];
|
|
#define _ttb_size (_ettb - _ttb)
|
|
|
|
extern u8 _ttb_subtables[];
|
|
extern u8 _ettb_subtables[];
|
|
#define _ttb_subtables_size (_ettb_subtables - _ttb_subtables)
|
|
|
|
extern u8 _dma_coherent[];
|
|
extern u8 _edma_coherent[];
|
|
#define _dma_coherent_size (_edma_coherent - _dma_coherent)
|
|
|
|
#endif /* __SYMBOLS_H */
|