ee icon indicating copy to clipboard operation
ee copied to clipboard

data not written on stm32f103c8t6?

Open TecDroiD opened this issue 2 years ago • 11 comments

Hi,

i'm currently trying to write and read a data structure into eeprom which looks basically like this

` typedef struct s_machinecfg { uint8_t version, uint16_t datax, uint16_t datay, .. } t_machinecfg, *p_machinecfg;

typedef struct s_machine { t_machinecfg config; .. } t_machine, *p_machine; ...

void read_config() { ee_read(0, sizeof(t_machinecfg), &self.config); if (self.config.version != stdconfig.version) { memcpy(&self.config, &std_config, sizeof(t_machinecfg)); write_config(); } } void write_config() { ee_format(0); ee_WriteToRAM(0, sizeof(t_machinecfg), &self.config); ee_commit(); }

... t_machine machine;

ee_init(); read_config();

`

later, I want to alter some values in my configuration and save it using write_config() but every time I restart the controller, I get the unaltered data. If I change my stdconfig in the program, former data is displayed, so first write must work.. but why doesn't the second one do?

Do you have any idea what my problem could be?

my eeConfig.h looks this way: ` #ifndef __EECONFIG_H #define __EECONFIG_H

#define _EE_USE_FLASH_PAGE_OR_SECTOR (63) #define _EE_USE_RAM_BYTE (1024) #define _EE_VOLTAGE FLASH_VOLTAGE_RANGE_3 // use in some devices #endif `

TecDroiD avatar Dec 10 '23 10:12 TecDroiD

hi. because you should not use format

nimaltd avatar Dec 12 '23 18:12 nimaltd

Well I just tried format it didn't work before. Removed format now but same effect.

TecDroiD avatar Dec 13 '23 06:12 TecDroiD

And remove if (self.config.version != stdconfig.version) { memcpy(&self.config, &std_config, sizeof(t_machinecfg)); And try again. And debug step by step to see what is happening. It seems ok.

nimaltd avatar Dec 13 '23 06:12 nimaltd

i debugged without my autowrite mechanics and it seems that after reading the first byte is 0 instead 0x10..

TecDroiD avatar Dec 13 '23 07:12 TecDroiD

Let me a while to check.

nimaltd avatar Dec 13 '23 07:12 nimaltd

@TecDroiD I have updated "ee.c". please check again and tell me the result. thanks

nimaltd avatar Dec 13 '23 08:12 nimaltd

did you check? @TecDroiD

nimaltd avatar Dec 16 '23 11:12 nimaltd

sorry, was off for a few days. first short experiment doesn't look promising but I promise to do a complete debug today.

TecDroiD avatar Dec 16 '23 11:12 TecDroiD

someone broke my blue pill. got a new one now.. and I cleaned the project twice between several debuggings and now it seems to work using uint8_t as first entry in my struct. may I ask a stupid question? in ee_read you do read the data using *data = ... and increase the pointer after. then you write to ram buffer using ee_ram[i]. Is there any reason I can't see why you didn't use data[i], too?

TecDroiD avatar Dec 20 '23 14:12 TecDroiD

I am so glad it works. no reason :)

nimaltd avatar Dec 23 '23 08:12 nimaltd

I have updated the LIB. please try again for any devices you have.

nimaltd avatar Mar 28 '24 09:03 nimaltd