【实验环境】
·芯片:STM32F103RB
·电压3.3v
·内核频率72MHz,预取2周期
·IO速度配置50MHz(使得测量结果更准确)
·Keil 4.12
【实验目的】
1)GPIO可以由Bitband方式(由内核支持)或BSRR寄存器(由外设支持)来操作,都满足原子操作要求。
2)两者仿真时性能一致,单次操作均需要5指令周期,70ns。
3)待实测真实速度,及其和优化等级的关系。
【实验方法】
1)操作BSRR寄存器方法
#define PA7_ON GPIOA->BSRR =
1<<(7)
#define PA7_OFF GPIOA->BSRR =
1<<(7+16)
while (1)
{
PA7_ON A7_OFF;
PA7_ON A7_OFF;
PA7_ON A7_OFF;
PA7_ON A7_OFF;
}
2)Bitband方法(参考Alientek开发板资料)
#define BITBAND(addr, bitnum) ((addr &
0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2))
#define MEM_ADDR(addr) *((volatile unsigned long *)(addr))
#define BIT_ADDR(addr, bitnum) MEM_ADDR(BITBAND(addr, bitnum))
#define PAout(n) BIT_ADDR(GPIOA_ODR_Addr,n)
#define PA7 PAout(7)
while (1)
{
PA7=1 A7=0;
PA7=1 A7=0;
PA7=1 A7=0;
PA7=1 A7=0;
}
【实验数据】
|