/***********************************************************************
Copyright © 2019 Jean Michault.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see .
*************************************************************************/
#include
#include
#include
#include
#include
#include
#include
#include "CCDebugger.h"
void writeHexLine(FILE * fic,uint8_t *buf, int len,int offset)
{
int i=0;
for(i=0 ; i>8)&0xff);
fprintf(fic,":%02X%04X00",len,offset);
for(int i=0 ; i= argc ) { helpo(); exit(1); }
FILE * ficout = fopen(argv[optind],"w");
if(!ficout) { fprintf(stderr," Can't open file %s.\n",argv[optind]); exit(1); }
// initialize GPIO ports
cc_init(rePin,dcPin,ddPin);
// enter debug mode
cc_enter();
// get ChipID :
uint16_t ID;
ID = cc_getChipID();
printf(" ID = %04x.\n",ID);
uint16_t offset=0;
uint8_t bank=0;
int progress=1;
// int nbread=0;
for( bank=0 ; bank<8 ; bank++)
{
printf(".");fflush(stdout);
if(! (bank&1))
{
uint8_t sum=2+4+(bank/2);
fprintf(ficout,":02000004%04X%02X\n",bank/2,(-sum)&255 );
}
offset=0;
int len=0;
uint8_t buf[17];
for ( uint16_t i=0 ; i<32 ; i++ )
{
do
{
read1k(bank,i*1024, buf1);
read1k(bank,i*1024, buf2);
// nbread++;
} while(memcmp(buf1,buf2,1024));
for(uint16_t j=0 ; j<64 ; j++)
writeHexLine(ficout,buf1+j*16, 16,(bank&1)*32*1024+ i*1024+j*16);
printf("\r reading %dk/256k",progress++);fflush(stdout);
}
}
// fprintf(stderr,"nbread=%d\n",nbread);
fprintf(ficout,":00000001FF\n");
// exit from debug
cc_setActive(false);
fclose(ficout);
}