Port of flash_cc2531 to FreeBSD. This is likely more just include a wiringPi compatible library for FreeBSD. Any new files are BSD licensed and NOT GPLv3 license.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

144 lines
3.7 KiB

  1. /***********************************************************************
  2. Copyright © 2019 Jean Michault.
  3. This program is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation, either version 3 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program. If not, see <https://www.gnu.org/licenses/>.
  13. *************************************************************************/
  14. #include <wiringPi.h>
  15. #include <stdlib.h>
  16. #include <stdio.h>
  17. #include <stdbool.h>
  18. #include <string.h>
  19. #include <stdint.h>
  20. #include <unistd.h>
  21. #include "CCDebugger.h"
  22. void writeHexLine(FILE * fic,uint8_t *buf, int len,int offset)
  23. {
  24. int i=0;
  25. for(i=0 ; i<len ; i++)
  26. if(buf[i] != 0xff) break;
  27. if(i==len) return;
  28. int sum=len+(offset&0xff)+((offset>>8)&0xff);
  29. fprintf(fic,":%02X%04X00",len,offset);
  30. for(int i=0 ; i<len;i++)
  31. {
  32. fprintf(fic,"%02X",buf[i]);
  33. sum += buf[i];
  34. }
  35. fprintf(fic,"%02X\n",(-sum)&0xff);
  36. }
  37. uint8_t buf1[1024];
  38. uint8_t buf2[1024];
  39. void read1k(int bank,uint16_t offset,uint8_t * buf)
  40. {
  41. // get FMAP
  42. uint8_t res = cc_exec2(0xE5, 0xC7);
  43. // select bank
  44. res = (res & 0xF8) | (bank & 0x07);
  45. res = cc_exec3(0x75, 0xC7, res); // MOV direct,#data
  46. // Setup DPTR
  47. cc_execi( 0x90, 0x8000+offset ); // MOV DPTR,#data16
  48. for(int i=0 ; i<1024 ;i++)
  49. {
  50. res = cc_exec ( 0xE0 ); // MOVX A,@DPTR
  51. buf[i] = res;
  52. res = cc_exec ( 0xA3 ); // INC DPTR
  53. }
  54. }
  55. void helpo()
  56. {
  57. fprintf(stderr,"usage : cc_read [-d pin_DD] [-c pin_DC] [-r pin_reset] out_file\n");
  58. fprintf(stderr," -c : change pin_DC (default 27)\n");
  59. fprintf(stderr," -d : change pin_DD (default 28)\n");
  60. fprintf(stderr," -r : change reset pin (default 24)\n");
  61. }
  62. int main(int argc,char *argv[])
  63. {
  64. int opt;
  65. int rePin=-1;
  66. int dcPin=-1;
  67. int ddPin=-1;
  68. while( (opt=getopt(argc,argv,"d:c:r:h?")) != -1)
  69. {
  70. switch(opt)
  71. {
  72. case 'd' : // DD pinglo
  73. ddPin=atoi(optarg);
  74. break;
  75. case 'c' : // DC pinglo
  76. dcPin=atoi(optarg);
  77. break;
  78. case 'r' : // restarigi pinglo
  79. rePin=atoi(optarg);
  80. break;
  81. case 'h' : // helpo
  82. case '?' : // helpo
  83. helpo();
  84. exit(0);
  85. break;
  86. }
  87. }
  88. if( optind >= argc ) { helpo(); exit(1); }
  89. FILE * ficout = fopen(argv[optind],"w");
  90. if(!ficout) { fprintf(stderr," Can't open file %s.\n",argv[optind]); exit(1); }
  91. // initialize GPIO ports
  92. cc_init(rePin,dcPin,ddPin);
  93. // enter debug mode
  94. cc_enter();
  95. // get ChipID :
  96. uint16_t ID;
  97. ID = cc_getChipID();
  98. printf(" ID = %04x.\n",ID);
  99. uint16_t offset=0;
  100. uint8_t bank=0;
  101. int progress=1;
  102. // int nbread=0;
  103. for( bank=0 ; bank<8 ; bank++)
  104. {
  105. printf(".");fflush(stdout);
  106. if(! (bank&1))
  107. {
  108. uint8_t sum=2+4+(bank/2);
  109. fprintf(ficout,":02000004%04X%02X\n",bank/2,(-sum)&255 );
  110. }
  111. offset=0;
  112. int len=0;
  113. uint8_t buf[17];
  114. for ( uint16_t i=0 ; i<32 ; i++ )
  115. {
  116. do
  117. {
  118. read1k(bank,i*1024, buf1);
  119. read1k(bank,i*1024, buf2);
  120. // nbread++;
  121. } while(memcmp(buf1,buf2,1024));
  122. for(uint16_t j=0 ; j<64 ; j++)
  123. writeHexLine(ficout,buf1+j*16, 16,(bank&1)*32*1024+ i*1024+j*16);
  124. printf("\r reading %dk/256k",progress++);fflush(stdout);
  125. }
  126. }
  127. // fprintf(stderr,"nbread=%d\n",nbread);
  128. fprintf(ficout,":00000001FF\n");
  129. // exit from debug
  130. cc_setActive(false);
  131. fclose(ficout);
  132. }