📄 stampbin.c
字号:
//
while (1) {
//
// Record address
//
fRet = ReadFile(hFile, &dwRecAddr, sizeof(DWORD), &dwRead, NULL);
if (!fRet || dwRead != sizeof(DWORD)) {
break;
}
//
// Record length
//
fRet = ReadFile(hFile, &dwRecLen, sizeof(DWORD), &dwRead, NULL);
if (!fRet || dwRead != sizeof(DWORD)) {
break;
}
//
// Record checksum
//
fRet = ReadFile(hFile, &dwRecChk, sizeof(DWORD), &dwRead, NULL);
if (!fRet || dwRead != sizeof(DWORD)) {
break;
}
g_Records[g_dwNumRecords].dwStartAddress = dwRecAddr;
g_Records[g_dwNumRecords].dwLength = dwRecLen;
g_Records[g_dwNumRecords].dwChecksum = dwRecChk;
g_Records[g_dwNumRecords].dwFilePointer = SetFilePointer(hFile, 0, NULL, FILE_CURRENT);
g_dwNumRecords++;
if (dwRecAddr == 0 && dwRecChk == 0) {
break;
}
SetFilePointer(hFile, dwRecLen, NULL, FILE_CURRENT);
}
//
// Find pTOC
//
fRet = AccessBinFile(pBuffer, g_dwImageStart + 0x40, 8, 0, FALSE);
if (fRet) {
g_pTOC = *((PDWORD)(pBuffer + 4));
} else {
printf("ERROR: Couldn't find pTOC\n");
goto Error;
}
if (!ComputeRomOffset(g_pTOC)) {
goto Error;
}
return TRUE;
Error:
return FALSE;
}
//------------------------------------------------------------------------------
//------------------------------------------------------------------------------
int CloseBin(){
CloseHandle(hFile);
return TRUE;
}
//------------------------------------------------------------------------------
//------------------------------------------------------------------------------
int StampFile(LPCTSTR lpFileName, LPCTSTR section_name, LPCTSTR section_type, LPCTSTR input_file){
BOOL ret = FALSE;
HANDLE hInput = INVALID_HANDLE_VALUE;
DWORD type = strtol(section_type, NULL, 16);
if(!OpenBin(lpFileName)){
printf ("Error opening %s\n", lpFileName);
goto EXIT;
}
hInput = CreateFile(input_file, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0, 0);
if(hInput == INVALID_HANDLE_VALUE){
printf ("Error opening %s\n", input_file);
goto EXIT;
}
// find correct extension
if(!AccessBinFile(pBuffer, g_pTOC, sizeof(ROMHDR), g_dwROMOffset, FALSE)){
printf("Couldn't read TOC data\n");
goto EXIT;
}
{
ROMHDR* pTOC = (ROMHDR *)pBuffer;
ROMPID pid;
if (pTOC->pExtensions) {
if (!AccessBinFile((PBYTE)&pid, (DWORD)pTOC->pExtensions, sizeof(ROMPID), g_dwROMOffset, FALSE)) {
printf("Couldn't read TOC Extensions\n");
goto EXIT;
}
while(pid.pNextExt){
DWORD ExtAddress = (DWORD)pid.pNextExt;
if (!AccessBinFile((PBYTE)&pid, ExtAddress, sizeof(ROMPID), g_dwROMOffset, FALSE)) {
printf("Couldn't read TOC Extensions\n");
goto EXIT;
}
if(strcmp(pid.name, section_name) == 0 && pid.type == type) {
DWORD size = 0, cb = 0;
BYTE *buffer;
printf("Found extension to update\n"
" Name: %s\n"
" Type: %08x\n"
" pData: %08x\n"
" Length: %08x\n"
" Reserved: %08x\n"
" Next: %08x\n",
pid.name, pid.type, pid.pdata, pid.length, pid.reserved, pid.pNextExt);
size = GetFileSize(hInput, NULL);
if(pid.reserved < size){
printf("Error: input file was too large to fit in extension\n"
" Extension size: %08x\n"
" Input File size: %08x\n",
pid.reserved,
size);
goto EXIT;
}
buffer = malloc(size + sizeof(ROMPID));
if(!buffer){
printf("Error: failed allocating memory for buffer\n");
goto EXIT;
}
pid.length = size;
memcpy(buffer, &pid, sizeof(pid));
if(!ReadFile(hInput, buffer + sizeof(ROMPID), size, &cb, NULL)){
printf("Error: failed reading input file\n");
goto EXIT;
}
if(!AccessBinFile(buffer, ExtAddress, size + sizeof(ROMPID), g_dwROMOffset, TRUE)){
printf("Error: Failed updating extension\n");
goto EXIT;
}
// copy contents to file at right spot (AccessBinFile?)
ret = TRUE;
goto EXIT;
}
}
}
}
printf("No extensions found with name '%s' and type '%08x'\n",
section_name, type);
EXIT:
CloseHandle(hInput);
CloseBin();
return ret;
}
//------------------------------------------------------------------------------
//------------------------------------------------------------------------------
int StampPID(LPCTSTR lpFileName, ROMPID *pPID) {
if(!OpenBin(lpFileName)){
printf ("Error opening %s\n", lpFileName);
return FALSE;
}
if (!WritePID(pPID)) {
goto Error;
}
CloseBin();
return TRUE;
Error:
CloseBin();
return FALSE;
}
BOOL ReadPidFile(DWORD *pPid, char *pid_file){
int i = 0;
FILE *hfile = NULL;
BOOL ret = FALSE;
if(!pid_file || !pPid)
return FALSE;
hfile = fopen(pid_file, "r");
if(!hfile){
fprintf(stderr, "Can't open '%s'", pid_file);
return FALSE;
}
for(i = 0; i < sizeof(ROMPID)/4 - 1; i++){
int count = 0;
if(fscanf(hfile, "%x", (DWORD*)(pPid + i)) != 1){
printf("Failed reading element %d of pid\n", i);
goto EXIT;
}
}
ret = TRUE;
EXIT:
fclose(hfile);
return ret;
}
//------------------------------------------------------------------------------
//------------------------------------------------------------------------------
int main(int argc, char *argv[])
{
TCHAR *iFileName = "nk.bin";
ROMPID Pid = {
{ 0x11111111, 0x22222222, 0x33333333, 0x44444444, 0x55555555, 0x66666666, 0x77777777, 0x88888888, 0x99999999, 0xaaaaaaaa },
NULL
};
printf("Stampbin V1.1 built " __DATE__ " " __TIME__ "\n\n");
if(getenv("d_break"))
DebugBreak();
if(argc >= 3 && _tcsicmp(argv[1], "-i") == 0){
iFileName = argv[2];
argc -= 2;
argv = &argv[2];
}
#if 1
{
int i;
for(i = 0; i < argc; i++)
printf("%d) %s\n", i, argv[i]);
}
#endif
if(argc == 2){
if(!ReadPidFile((DWORD*)&Pid, argv[1]) || !StampPID(iFileName, &Pid)) {
printf("ERROR!\n");
exit(1);
}
}
else if(argc == 4){
if(!StampFile(iFileName, argv[1], argv[2], argv[3])) {
printf("ERROR!\n");
exit(1);
}
}
else{
printf("\nUsage: %s [-i imagename] pidfile"
"\n or: %s [-i imagename] name type inputfile\n\n"
" imagename - name of .bin file to stamp (defaults to nk.bin)\n"
" pidfile - ascii file containing 10 hex values separated by whitespace\n"
" ex. \"00abc123 456def123 a3450000 ...\"\n"
" name/type/input - search for an extension with the specified name and type\n"
" and then copy the contents of the file into that region. The\n"
" file must be less then or equal to the size of the region.\n",
argv[0], argv[0]);
exit(1);
}
return 0;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -