联合体在嵌入式开发中的妙用

联合体在嵌入式开发中的妙用,第1张

1. 检测当前处理器是大小端模式

#include 
#include 
#include 

typedef union diver
{
   unsigned int  all;      // all中存放要进行分离高低字节的数据
   unsigned char ch[4];    // char占一个字节,所以all与数组ch占的字节数相同
}DIVIDER;

int main()
{
  DIVIDER divider;
  divider.all = 0x11223344;
  
  if(0x44 == divider.ch[0])
  {
     printf("little endian \n");
  }
  else
  {
      printf("big endian \n");
  }

  return 0;
}

2. 按字节分离一个WORD或者DWORD数据

#include 
#include 
#include 

typedef union diver
{
   unsigned int  all;      // all中存放要进行分离高低字节的数据
   unsigned char ch[4];    // char占一个字节,所以all与数组ch占的字节数相同
}DIVIDER;

int main()
{
  int i = 0;
  DIVIDER divider;
  unsigned char DIV[4];

  divider.all = 0x11223344;

  /* 下面通过访问divider中数组ch的数据来取出高低字节的数据 */
  for(i = 0; i < 4; i++)
  {
      DIV[i] = divider.ch[i];
      printf("DIV[%d] =0x%x \n",i,DIV[i]);
  }
    return 0;
}

3.硬件寄存器封装

#include 
#include 
#include 

typedef union ISP_BLC_REG
{
  unsigned int  all;
  struct
  {
  unsigned int bit0:2;
  unsigned int bit1:2;
  unsigned int bit2:2;
  unsigned int bit3:2;
  unsigned int bit4:2;
  unsigned int bit5:2;
  unsigned int bit6:2;
  unsigned int bit7:2;
  unsigned int bit8:2;
  unsigned int bit9:2;
  unsigned int bit10:2;
  unsigned int bit11:2;
  unsigned int bit12:2;
  unsigned int bit13:2;
  unsigned int bit14:2;
  unsigned int bit15:2;
  };

}ISP_BLC_REG;

typedef union ISP_AWB_REG
{
  unsigned int  all;
  struct
  {
  unsigned int bit0:2;
  unsigned int bit1:2;
  unsigned int bit2:2;
  unsigned int bit3:2;
  unsigned int bit4:2;
  unsigned int bit5:2;
  unsigned int bit6:2;
  unsigned int bit7:2;
  unsigned int bit8:2;
  unsigned int bit9:2;
  unsigned int bit10:2;
  unsigned int bit11:2;
  unsigned int bit12:2;
  unsigned int bit13:2;
  unsigned int bit14:2;
  unsigned int bit15:2;
  };
};

}ISP_AWB_REG;

typedef struct isp_reg
{
  volatile   ISP_AWB_REG     isp_blc;
  unsigned   int             rev[2];
  volatile   ISP_BLC_REG     isp_awb;
}ISP_REG_S;


int main()
{
  ISP_REG_S *gst_isp = NULL;

  gst_isp = (ISP_REG_S *)malloc(sizeof(ISP_REG_S));
  if(NULL == gst_isp)
  {
    printf("gst_isp malloc is fail!\n");
    return -1;
  }

  gst_isp->isp_blc.all = 0x11111111;

  printf("gst_isp  =0x%x\n",gst_isp);
  printf("gst_isp->isp_blc  =0x%x\n",&gst_isp->isp_blc);
  printf("gst_isp->isp_awb  =0x%x\n",&gst_isp->isp_awb);

  printf("gst_isp->isp_blc.bit0  =0x%x\n",gst_isp->isp_blc.bit0);

  gst_isp->isp_blc.bit0 = 0x0;

  printf("gst_isp->isp_blc.bit0  =0x%x\n",gst_isp->isp_blc.bit0);

  if(gst_isp != NULL)
  {
    free(gst_isp);
  }
  
  return 0;
}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/717803.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-25
下一篇 2022-04-25

发表评论

登录后才能评论

评论列表(0条)

保存