coreboot arm: Define function for setting cntfrq register
Define functions for setting cntfrq register in arm and arm64 arch. This allows SoCs to set this register independent of the architecture being used. BUG=None BRANCH=None TEST=Compiles successfully for nyan and rush Change-Id: I93240419b2c012eee29a408deff34a42af943a63 Signed-off-by: Furquan Shaikh <furquan@google.com> Reviewed-on: https://chromium-review.googlesource.com/205580 Tested-by: Furquan Shaikh <furquan@chromium.org> Reviewed-by: Aaron Durbin <adurbin@chromium.org> Commit-Queue: Aaron Durbin <adurbin@chromium.org>
This commit is contained in:
parent
296fe6732c
commit
768463fef5
8 changed files with 134 additions and 3 deletions
|
|
@ -45,6 +45,7 @@ ifeq ($(CONFIG_ARCH_BOOTBLOCK_ARM),y)
|
|||
bootblock-y += div0.c
|
||||
bootblock-$(CONFIG_BOOTBLOCK_CONSOLE) += early_console.c
|
||||
bootblock-y += id.S
|
||||
bootblock-y += clock.c
|
||||
|
||||
$(obj)/arch/arm/id.bootblock.o: $(obj)/build.h
|
||||
|
||||
|
|
@ -78,6 +79,7 @@ romstage-y += memset.S
|
|||
romstage-y += memcpy.S
|
||||
romstage-y += memmove.S
|
||||
romstage-$(CONFIG_COLLECT_TIMESTAMPS) += timestamp.c
|
||||
romstage-y += clock.c
|
||||
|
||||
$(objcbfs)/romstage.debug: $$(romstage-objs) $(src)/arch/arm/romstage.ld $(obj)/ldoptions
|
||||
@printf " LINK $(subst $(obj)/,,$(@))\n"
|
||||
|
|
@ -104,6 +106,7 @@ ramstage-y += tables.c
|
|||
ramstage-y += memset.S
|
||||
ramstage-y += memcpy.S
|
||||
ramstage-y += memmove.S
|
||||
ramstage-y += clock.c
|
||||
|
||||
rmodules-y += memset.S
|
||||
rmodules-y += memcpy.S
|
||||
|
|
|
|||
36
src/arch/arm/clock.c
Normal file
36
src/arch/arm/clock.c
Normal file
|
|
@ -0,0 +1,36 @@
|
|||
/*
|
||||
* This file is part of the coreboot project.
|
||||
*
|
||||
* Copyright 2014 Google Inc.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* 3. The name of the author may not be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
#include <stdint.h>
|
||||
#include <arch/clock.h>
|
||||
|
||||
void set_cntfrq(uint32_t freq)
|
||||
{
|
||||
__asm__ __volatile__("mcr p15, 0, %0, c14, c0, 0\n" :: "r"(freq));
|
||||
}
|
||||
25
src/arch/arm/include/arch/clock.h
Normal file
25
src/arch/arm/include/arch/clock.h
Normal file
|
|
@ -0,0 +1,25 @@
|
|||
/*
|
||||
* 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 __ARM_CLOCK_H_
|
||||
#define __ARM_CLOCK_H_
|
||||
|
||||
void set_cntfrq(uint32_t);
|
||||
|
||||
#endif //__ARM_CLOCK_H_
|
||||
|
|
@ -28,7 +28,7 @@
|
|||
##
|
||||
#####################################################################################
|
||||
|
||||
lib_access = pstate.c sysctrl.c cache.c tlb.c misc.c
|
||||
lib_access = pstate.c sysctrl.c cache.c tlb.c misc.c clock.c
|
||||
|
||||
ifeq ($(CONFIG_ARCH_BOOTBLOCK_ARM_V8_64),y)
|
||||
bootblock-y += $(lib_access)
|
||||
|
|
|
|||
40
src/arch/arm64/armv8/lib/clock.c
Normal file
40
src/arch/arm64/armv8/lib/clock.c
Normal file
|
|
@ -0,0 +1,40 @@
|
|||
/*
|
||||
* This file is part of the coreboot project.
|
||||
*
|
||||
* Copyright 2014 Google Inc.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* 3. The name of the author may not be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*
|
||||
* clock.c: Functions for accessing clock and timer related registers
|
||||
* Reference: ARM Architecture Reference Manual, ARMv8-A edition
|
||||
*/
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
#include <arch/clock.h>
|
||||
|
||||
void set_cntfrq(uint32_t freq)
|
||||
{
|
||||
__asm__ __volatile__("msr cntfrq_el0, %0" :: "r"(freq));
|
||||
}
|
||||
25
src/arch/arm64/include/arch/clock.h
Normal file
25
src/arch/arm64/include/arch/clock.h
Normal file
|
|
@ -0,0 +1,25 @@
|
|||
/*
|
||||
* 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 __ARM_CLOCK_H_
|
||||
#define __ARM_CLOCK_H_
|
||||
|
||||
void set_cntfrq(uint32_t);
|
||||
|
||||
#endif //__ARM_CLOCK_H_
|
||||
|
|
@ -20,6 +20,7 @@
|
|||
#include <soc/addressmap.h>
|
||||
#include <soc/clock.h>
|
||||
#include <stdlib.h>
|
||||
#include <arch/clock.h>
|
||||
#include "clk_rst.h"
|
||||
#include "flow.h"
|
||||
#include "maincpu.h"
|
||||
|
|
@ -181,7 +182,7 @@ void clock_init_arm_generic_timer(void)
|
|||
{
|
||||
uint32_t freq = clock_get_osc_khz() * 1000;
|
||||
// Set the cntfrq register.
|
||||
__asm__ __volatile__("mcr p15, 0, %0, c14, c0, 0\n" :: "r"(freq));
|
||||
set_cntfrq(freq);
|
||||
|
||||
// Record the system timer frequency.
|
||||
write32(freq, &sysctr->cntfid0);
|
||||
|
|
|
|||
|
|
@ -20,6 +20,7 @@
|
|||
#include <soc/addressmap.h>
|
||||
#include <soc/clock.h>
|
||||
#include <stdlib.h>
|
||||
#include <arch/clock.h>
|
||||
#include "clk_rst.h"
|
||||
#include "flow.h"
|
||||
#include "maincpu.h"
|
||||
|
|
@ -181,7 +182,7 @@ void clock_init_arm_generic_timer(void)
|
|||
{
|
||||
uint32_t freq = clock_get_osc_khz() * 1000;
|
||||
// Set the cntfrq register.
|
||||
__asm__ __volatile__("mcr p15, 0, %0, c14, c0, 0\n" :: "r"(freq));
|
||||
set_cntfrq(freq);
|
||||
|
||||
// Record the system timer frequency.
|
||||
write32(freq, &sysctr->cntfid0);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue