提交 3daa7c7b 编写于 作者: V Vlad Zakharov 提交者: Alexey Brodkin

arc: use timer driver for ARC boards

This commit replaces legacy timer code with usage of arc timer
driver.

It removes arch/arc/lib/time.c file and selects CONFIG_CLK,
CONFIG_TIMER and CONFIG_ARC_TIMER options for all ARC boards by default.
Therefore we remove CONFIG_CLK option from less common axs101 and
axs103 defconfigs.

Also it removes legacy CONFIG_SYS_TIMER_RATE config symbol from
axs10x.h, tb100.h and nsim.h configs files as it is no longer required.
Signed-off-by: NVlad Zakharov <vzakhar@synopsys.com>
Reviewed-by: NSimon Glass <sjg@chromium.org>
上级 0c77092e
...@@ -13,6 +13,9 @@ config ARC ...@@ -13,6 +13,9 @@ config ARC
select HAVE_PRIVATE_LIBGCC select HAVE_PRIVATE_LIBGCC
select SUPPORT_OF_CONTROL select SUPPORT_OF_CONTROL
select ARCH_EARLY_INIT_R select ARCH_EARLY_INIT_R
select CLK
select TIMER
select ARC_TIMER
config ARM config ARM
bool "ARM architecture" bool "ARM architecture"
......
...@@ -18,7 +18,6 @@ obj-y += memcmp.o ...@@ -18,7 +18,6 @@ obj-y += memcmp.o
obj-y += memcpy-700.o obj-y += memcpy-700.o
obj-y += memset.o obj-y += memset.o
obj-y += reset.o obj-y += reset.o
obj-y += timer.o
obj-y += ints_low.o obj-y += ints_low.o
obj-y += init_helpers.o obj-y += init_helpers.o
......
/*
* Copyright (C) 2013-2014 Synopsys, Inc. All rights reserved.
*
* SPDX-License-Identifier: GPL-2.0+
*/
#include <asm/arcregs.h>
#define NH_MODE (1 << 1) /* Disable timer if CPU is halted */
int timer_init(void)
{
write_aux_reg(ARC_AUX_TIMER0_CTRL, NH_MODE);
/* Set max value for counter/timer */
write_aux_reg(ARC_AUX_TIMER0_LIMIT, 0xffffffff);
/* Set initial count value and restart counter/timer */
write_aux_reg(ARC_AUX_TIMER0_CNT, 0);
return 0;
}
unsigned long timer_read_counter(void)
{
return read_aux_reg(ARC_AUX_TIMER0_CNT);
}
...@@ -19,7 +19,6 @@ CONFIG_OF_CONTROL=y ...@@ -19,7 +19,6 @@ CONFIG_OF_CONTROL=y
CONFIG_OF_EMBED=y CONFIG_OF_EMBED=y
CONFIG_NET_RANDOM_ETHADDR=y CONFIG_NET_RANDOM_ETHADDR=y
CONFIG_DM=y CONFIG_DM=y
CONFIG_CLK=y
CONFIG_SYS_I2C_DW=y CONFIG_SYS_I2C_DW=y
CONFIG_MMC=y CONFIG_MMC=y
CONFIG_MMC_DW=y CONFIG_MMC_DW=y
......
...@@ -18,7 +18,6 @@ CONFIG_OF_CONTROL=y ...@@ -18,7 +18,6 @@ CONFIG_OF_CONTROL=y
CONFIG_OF_EMBED=y CONFIG_OF_EMBED=y
CONFIG_NET_RANDOM_ETHADDR=y CONFIG_NET_RANDOM_ETHADDR=y
CONFIG_DM=y CONFIG_DM=y
CONFIG_CLK=y
CONFIG_SYS_I2C_DW=y CONFIG_SYS_I2C_DW=y
CONFIG_MMC=y CONFIG_MMC=y
CONFIG_MMC_DW=y CONFIG_MMC_DW=y
......
...@@ -11,8 +11,6 @@ ...@@ -11,8 +11,6 @@
/* /*
* CPU configuration * CPU configuration
*/ */
#define CONFIG_SYS_TIMER_RATE CONFIG_SYS_CLK_FREQ
#define ARC_FPGA_PERIPHERAL_BASE 0xE0000000 #define ARC_FPGA_PERIPHERAL_BASE 0xE0000000
#define ARC_APB_PERIPHERAL_BASE 0xF0000000 #define ARC_APB_PERIPHERAL_BASE 0xF0000000
#define ARC_DWMMC_BASE (ARC_FPGA_PERIPHERAL_BASE + 0x15000) #define ARC_DWMMC_BASE (ARC_FPGA_PERIPHERAL_BASE + 0x15000)
......
...@@ -9,11 +9,6 @@ ...@@ -9,11 +9,6 @@
#include <linux/sizes.h> #include <linux/sizes.h>
/*
* CPU configuration
*/
#define CONFIG_SYS_TIMER_RATE CONFIG_SYS_CLK_FREQ
/* /*
* Memory configuration * Memory configuration
*/ */
......
...@@ -9,11 +9,6 @@ ...@@ -9,11 +9,6 @@
#include <linux/sizes.h> #include <linux/sizes.h>
/*
* CPU configuration
*/
#define CONFIG_SYS_TIMER_RATE CONFIG_SYS_CLK_FREQ
/* /*
* Memory configuration * Memory configuration
*/ */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册