diff options
author | Daniel Friesel <daniel.friesel@uos.de> | 2022-07-21 12:44:43 +0200 |
---|---|---|
committer | Daniel Friesel <daniel.friesel@uos.de> | 2022-07-21 12:44:43 +0200 |
commit | e2d191ebe69745fe658df8c56be2f8d3c4e7af47 (patch) | |
tree | 321fb7db3a557d4eb60e92932480466e707d3c66 /include/arch | |
parent | 68f92431e5706b4bed64ad37f0f26e8eef57c11e (diff) |
tc1796: it's working!
Diffstat (limited to 'include/arch')
-rw-r--r-- | include/arch/infineon-tc1796-mock/driver/counter.h | 12 |
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 ©); + 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; } }; |