]> Git Repo - J-u-boot.git/blame - drivers/timer/ast_ibex_timer.c
Merge patch series "dwc3: gadget: properly fix cache operations"
[J-u-boot.git] / drivers / timer / ast_ibex_timer.c
CommitLineData
4b0129e8
CWW
1// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright (c) 2024 Aspeed Technology Inc.
4 */
5
6#include <asm/csr.h>
7#include <asm/io.h>
8#include <dm.h>
9#include <errno.h>
10#include <timer.h>
11
12#define CSR_MCYCLE 0xb00
13#define CSR_MCYCLEH 0xb80
14
15static u64 ast_ibex_timer_get_count(struct udevice *dev)
16{
17 uint32_t cnt_l, cnt_h;
18
19 cnt_l = csr_read(CSR_MCYCLE);
20 cnt_h = csr_read(CSR_MCYCLEH);
21
22 return ((uint64_t)cnt_h << 32) | cnt_l;
23}
24
25static int ast_ibex_timer_probe(struct udevice *dev)
26{
27 return 0;
28}
29
30static const struct timer_ops ast_ibex_timer_ops = {
31 .get_count = ast_ibex_timer_get_count,
32};
33
34static const struct udevice_id ast_ibex_timer_ids[] = {
35 { .compatible = "aspeed,ast2700-ibex-timer" },
36 { }
37};
38
39U_BOOT_DRIVER(ast_ibex_timer) = {
40 .name = "ast_ibex_timer",
41 .id = UCLASS_TIMER,
42 .of_match = ast_ibex_timer_ids,
43 .probe = ast_ibex_timer_probe,
44 .ops = &ast_ibex_timer_ops,
45};
This page took 0.027471 seconds and 4 git commands to generate.