Support Board: BK7236
Timer
Project Overview
General purpose timer groups TIMG0 and TIMG1 each contain three timers, each with a 32-bit up-counter. The three counters per timer group are driven by a 4-bit prescaler. General purpose timers can be used to trigger an interrupt after a set period or act as a hardware clock.
Each TIMG module has the following characteristics:
3 timer (Timer0/1/2)
3 32-bit up-counters
4-bit prescaler used to divide the counter clock frequency by a factor between 1 and 16
The real-time value of the counter can be read
Hardware Requirements
NA
Configure and Build
Configure the Project
NA
Build
Enter the following command in the Armino root directory to compile:
> make bk7236 PROJECT=examples/peripherals/timer
Build different APP version
If you want to run a secure upgrade, it is recommended to compile twice with different APP_VERSION, for example:
When compiling for the first time, APP_VERSION=”v1.0”, the generated all-app.bin is used for burning.
When compiling for the second time, APP_VERSION=”v2.0”, the generated ota.bin is used for upgrade.
You can determine the currently running version by checking the APP Version in the startup log. The version used can also be judged by printing time:
`
bk_init:I(0):armino app init: Jul 21 2023 10:12:47
bk_init:I(2):APP Version: v1.0
`
Connect UART
UART0 is used for:
BKFIL to download images
Flash all-app.bin
Burn Armino/build/secureboot/bk7236/all-app.bin to the board using BKFIL.
Running and Output
Reset board
Case - Timer
log Output
os:I(0):mem_type start end size
os:I(0):-------- -------- -------- --------
os:I(0):itcm 0x0 0x3c58 15448
os:I(0):dtcm 0x20000000 0x20001908 6408
os:I(0):ram 0x28000000 0x2807ebf8 519160
os:I(0):non_heap 0x28000000 0x2800fcb0 64688
os:I(0):iram 0x28000000 0x28000814 2068
os:I(0):data 0x28000814 0x280011b0 2460
os:I(0):bss 0x280011c0 0x2800fcb0 60144
os:I(0):non_cache 0x2800fcb0 0x2800fcb0 0
os:I(0):heap 0x2800fcb0 0x2807ebf8 454472
os:I(0):psram 0x60700000 0x60780000 524288
flash:I(0):id=0xc84016
flash:I(0):write status reg:38, status_reg_size:1
I(0):ate enabled is 1
I(0):driver_init end
init:I(0):reason - deep sleep gpio
init:I(0):regs - 3, 3, 0
init:I(0):armino rev:
init:I(0):armino soc id:53434647_72360001
init:I(0):trng enable
os:I(0):prvHeapInit-psram start addr:0x60700000, size:524288
mailbox:I(0):mailbox_config
mailbox:I(0):bk_mailbox_recv_callback_register
mailbox:I(0):bk_mailbox_recv_callback_register
init:I(0):Intialize random stack guard.
os:I(0):create main, tcb=280118a0, stack=[28010878-28011878:4096], prio=5
I(0):start user app thread.
os:I(0):create app, tcb=28012948, stack=[28011920-28012920:4096], prio=2
os:I(0):os time(0ms).
os:I(0):base aon rtc time: 0:46
os:I(0):create IDLE, tcb=20000330, stack=[2000038c-2000098c:1536], prio=0
os:I(0):create Tmr Svc, tcb=2000098c, stack=[200009e8-20000fe8:1536], prio=5
timer:E(0):timer0 is reserved for us timer!
timer:E(2):timer0 is reserved for us timer!
[11:05:29.498]收←◆timer_ex:I(1844):timer0(0) enter timer0_example_isr
timer_ex:I(1844):current counter value:2844
timer_ex:I(1844):period counter value:52000000
timer_ex:I(1844):timer0-5 enable status:0x0
timer_ex:I(1844):current counter value(0)
timer_ex:I(1844):timer0-5 enable status:0x1
timer_ex:I(1844):current counter value(101105)
[11:05:31.506]收←◆timer_ex:I(3680):timer0(0) enter timer0_example_isr
timer_ex:I(3680):current counter value:1795
timer_ex:I(3680):period counter value:52000000
timer_ex:I(3680):timer0-5 enable status:0x0
timer_ex:I(3680):current counter value(0)
timer_ex:I(3680):timer0-5 enable status:0x1
timer_ex:I(3680):current counter value(101244)
[11:05:32.524]收←◆timer_ex:I(4602):timer1(1) enter timer1_example_isr
timer_ex:I(4602):current counter value:2132
timer_ex:I(4602):period counter value:26000000
timer_ex:I(4602):timer0-5 enable status:0x2