底层抽象

地址描述:
16Bit MCU
存储形态:
在这里插入图片描述
寄存器:
在这里插入图片描述

&(0xFF0000)=0x24;
32Bit MCU
存储形态:
在这里插入图片描述
&(0x8000000)=0x50

寄存器:
在这里插入图片描述

volatile
/*
简单的说,就是不让编译器进行优化,即每次读取或者修改值的时候,都必须重新从内存或者寄存器中读取或者修改。
1、中断服务程序中修改的供其它程序检测的变量需要加volatile;
2、多任务环境下各任务间共享的标志应该加volatile;
3、存储器映射的硬件寄存器通常也要加volatile说明,因为每次对它的读写都可能由不同意义;
*/

/*一个参数既可以是const还可以是volatile吗?解释为什么 */
// 是的
// 一个例子是只读的状态寄存器。它是volatile因为它可能被意想不到地改变。它是const因为程序不应该试图去修改它。

/一个指针可以是volatile 吗?解释为什么。/
//是的
//尽管这并不很常见。一个例子是当一个中服务子程序修该一个指向一个buffer的指针时。

#define  __IO  volatile    
 
 /** RTC - Register Layout Typedef */
typedef struct {
  __IO uint32_t TSR;                               /**< RTC Time Seconds Register, offset: 0x0 */
  __IO uint32_t TPR;                               /**< RTC Time Prescaler Register, offset: 0x4 */
  __IO uint32_t TAR;                               /**< RTC Time Alarm Register, offset: 0x8 */
  __IO uint32_t TCR;                               /**< RTC Time Compensation Register, offset: 0xC */
  __IO uint32_t CR;                                /**< RTC Control Register, offset: 0x10 */
  __IO uint32_t SR;                                /**< RTC Status Register, offset: 0x14 */
  __IO uint32_t LR;                                /**< RTC Lock Register, offset: 0x18 */
  __IO uint32_t IER;                               /**< RTC Interrupt Enable Register, offset: 0x1C */
} RTC_Type, *RTC_MemMapPtr;
 
/** Peripheral RTC base address */
#define  RTC_BASE  (0x4003D000u) 
/** Peripheral RTC base pointer */
#define  RTC  ((RTC_Type *)RTC_BASE)

RTC->TSR=0x55;

-> 是一个整体,它是用于指向结构体、C++中的class等含有子数据的指针用来取子数据。换种说法,如果我们在C语言中定义了一个结构体,然后申明一个指针指向这个结构体,那么我们要用指针取出结构体中的数据,就要用到“->”.

struct Data
{
   int a,b,c;
};                        /*定义结构体*/
struct Data * p;          /*定义结构体指针*/
struct Data A = {1,2,3};  /*声明变量A*/
int x;                    /*声明一个变量x*/
p = &A ;                  /*让p指向A*/
x = p->a;             /*这句话的意思就是取出p所指向的结构体中包含的数据项a赋值给x*/
                      /*由于此时p指向A,因而 p->a == A.a,也就是1*/

对于一开始的问题 p = p->next;这应该出现在C语言的链表,这里的next应该是一个与p同类型的结构体指针,其定义格式应该是:

struct Data 
{
   int a;
   struct Data * next;
};/*定义结构体*/
main()
{
   struct Data * p;/*声明指针变量p*/
   p = p->next;/*将next中的值赋给p*/
}

案例Ⅰ:

#define READ_REG_U16(0x1000)     ((uint16_t) (*(volatile uint16_t *)(0x1000)))
/** An saradc command entry of a table. See SARADC register description.*/
typedef struct {
  /** [15:0]  */u16 target_adr;
  /** [30:16] */saradc_elem2_t e2;
  /** [47:32] */u16 trigger;
} saradc_table_list_entry;

   extern saradc_table_list_entry list_bemf_window_0[];

   void *done = (void *) READ_REG_U16(0x1000)   // 空指针类型

	if (done == list_bemf_window_0) 
	{
	}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值