summaryrefslogtreecommitdiff
path: root/include/arch
diff options
context:
space:
mode:
authorDaniel Friesel <daniel.friesel@uos.de>2022-07-21 12:44:43 +0200
committerDaniel Friesel <daniel.friesel@uos.de>2022-07-21 12:44:43 +0200
commite2d191ebe69745fe658df8c56be2f8d3c4e7af47 (patch)
tree321fb7db3a557d4eb60e92932480466e707d3c66 /include/arch
parent68f92431e5706b4bed64ad37f0f26e8eef57c11e (diff)
tc1796: it's working!
Diffstat (limited to 'include/arch')
-rw-r--r--include/arch/infineon-tc1796-mock/driver/counter.h12
1 files changed, 11 insertions, 1 deletions
diff --git a/include/arch/infineon-tc1796-mock/driver/counter.h b/include/arch/infineon-tc1796-mock/driver/counter.h
index b7330db..38d039e 100644
--- a/include/arch/infineon-tc1796-mock/driver/counter.h
+++ b/include/arch/infineon-tc1796-mock/driver/counter.h
@@ -6,23 +6,33 @@
#ifndef COUNTER_H
#define COUNTER_H
+#define STM_TIM0 (*(volatile unsigned int*)0xf0000210)
+#define STM_CAP (*(volatile unsigned int*)0xf000022c)
+
typedef unsigned int counter_value_t;
typedef unsigned int counter_overflow_t;
class Counter {
private:
Counter(const Counter &copy);
+ unsigned long long startvalue, stopvalue;
public:
counter_value_t value;
- volatile counter_overflow_t overflow;
+ counter_overflow_t overflow;
Counter() : overflow(0) {}
inline void start() {
+ startvalue = STM_TIM0;
+ startvalue += (unsigned long long)STM_CAP << 32;
}
inline void stop() {
+ stopvalue = STM_TIM0;
+ stopvalue += (unsigned long long)STM_CAP << 32;
+ value = (stopvalue - startvalue) & 0xffffffff;
+ overflow = (unsigned long long)(stopvalue - startvalue) >> 32;
}
};