C语言位域联合体结构体操作寄存器实现51单片机Sbit和STM32位带操作方式输出高低电平

1.结构体联合体应用简单示例

代码如下(示例):

/*** 8位二进制显示 ***/
void toHex(u8 data)
{
    u8 bin = 0;
    for(int i=0;i<8;i++)
    {
        bin = data<<i;
        bin = bin >>7;
        if(bin)printf("1");
        else   printf("0");
    }
    printf("\r\n");
}
typedef union Byte {
	struct bit
	{
		u8 b7 : 1;
		u8 b6 : 1;
		u8 b5 : 1;
		u8 b4 : 1;
		u8 b3 : 1;
		u8 b2 : 1;
		u8 b1 : 1;
		u8 b0 : 1;
	}bit;
	u8 byte;
}Byte;

void UserMain(void)
{
	Byte reg;
	Byte *pReg;
	printf("\n---> user task \n");
	printf("sizeof(union Byte):%d\r\n",sizeof(union Byte));

	reg.byte = 0b10000001;
	toHex(reg.byte);

	printf("%d",reg.bit.b0);
	printf("%d",reg.bit.b1);
	printf("%d",reg.bit.b2);
	printf("%d",reg.bit.b3);
	printf("%d",reg.bit.b4);
	printf("%d",reg.bit.b5);
	printf("%d",reg.bit.b6);
	printf("%d",reg.bit.b7);
	printf("\r\n");

	pReg = &reg;
	pReg->byte = 0b10111101;
	toHex(pReg->byte);

	printf("%d",pReg->bit.b0);
	printf("%d",pReg->bit.b1);
	printf("%d",pReg->bit.b2);
	printf("%d",pReg->bit.b3);
	printf("%d",pReg->bit.b4);
	printf("%d",pReg->bit.b5);
	printf("%d",pReg->bit.b6);
	printf("%d",pReg->bit.b7);
	printf("\r\n");
	
	pReg->bit.b3 = 0;
	pReg->bit.b4 = 0;

	toHex(pReg->byte);
	
}

2.执行结果

如下:

---> user task 
sizeof(union Byte):1
10000001
10000001

10111101
10111101

10100101

3.在W800上面测试代码

如下:

typedef union Bytes {
	struct bits
	{
		u32 bit00 : 1;
		u32 bit01 : 1;
		u32 bit02 : 1;
		u32 bit03 : 1;
		u32 bit04 : 1;
		u32 bit05 : 1;
		u32 bit06 : 1;
		u32 bit07 : 1;
		u32 bit08 : 1;
		u32 bit09 : 1;
		u32 bit10 : 1;
		u32 bit11 : 1;
		u32 bit12 : 1;
		u32 bit13 : 1;
		u32 bit14 : 1;
		u32 bit15 : 1;
		u32 bit16 : 1;
		u32 bit17 : 1;
		u32 bit18 : 1;
		u32 bit19 : 1;
		u32 bit20 : 1;
		u32 bit21 : 1;
		u32 bit22 : 1;
		u32 bit23 : 1;
		u32 bit24 : 1;
		u32 bit25 : 1;
		u32 bit26 : 1;
		u32 bit27 : 1;
		u32 bit28 : 1;
		u32 bit29 : 1;
		u32 bit30 : 1;
		u32 bit31 : 1;	
	}bits;   
	u32 bytes;              
	u8  byte[4];      
}Bytes;// 其中bits、bytes、byte[4]、共用内存 4byte,都可以用于操作数据

//  GPIO数据寄存器、数据使能寄存器地址
Bytes *pPaDt = HR_GPIOA_DATA;
Bytes *pPbDt = HR_GPIOB_DATA;
Bytes *pPaEn = HR_GPIOA_DATA_EN;
Bytes *pPbEn = HR_GPIOB_DATA_EN;

void UserMain(void)
{
	u8 *VERSION = "\r\n--->Compile "__DATE__", "__TIME__"\r\n";
	printf("%s\r\n\r\n",VERSION);
	printf("\n---> user task \n");
	
	//  配置GPIO输出模式
	tls_gpio_cfg(WM_IO_PB_00, WM_GPIO_DIR_OUTPUT, WM_GPIO_ATTR_FLOATING);
	tls_gpio_cfg(WM_IO_PB_01, WM_GPIO_DIR_OUTPUT, WM_GPIO_ATTR_FLOATING);
	tls_gpio_cfg(WM_IO_PB_02, WM_GPIO_DIR_OUTPUT, WM_GPIO_ATTR_FLOATING);

	//  配置GPIOB 数据使能寄存器
	pPbEn->bytes = 0xFFFFFFFF;
	
	//  配置GPIOB 数据寄存器对应位的电平
	pPbDt->bits.bit00 = 1;              // WM_IO_PB_00
	pPbDt->bits.bit01 = 1;              // WM_IO_PB_01
	pPbDt->bits.bit02 = 1;              // WM_IO_PB_02

 	pPbDt->bits.bit00  = 0;
	tls_os_time_delay(HZ);
	pPbDt->bits.bit00  = 1;
	tls_os_time_delay(HZ);


	pPbDt->bits.bit01 = 0;
	tls_os_time_delay(HZ);
	pPbDt->bits.bit01 = 1;
	tls_os_time_delay(HZ);

	pPbDt->bits.bit02 = 0;
	tls_os_time_delay(HZ);
	pPbDt->bits.bit02 = 1;
	tls_os_time_delay(HZ);

	pPbDt->bits.bit00 = 0;
	pPbDt->bits.bit01 = 0;
	pPbDt->bits.bit02 = 0;
	tls_os_time_delay(HZ);
	pPbDt->bits.bit00 = 1;
	pPbDt->bits.bit01 = 1;
	pPbDt->bits.bit02 = 1;
	tls_os_time_delay(HZ);
}

4.执行结果

如下:

自行脑...
  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 可以回答这个问题。在使用 C 语言操作 STM32 寄存器时,需要使用特定的寄存器地址和位掩码来读取或寄存器的值。可以使用宏定义或结构体来简化操作。例如,使用宏定义可以定义一个 GPIO_Pin_ 的值为 x0001,然后使用位运算符来设置或清除 GPIO 的某个引脚。 ### 回答2: 使用C语言操作STM32寄存器的过程如下: 1. 包含头文件:首先在程序中包含stm32fxx.h头文件,其中xx代表所使用的具体型号的STM32。这个头文件中包含了对应型号的所有寄存器的定义和地址信息。 2. 配置寄存器:根据需要,使用宏定义或直接访问寄存器方式配置相应的寄存器。例如,可以使用宏定义来设置GPIO口的模式和参数,或者直接访问外设的控制寄存器来配置时钟、中断等。 3. 读取和寄存器:通过直接访问寄存器方式读取和入数据。使用特定寄存器的地址和位操作实现寄存器的读操作。例如,可以通过寄存器的特定位来设置相应的标志位,或者通过读取寄存器的特定位来获取状态信息。 4. 中断处理:对于使用中断的外设,需要配置中断使能和中断优先级,并在主程序中编中断处理函数。中断处理函数通常包含对寄存器的读操作,以响应相应的事件。 需要注意的是,使用C语言操作STM32寄存器需要对寄存器的地址和寄存器操作有一定的了解,并且根据具体的外设和功能需求进行相应的配置。此外,还需要阅读官方提供的参考手册和开发文档,以了解具体的寄存器定义和使用方法。 ### 回答3: 在使用C语言操作STM32寄存器时,我们首先需要了解寄存器的基本概念和功能。 寄存器是一种特殊的存储器,位于CPU内部,用于存储和处理数据。在STM32微控制器中,寄存器用于控制外设、IO口、时钟、中断等功能。 要使用C语言操作STM32寄存器,我们需要按照以下步骤进行: 1. 头文件引用:首先,我们需要引用STM32提供的相关头文件,通常是stm32fxxx.h,其中xxx代表具体的微控制器型号。 2. 定义寄存器:通过查阅相关手册或官方文档,我们可以找到需要操作寄存器地址和对应的位域。在C语言中,我们可以使用`volatile`关键字定义寄存器变量,确保编译器不会对其做优化。 例如,如果我们要操作GPIOB端口的控制寄存器GPIOB_CRH,可以通过以下代码进行定义: ``` volatile uint32_t* GPIOB_CRH = (volatile uint32_t*)0x40010C04; ``` 这里的`0x40010C04`是GPIOB_CRH寄存器的地址,`uint32_t`表示32位寄存器的数据类型。 3. 操作寄存器:通过寄存器变量,我们可以读取和寄存器的值。例如,要设置GPIOB_CRH寄存器的第8位和第9位为推挽输出模式,可以使用以下代码: ``` *GPIOB_CRH |= (0x3 << 8); ``` 这里使用了按位或运算符`|`将寄存器的第8位和第9位设置为1。通过适当的位运算,可以对寄存器进行各种操作。 需要注意的是,在使用C语言操作寄存器时,我们需要非常小心,确保不会与其他代码产生冲突或意外的结果。此外,还应该深入了解寄存器的功能和寄存器地址的定义,以确保正确操作。 总而言之,通过引用头文件、定义寄存器变量和使用位运算,我们可以使用C语言STM32寄存器进行操作,从而实现对外设、IO口、时钟等功能的控制。这种底层操作对于一些特定的任务和需求非常有用,但需要谨慎使用,以避免出现错误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值