在EEPROM里存储结构体的问题,?????????

2019-07-21 04:55发布

我调用STM32F4库函数里的EEPROM读写函数向EEPROM里写数据

当写入u8型数组的时候
 for(i=0;i<30;i++)ReadTmp=i+1;

  sEE_WriteBuffer(ReadTmp, FRMODVAILDFLGADDR, 30); //写信息区
 tmp=30;
 for(i=0;i<30;i++)ReadTmp=0;
sEE_ReadBuffer(ReadTmp, FRMODVAILDFLGADDR, &tmp);  
   
写入和读出的数据相同,

但是当我写入结构体的时候,发现读出的数据不是我写入的,全部是0,应该是没读正确,
根据u8型数组的测试,可以断定读写函数没错

下面是我结构体的定义
typedef struct
{
 union ASSEMBLY_TEST_CMD cmd; //输出 控制命令
 union ASSEMBLY_TEST_INPUT input; //输入 控制命令
  u8 StartTest:1;//开始测试标志
    struct   //需要掉电保存的数据
    {
u8 TestMethod:2;//1—方式一,2-方式二  
u8   res         :5; //保留
u16 OpenTime;//门开齐后延时的时间
u16 CloseTime;//门关齐后延时的时间
u16 TestCNT; //测试次数上限
u16 Stallcnt; //堵转次数上限
    }Method;
 u16 u16_OpenCnt; //开门次数
 u16 u16_OpenFullCnt;//开门到位次数
 u16 u16_CloseCnt;//关门次数
 u16 u16_CloseFullCnt;//关门到位次数
 u16 u16_Close23cnt;//关门2/3次数 
 u16 u16_uStallCnt;  //堵转次数
 u8  uTestResault;
 u16 Step;            //测试步骤

 u16 ControllerNum;   //控制器号
 u8 tmp_cdfull;       //关门到位标志
 u8 tmp_odfull;        //开门到位标志
 u16 TestTimeCnt;      //测试时间变量                                           // };
 u16 DelayCheckTime;
 u16 CmdSwTimeCnt;
 u16 uSeqTimeCnt;
 u8 cSeqStep;

}ASSEMBLY_TEST_STRUCT;
//===============================================================================


#define ASSEMBLY_TEST_STRUCT_DEFAULTS {
        0,
         0,
         0,
         0,
         0,
         5000,
         5000,
         1000,
         20,
         0,
         0,
         0,
         0,
         0,
         0,
         0,
         0,
         0,
         0,
         0,
         5000,
         5000,
         5000,
         5000,
         0,
        }

ASSEMBLY_TEST_STRUCT g_hAssemblyTestVar[2] = {ASSEMBLY_TEST_STRUCT_DEFAULTS,ASSEMBLY_TEST_STRUCT_DEFAULTS}; 
  
 
下面是我的读写操作

sEE_WriteBuffer((uint8_t*)&(g_hAssemblyTestVar[0].Method), FRMODADDR,sizeof(g_hAssemblyTestVar[0].Method));    
sEE_ReadBuffer((uint8_t*)&(g_hAssemblyTe.Method), FRMODADDR, &tmp); 

 g_hAssemblyTe.Method的值和g_hAssemblyTestVar[0].Method不一样, g_hAssemblyTe.Method全是0,

我使用的读写函数是库里的函数,路径是STM32F4xx_DSP_StdPeriph_Lib_V1.0.1UtilitiesSTM32_EVALSTM3240_41_G_EVAL里的stm324xg_eval_i2c_ee.c
请问这是哪里问题

记得以前使用51的时候直接读写结构体是可以的啊

 
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
15条回答
正点原子
1楼-- · 2019-07-21 05:46
[mw_shl_code=c,true]#define SAVE_ADDR_BASE 40 //保存校准参数 void TP_Save_Adjdata(void) { //保存校正结果! AT24CXX_WriteLenByte(SAVE_ADDR_BASE,*((u32*)&tp_dev.xfac),4); //保存x校正因素(将tp_dev.xfac的地址强制转换为u32类型,再取值) AT24CXX_WriteLenByte(SAVE_ADDR_BASE+4,*((u32*)&tp_dev.yfac),4); //保存y校正因素(将tp_dev.yfac的地址强制转换为u32类型,再取值) AT24CXX_WriteLenByte(SAVE_ADDR_BASE+8,(u16)tp_dev.xoff,2); //保存x偏移量 AT24CXX_WriteLenByte(SAVE_ADDR_BASE+10,(u16)tp_dev.yoff,2); //保存y偏移量 AT24CXX_WriteOneByte(SAVE_ADDR_BASE+12,tp_dev.touchtype); //保存触屏类型 AT24CXX_WriteOneByte(SAVE_ADDR_BASE+13,0X0A); //标记校准过了 } //得到保存在EEPROM里面的校准值 //返回值:1,成功获取数据 // 0,获取失败,要重新校准 u8 TP_Get_Adjdata(void) { u8 temp; temp=AT24CXX_ReadOneByte(SAVE_ADDR_BASE+13);//读取标记字,看是否校准过! if(temp==0X0A)//触摸屏已经校准过了 { *((u32*)&tp_dev.xfac)=AT24CXX_ReadLenByte(SAVE_ADDR_BASE,4); //得到x校准参数(将tp_dev.xfac的地址强制转换为u32类型,再赋值) *((u32*)&tp_dev.yfac)=AT24CXX_ReadLenByte(SAVE_ADDR_BASE+4,4); //得到y校准参数(将tp_dev.xfac的地址强制转换为u32类型,再赋值) tp_dev.xoff=(short)AT24CXX_ReadLenByte(SAVE_ADDR_BASE+8,2); //得到x偏移量 tp_dev.yoff=(short)AT24CXX_ReadLenByte(SAVE_ADDR_BASE+10,2); //得到y偏移量 tp_dev.touchtype=AT24CXX_ReadOneByte(SAVE_ADDR_BASE+12); //读取触屏类型标记 if(tp_dev.touchtype)//X,Y方向与屏幕相反 { CMD_RDX=0X90; CMD_RDY=0XD0; }else //X,Y方向与屏幕相同 { CMD_RDX=0XD0; CMD_RDY=0X90; } return 1; } return 0; } [/mw_shl_code] 参考下我们的.
正点原子
2楼-- · 2019-07-21 09:20
在结构体前面,加上
__packed关键字修饰下,再试试.
wang12zhe
3楼-- · 2019-07-21 14:21
回复【2楼】正点原子:
---------------------------------
原子哥,
你看看这里是不是有问题
sEE_WriteBuffer((uint8_t*)&(g_hAssemblyTestVar[0].Method), FRMODADDR,sizeof(g_hAssemblyTestVar[0].Method));    
sEE_ReadBuffer((uint8_t*)&(g_hAssemblyTe.Method), FRMODADDR, &tmp);

函数的第一个参数传递的是不是地址的地址?????
问题应该在这,但是我改成
(uint8_t*)(g_hAssemblyTestVar[0].Method)
(uint8_t)&(g_hAssemblyTestVar[0].Method)
都编译报错,  改咋办
正点原子
4楼-- · 2019-07-21 18:52
回复【3楼】wang12zhe:
---------------------------------
传送的是:g_hAssemblyTestVar[0].Method的地址
wang12zhe
5楼-- · 2019-07-21 21:33
 精彩回答 2  元偷偷看……
正点原子
6楼-- · 2019-07-22 01:59
回复【5楼】wang12zhe:
---------------------------------
默认是u32类型的
强制转换为u8*类型,否则MDK会报警告。

一周热门 更多>