]>
cvs.zerfleddert.de Git - rsbs2/blob - firmware.c
80e12e54f9ff73aaaa15449524dde10055601a7d
  11 #include "filesystem.h" 
  13 #define FINDSTR(addr, str) (!strncmp((char*)addr, str, strlen(str))) 
  17         unsigned char unknown0
; 
  18         unsigned char unknown1
; 
  19         unsigned char right_rw
; 
  20         unsigned char rw_mask
; 
  22         unsigned char unknown5
; 
  23         unsigned char unknown6
; 
  24         unsigned char unknown7
; 
  29 #define PROP_ACTION_TRUE        (1<<0) 
  30 #define PROP_ACTION_FALSE       (1<<1) 
  31 #define PROP_ACTION_RO          (1<<2) 
  32 #define PROP_ACTION_RW          (1<<3) 
  34 #define PROP_STATUS_NOTFOUND    (0) 
  35 #define PROP_STATUS_WRONGTYPE   (1<<0) 
  36 #define PROP_STATUS_WRONGRIGHTS (1<<1) 
  37 #define PROP_STATUS_SAMEVAL     (1<<2) 
  38 #define PROP_STATUS_SUCCESS     (1<<3) 
  44         struct propaction 
*next
; 
  47 void show_properties(unsigned char *fw
, int len
) 
  49         struct file_entry 
*fent
; 
  51         for (fent 
= get_next_file(fw
, len
); fent 
!= NULL
; fent 
= get_next_file(NULL
, 0)) { 
  52                 if (FINDSTR(fent
->name
, "/default/fw_prop/") || 
  53                     FINDSTR(fent
->name
, "/default/fw_setup/") || 
  54                     FINDSTR(fent
->name
, "/default/oem_prop/")) { 
  55                         struct properties 
*prop
; 
  57                         printf("0x%08x: found setting: %s ", fent
->start 
- fw
, fent
->name
); 
  59                         prop 
= (struct properties
*)fent
->start
; 
  61                         if (prop
->magic 
!= 0x83011111) { 
  62                                 printf("ignoring...\n"); 
  66                         if (prop
->type1 
== 0x00 && prop
->type2 
== 0x04) { 
  67                                 printf("STRING: '%s' ", prop
->val
); 
  68                         } else if (prop
->type1 
== 0x01 && prop
->type2 
== 0x01) { 
  69                                 printf("BOOL: %s ",(*prop
->val 
? "TRUE" : "FALSE")); 
  70                         } else if (prop
->type1 
== 0x04 && prop
->type2 
== 0x02) { 
  71                                 printf("VAL: 0x%x ", *((unsigned int*)prop
->val
)); 
  73                                 printf("0x%02x 0x%2x...ignoring\n", prop
->type1
, prop
->type2
); 
  77                         if (prop
->right_rw 
== 0x00 && prop
->rw_mask 
== 0x00) { 
  79                         } else if (prop
->right_rw 
== 0x01) { 
  80                                 printf("(RW mask: 0x%02x)", prop
->rw_mask
); 
  82                                 printf("(UNK 0x%02x 0x%02x)", prop
->right_rw
, prop
->rw_mask
); 
  84                         printf(", length: %d\n", fent
->length
); 
  89 void change_properties(unsigned char *fw
, int len
, struct propaction 
*paction
) 
  91         struct file_entry 
*fent
; 
  92         struct propaction 
*cpaction
; 
  94         for (fent 
= get_next_file(fw
, len
); fent 
!= NULL
; fent 
= get_next_file(NULL
, 0)) { 
  96                 while (cpaction 
!= NULL
) { 
  97                         if (FINDSTR(fent
->name
, cpaction
->property
)) { 
 100                         cpaction 
= cpaction
->next
; 
 102                 if (cpaction 
!= NULL
) { 
 103                         struct properties 
*prop
; 
 105                         prop 
= (struct properties
*)fent
->start
; 
 107                         if (prop
->magic 
!= 0x83011111) { 
 111                         if (cpaction
->action 
& (PROP_ACTION_TRUE
|PROP_ACTION_FALSE
)) { 
 112                                 if (prop
->type1 
== 0x01 && prop
->type2 
== 0x01) { 
 113                                         if (cpaction
->action 
& PROP_ACTION_TRUE
) { 
 114                                                 if (*prop
->val 
== 0x00) { 
 116                                                         cpaction
->status 
|= PROP_STATUS_SUCCESS
; 
 118                                                         cpaction
->status 
|= PROP_STATUS_SAMEVAL
; 
 121                                                 if (*prop
->val 
== 0x01) { 
 123                                                         cpaction
->status 
|= PROP_STATUS_SUCCESS
; 
 125                                                         cpaction
->status 
|= PROP_STATUS_SAMEVAL
; 
 129                                         cpaction
->status 
= PROP_STATUS_WRONGTYPE
; 
 132                         if (cpaction
->action 
& PROP_ACTION_RW
) { 
 133                                 if (prop
->right_rw 
== 0x00 && prop
->rw_mask 
== 0x00) { 
 134                                         prop
->right_rw 
= 0x01; 
 135                                         prop
->rw_mask 
= 0x02; 
 136                                         cpaction
->status 
|= PROP_STATUS_SUCCESS
; 
 138                                         cpaction
->status 
|= PROP_STATUS_WRONGRIGHTS
; 
 141                         if (cpaction
->action 
& PROP_ACTION_RO
) { 
 142                                 if (prop
->right_rw 
== 0x01 && prop
->rw_mask 
== 0x02) { 
 143                                         prop
->right_rw 
= 0x00; 
 144                                         prop
->rw_mask 
= 0x00; 
 145                                         cpaction
->status 
|= PROP_STATUS_SUCCESS
; 
 147                                         cpaction
->status 
|= PROP_STATUS_WRONGRIGHTS
; 
 154 #define BD_SERIAL1      0x14,0x02 
 155 #define BD_ICMB         0x14,0x04 
 156 #define BD_LAN          0x14,0x08 
 157 #define BD_SERIAL2      0x14,0x10 
 158 #define BD_SERIAL3      0x14,0x20 
 159 #define BD_USB          0x14,0x40 
 160 #define BD_PCI          0x15,0x03 
 161 #define BD_LPC          0x15,0x04 
 162 #define BD_VGA          0x15,0x08 
 163 #define BD_BATTERY      0x15,0x10 
 164 #define BD_ACDC         0x15,0x20 
 165 #define BD_STANDBY      0x15,0x40 
 166 #define BD_POWERCONN    0x15,0x70 
 167 #define BD_DVI          0x15,0x80 
 168 #define BD_PWRATX       0x16,0x01 
 169 #define BD_PWRRELAY     0x16,0x02 
 170 #define BD_PS2A         0x19,0xff 
 172 #define MAGIC(fn, args...) fn(args) 
 174 #define _BD_IS_SET(bd, byte, bits) (bd[byte] & bits) 
 175 #define BD_IS_SET(bd, ident) MAGIC(_BD_IS_SET, bd, BD_##ident) 
 176 #define BD_TEXT(bd, ident) (BD_IS_SET(bd, ident) ? "TRUE" : "FALSE") 
 178 #define _BD_SET(bd, byte, bits) (bd[byte] |= bits) 
 179 #define BD_SET(bd, ident) MAGIC(_BD_SET, bd, BD_##ident) 
 181 void print_boarddescription(unsigned char *bd
) 
 185         for (j 
= 0; j 
< 32; j
++) { 
 186                 printf("%02x ", *(bd
+j
)); 
 190         /* com/agilent/rmc/amr/AmrMaster.class 
 191          * com/agilent/rmc/mgui/RmcPanel.class 
 192          * com/agilent/rmc/mgui/panels/AvrManualConfig.class 
 193          * com/agilent/rmc/mgui/panels/CardConf.jad 
 194          * com/agilent/rmc/mgui/panels/PowerMgmtConf.jad 
 195          * com/agilent/rmc/mgui/panels/RemoteDiskConf.jad 
 197         printf("\tserial1Present\t\t: %s\n", BD_TEXT(bd
, SERIAL1
)); 
 198         printf("\ticmbPresent\t\t: %s\n", BD_TEXT(bd
, ICMB
)); 
 199         printf("\tlanPresent\t\t: %s\n", BD_TEXT(bd
, LAN
)); 
 200         printf("\tserial2Present\t\t: %s\n", BD_TEXT(bd
, SERIAL2
)); 
 201         printf("\tserial3Present\t\t: %s\n", BD_TEXT(bd
, SERIAL3
)); 
 202         printf("\tusbPresent\t\t: %s\n", BD_TEXT(bd
, USB
)); 
 203         printf("\tpciPresent\t\t: %s\n", BD_TEXT(bd
, PCI
)); 
 204         printf("\tlpcPresent\t\t: %s\n", BD_TEXT(bd
, LPC
)); 
 205         printf("\tvgaPresent\t\t: %s\n", BD_TEXT(bd
, VGA
)); 
 206         printf("\tbatteryPresent\t\t: %s\n", BD_TEXT(bd
, BATTERY
)); 
 207         printf("\tacdcPresent\t\t: %s\n", BD_TEXT(bd
, ACDC
)); 
 208         printf("\tstandbyPresent\t\t: %s\n", BD_TEXT(bd
, STANDBY
)); 
 209         printf("\thasPowerConnectors\t: %s\n", BD_TEXT(bd
, POWERCONN
)); 
 210         printf("\tdviPresent\t\t: %s\n", BD_TEXT(bd
, DVI
)); 
 211         printf("\tpowerSwitchATX\t\t: %s\n", BD_TEXT(bd
, PWRATX
)); 
 212         printf("\tpowerSwitchRelay\t: %s\n", BD_TEXT(bd
, PWRRELAY
)); 
 214         printf("\tps2aPresent\t\t: %s\n", BD_TEXT(bd
, PS2A
)); 
 217 void handle_boarddescription(unsigned char *fw
, int len
, int patch
) 
 219         struct file_entry 
*fent
; 
 222         for (fent 
= get_next_file(fw
, len
); fent 
!= NULL
; fent 
= get_next_file(NULL
, 0)) { 
 223                 if (!strcmp(fent
->name
, "pdata")) 
 228                 fprintf(stderr
, "pdata file not found, aborting!\n"); 
 235         if (*((unsigned int*)pos
) != 0x00002802) { 
 236                 fprintf(stderr
, "pdata magic does not match, aborting!\n"); 
 243         if (*((unsigned int*)pos
) != 0x00500101) { 
 244                 fprintf(stderr
, "pdata magic2 does not match, aborting!\n"); 
 249                 /* Enable ATX and relay power switching */ 
 251                 BD_SET(pos
, PWRRELAY
); 
 254         printf("0x%08x: BOARD_DESCRIPTION: ", fent
->start 
- fw
); 
 255         print_boarddescription(pos
); 
 258 void syntax(char *name
) 
 260         fprintf(stderr
,"Syntax: %s parameters firmware.bin\n", name
); 
 261         fprintf(stderr
,"parameters as follows:\n"); 
 262         fprintf(stderr
,"\t-d\t\t\tdisplay all properties of the image\n"); 
 263         fprintf(stderr
,"\t-u\t\t\tupdate checksum of the image\n"); 
 264         fprintf(stderr
,"\t-b\t\t\tmodify BOARD_DESCRIPTION for more power-switch options\n"); 
 265         fprintf(stderr
,"\t-e\t\t\textract files in firmware\n"); 
 266         fprintf(stderr
,"\t-l\t\t\tlist files in firmware\n"); 
 267         fprintf(stderr
,"\t-t property\t\tset 'property' to true\n"); 
 268         fprintf(stderr
,"\t-f property\t\tset 'property' to false\n"); 
 269         fprintf(stderr
,"\t-w property\t\tallow read-write access to 'property'\n"); 
 270         fprintf(stderr
,"\t-r property\t\tallow read-only access to 'property'\n"); 
 271         fprintf(stderr
,"\t-x fw_file=local_file\treplace or add fw_file with content of local_file\n"); 
 275 void add_action(int opt
, char *optarg
, struct propaction 
**paction
) { 
 276         struct propaction 
*pos 
= *paction
; 
 277         struct propaction 
*prev 
= NULL
; 
 279         while (pos 
!= NULL
) { 
 280                 if (!strcmp(pos
->property
, optarg
)) 
 287                 pos 
= malloc(sizeof(struct propaction
)); 
 292                 bzero(pos
, sizeof(struct propaction
)); 
 293                 pos
->property 
= optarg
; 
 304                         if (pos
->action 
& PROP_ACTION_FALSE
) { 
 305                                 fprintf(stderr
,"inconsistent requests for %s\n",pos
->property
); 
 308                         pos
->action 
|= PROP_ACTION_TRUE
; 
 311                         if (pos
->action 
& PROP_ACTION_TRUE
) { 
 312                                 fprintf(stderr
,"inconsistent requests for %s\n",pos
->property
); 
 315                         pos
->action 
|= PROP_ACTION_FALSE
; 
 318                         if (pos
->action 
& PROP_ACTION_RO
) { 
 319                                 fprintf(stderr
,"inconsistent requests for %s\n",pos
->property
); 
 322                         pos
->action 
|= PROP_ACTION_RW
; 
 325                         if (pos
->action 
& PROP_ACTION_RW
) { 
 326                                 fprintf(stderr
,"inconsistent requests for %s\n",pos
->property
); 
 329                         pos
->action 
|= PROP_ACTION_RO
; 
 334 int check_crc(unsigned char *fw
, int len
) 
 337         unsigned int crc
, oldcrc
; 
 339         ret 
= rsb_crc2(fw
, len
, 0x55335053, &crc
); 
 340         oldcrc 
= (unsigned int)*((unsigned int*)(fw 
+ len 
- 4)); 
 342         printf("Checksum: 0x%08x (%s), should be: 0x%08x\n", 
 344                 (ret 
? "NOT OK" : "OK"), 
 350 void check_image(unsigned char *fw
, int len
) 
 352         struct file_entry 
*fent
; 
 353         char *last_name 
= NULL
; 
 355         /* get_next_file will abort on error */ 
 356         fent 
= get_next_file(fw
, len
); 
 357         while (fent 
!= NULL
) { 
 358                 last_name 
= fent
->name
; 
 359                 fent 
= get_next_file(NULL
, 0); 
 363 int main(int argc
, char **argv
) 
 373         struct propaction 
*paction 
= NULL
; 
 384         while ((opt 
= getopt(argc
, argv
, "dubelt:f:w:r:x:")) != -1) { 
 406                                 add_action(opt
, optarg
, &paction
); 
 409                                 replace_add_file(NULL
, 0, NULL
, NULL
); 
 422         if (stat(file
, &statbuf
) == -1) { 
 423                 fprintf(stderr
,"%s: ", file
); 
 428         if ((fd 
= open(file
, O_RDONLY
)) == -1) { 
 429                 fprintf(stderr
,"%s: ", file
); 
 434         if ((fw 
= malloc(statbuf
.st_size
)) == NULL
) { 
 439         bzero(fw
, statbuf
.st_size
); 
 441         remaining 
= statbuf
.st_size
; 
 444                 if ((ret 
= read(fd
, fw 
+ (statbuf
.st_size 
- remaining
), remaining
)) == -1) { 
 452         ret 
= check_crc(fw
, statbuf
.st_size
); 
 453         if ((ret 
!= 0) && (!update_crc
)) { 
 454                 fprintf(stderr
,"Checksum incorrect, aborting...\n"); 
 458         check_image(fw
, statbuf
.st_size 
- 4); 
 461                 struct propaction 
*cpaction 
= paction
; 
 463                 change_properties(fw
, statbuf
.st_size 
- 4, paction
); 
 465                 printf("\nProperty change results:\n"); 
 466                 while(cpaction 
!= NULL
) { 
 467                         printf("%s: ", cpaction
->property
); 
 469                         if (cpaction
->status 
== PROP_STATUS_NOTFOUND
) 
 471                         if (cpaction
->status 
& PROP_STATUS_SUCCESS
) 
 473                         if (cpaction
->status 
& PROP_STATUS_SAMEVAL
) 
 475                         if (cpaction
->status 
& PROP_STATUS_WRONGTYPE
) 
 476                                 printf("WRONGTYPE "); 
 477                         if (cpaction
->status 
& PROP_STATUS_WRONGRIGHTS
) 
 478                                 printf("WRONGRIGHTS "); 
 481                         cpaction 
= cpaction
->next
; 
 487                 handle_boarddescription(fw
, statbuf
.st_size 
- 4, 1); 
 491                 show_properties(fw
, statbuf
.st_size 
- 4); 
 492                 handle_boarddescription(fw
, statbuf
.st_size 
- 4, 0); 
 496                 list_files(fw
, statbuf
.st_size 
- 4); 
 500                 extract_files(fw
, statbuf
.st_size 
- 4); 
 503         if (update_crc 
|| patch_fw 
|| patch_bd
) { 
 504                 ret 
= rsb_crc2(fw
, statbuf
.st_size
, 0x55335053, &crc
); 
 506                         *((unsigned int*)(fw 
+ statbuf
.st_size 
- 4)) = crc
; 
 509                 check_image(fw
, statbuf
.st_size
-4); 
 511                 if (check_crc(fw
, statbuf
.st_size
) == 0) { 
 514                         newfile 
= malloc(strlen(file
) + strlen(".patched") + 1); 
 515                         if (newfile 
== NULL
) { 
 519                         strcpy(newfile
, file
); 
 520                         strcat(newfile
, ".patched"); 
 522                         printf("Writing %s\n", newfile
); 
 523                         if ((fd 
= open(newfile
, O_WRONLY
|O_CREAT
, 0644)) == -1) { 
 524                                 fprintf(stderr
,"%s: ", newfile
); 
 529                         remaining 
= statbuf
.st_size
; 
 532                                 if ((ret 
= write(fd
, fw 
+ (statbuf
.st_size 
- remaining
), remaining
)) == -1) { 
 540                         fprintf(stderr
,"Can't set correct checksum, aborting...\n");