avr-gcc-list
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

RE: [avr-gcc-list] srec_cat help request


From: Schwichtenberg, Knut
Subject: RE: [avr-gcc-list] srec_cat help request
Date: Thu, 5 Apr 2007 09:31:47 +0200

Larry,
 
I have not tried, but at 31.03.06 Uwe Fechner came around here with the same problem. He solved the problem and on his last email he showed his makefile which puts the CRC behind the last used byte of code.
 

# Create final output files (.hex, .eep) from ELF output file.

%.hex: %.elf

@echo

@echo $(MSG_FLASH) $@

$(OBJCOPY) -O $(FORMAT) -R .eeprom $< $@

mv $@ $(TARGET).org.hex

srec_cat $(TARGET).org.hex -Little_Endian_CRC16 -max $(TARGET).org.hex -Output $(TARGET).hex

 
I'm pretty sure he also showed the algorithm of the used AVR-CRC, but could not find it on his web.
 
Maybe that helps.
 
Cheers
 
Knut


From: address@hidden [mailto:address@hidden On Behalf Of larry barello
Sent: Thursday, April 05, 2007 12:12 AM
To: address@hidden
Subject: [avr-gcc-list] srec_cat help request

I am updating my boot-loader to perform a CRC check across the application – it will stay in the BL if the CRC is bad.

 

I am trying to use srec_cat to generate the CRC value.  I am having no success getting the CRC value to match what the bootloader calculates.  Since srec_cat operation is opaque to me, I am asking for some help.

 

How do I get srec_cat to calculate a CRC value from 0 to (lets say) 0x1F7FD and plop that value down in 0x1F7FE?  I.e. deposit the CRC into the last two bytes prior to my bootloader (2k byte, m128).

 

This is the command line I am using w/o luck (well, *something* is getting deposited…)

 

srec_cat $(TARGET).hex -Intel -fill 0xFF 0 0x1F7FE -Little_Endian_CRC16 0x1F7FE -Cyclic_Redundancy_Check_16_XMODEM -Output $(TARGET).hex -Intel

 

Does the above process the CRC over the entire address range?  Or just the extents of the input file?  Srec_cat isn’t clear on that.

 

Has anyone used these tools to do this?  The only example I have uses the application to check itself – it “knows” it’s extents because the linker provides that.  Unfortunately the boot-loader doesn’t have access to that information…

 

Alternatively if I could get srec_cat to put both the maximum extent and the CRC near the end of FLASH, I could adjust my boot-loader to read those values in generating the CRC.

 

Thanks in advance.


reply via email to

[Prev in Thread] Current Thread [Next in Thread]