From 9a6687278864e0ad1562587eb3290a1c42891d0b Mon Sep 17 00:00:00 2001 From: forth32 Date: Thu, 23 Feb 2017 21:41:37 +0300 Subject: [PATCH] =?UTF-8?q?=D0=98=D1=81=D0=BF=D1=80=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=20=D0=B0=D0=BB=D0=B3=D0=BE=D1=80=D0=B8=D1=82=D0=BC?= =?UTF-8?q?=20=D0=BF=D0=BE=D0=B8=D1=81=D0=BA=D0=B0=20=D1=80=D0=B0=D0=B7?= =?UTF-8?q?=D0=B4=D0=B5=D0=BB=D0=BE=D0=B2=20=D0=B2=20=D1=84=D0=B0=D0=B9?= =?UTF-8?q?=D0=BB=D0=B5=20=D0=B8=D1=81=D0=BA=D0=BB=D1=8E=D1=87=D0=B5=D0=BD?= =?UTF-8?q?=20=D0=BF=D0=BE=D0=B8=D1=81=D0=BA=20=D0=BB=D0=BE=D0=B6=D0=BD?= =?UTF-8?q?=D1=8B=D1=85=20=D1=80=D0=B0=D0=B7=D0=B4=D0=B5=D0=BB=D0=BE=D0=B2?= =?UTF-8?q?=20=D0=B2=20=D0=B4=D1=80=D0=B5=D0=B2=D0=BD=D0=B8=D1=85=20=D1=85?= =?UTF-8?q?=D1=83=D0=B0=D0=B2=D0=B5=D0=B5=D0=B2=D1=81=D0=BA=D0=B8=D1=85=20?= =?UTF-8?q?=D0=BF=D1=80=D0=BE=D1=88=D0=B8=D0=B2=D0=B0=D0=BB=D1=8C=D1=89?= =?UTF-8?q?=D0=B8=D0=BA=D0=B0=D1=85=20=D0=A0=D0=95-=D1=84=D0=BE=D1=80?= =?UTF-8?q?=D0=BC=D0=B0=D1=82=D0=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- build | 2 +- ptable.c | 24 +++++++++++++----------- 2 files changed, 14 insertions(+), 12 deletions(-) diff --git a/build b/build index 9d683f8..7b47338 100644 --- a/build +++ b/build @@ -1 +1 @@ -214 +221 diff --git a/ptable.c b/ptable.c index 1843a9a..04ce6e1 100644 --- a/ptable.c +++ b/ptable.c @@ -195,7 +195,7 @@ calc_crc16(npart); if (crcblocksize != crcsize(npart)) { printf("\n! Раздел %s (%02x) - неправильный размер блока контрольных сумм",ptable[npart].pname,ptable[npart].hd.code>>16); errflag=1; -} +} else if (memcmp(crcblock,ptable[npart].csumblock,crcblocksize) != 0) { printf("\n! Раздел %s (%02x) - неправильная блочная контрольная сумма",ptable[npart].pname,ptable[npart].hd.code>>16); @@ -230,8 +230,10 @@ if ((*(uint16_t*)ptable[npart].pimage) == 0xda78) { // продвигаем счетчик разделов npart++; -// отъезжаем немного назад -fseek(in,-16,SEEK_CUR); + +// отъезжаем, если надо, вперед на границу слова +res=ftell(in); +if ((res&3) != 0) fseek(in,(res+4)&(~3),SEEK_SET); } @@ -270,14 +272,14 @@ fread(prefix,0x5c,1,in); printf("\n Код файла прошивки: %i (0x%x)",*((uint32_t*)&prefix[0]),*((uint32_t*)&prefix[0])); // поиск остальных разделов -while (fread(&i,1,4,in) == 4) { - if (i != dpattern) { - fseek(in,-3,SEEK_CUR); - continue; // ищем разделитель - } - fseek(in,-4,SEEK_CUR); - extract(in); -} + +do { + if (fread(&i,1,4,in) != 4) break; // конец файла + if (i != dpattern) break; // образец не найден - конец цепочки разделов + fseek(in,-4,SEEK_CUR); // отъезжаем назад, на начало заголовка + extract(in); // извлекаем раздел +} while(1); + return npart; }