每 32 字节复制一个二进制文件 32 字节
Copy a Binary file 32 bytes per 32 bytes
我在这里要做的是,每 32 字节复制一个 32 字节的二进制文件。
我为什么要这样做?因为我需要在我的板子的 USART 上发送这个二进制文件。我不能一次性发送,所以我每 32 字节发送 32 字节。
首先,我尝试将我的二进制文件读入缓冲区并将其写入另一个文件,每 32 字节 3é 字节。
问题是,当我尝试执行我创建的新二进制文件时......它没有在板上执行,我不明白为什么
如果你想试一试,这是我的代码..
int sendBuff(char *buffer,int *size)
{
int i,n =0;
char c ;
FILE *file,target;
//Open file
file = fopen("Nucleo-L152RE_bis.bin", "rb");
if (!file)
{
fprintf(stderr, "Unable to open file %s", "Nucleo-L152RE_bis.hex");
return 0;
}
*size = getFileSize(file);
if (!buffer) {
fprintf(stderr, "Memory error!");
fclose(file);
return 0;
}
//Read file contents into buffer
fread(buffer,*size, 1, file);
fclose(file);
return 0;
}
void writefile(unsigned char *buffer,int size){
FILE *file;
int i;
file = fopen("salut.bin", "a");
if (!file)
{
fprintf(stderr, "Unable to open file %s", "Nucleo-L152RE.bin");
}
else
{
fwrite(buffer,sizeof(unsigned char),size,file);
fclose(file);
}
}
和主要功能:
int main()
{
/* variables locales */
unsigned char bufferS[1000000];
int nId = 5, nChoice, nBytesWritten, nBytesRead;
int* pByteRead, pByteWritten;
int size;
int k = 0,k_hexa = 0;
/* demande du numéro du port COM */
/* boucle tant que l'on ne quitte pas */
do
{
/* menu */
//ecriture de l'executable dans un buffer
sendBuff(bufferS, &size);
printf("size of file: %d\n\n", size);
k = 0;
printf("SIZE : %d\n", size);
//send program
do
{
printf("Envoi de donnees...\r\n");
//WriteCOM(bufferS + k, 32, &nBytesWritten);
writefile(bufferS+k,32);
printf("%d octet(s) envoye(s) et k : %d .\r\n",
nBytesWritten, k);
k += 32;
// scanf("%d",&nChoice);
} while (k < size);
}
}
我们应该参考您发布的代码吗?在那种情况下,您似乎正在触发未定义的行为,因为您试图在 printf
中读取 nBytesWritten
的值。但是nBytesWritten
好像没有初始化。
1)根据您的实施情况,
您向新 salut.bin 添加额外的 (32-size%32) 冗余字节,
导致执行失败。这样复制就OK了,
do
{
printf("Envoi de donnees...\r\n");
//WriteCOM(bufferS + k, 32, &nBytesWritten);
writefile(bufferS+k,32);
printf("%d octet(s) envoye(s) et k : %d .\r\n",
nBytesWritten, k);
k += 32;
// scanf("%d",&nChoice);
} while (k < size-32);
writefile(bufferS+k, size%32);
2)错误的bin格式或内容会导致execute failure
,有时这是由于偶然丢失了一些字节或在文件末尾添加了冗余字节造成的。
我在这里要做的是,每 32 字节复制一个 32 字节的二进制文件。 我为什么要这样做?因为我需要在我的板子的 USART 上发送这个二进制文件。我不能一次性发送,所以我每 32 字节发送 32 字节。
首先,我尝试将我的二进制文件读入缓冲区并将其写入另一个文件,每 32 字节 3é 字节。 问题是,当我尝试执行我创建的新二进制文件时......它没有在板上执行,我不明白为什么
如果你想试一试,这是我的代码..
int sendBuff(char *buffer,int *size)
{
int i,n =0;
char c ;
FILE *file,target;
//Open file
file = fopen("Nucleo-L152RE_bis.bin", "rb");
if (!file)
{
fprintf(stderr, "Unable to open file %s", "Nucleo-L152RE_bis.hex");
return 0;
}
*size = getFileSize(file);
if (!buffer) {
fprintf(stderr, "Memory error!");
fclose(file);
return 0;
}
//Read file contents into buffer
fread(buffer,*size, 1, file);
fclose(file);
return 0;
}
void writefile(unsigned char *buffer,int size){
FILE *file;
int i;
file = fopen("salut.bin", "a");
if (!file)
{
fprintf(stderr, "Unable to open file %s", "Nucleo-L152RE.bin");
}
else
{
fwrite(buffer,sizeof(unsigned char),size,file);
fclose(file);
}
}
和主要功能:
int main()
{
/* variables locales */
unsigned char bufferS[1000000];
int nId = 5, nChoice, nBytesWritten, nBytesRead;
int* pByteRead, pByteWritten;
int size;
int k = 0,k_hexa = 0;
/* demande du numéro du port COM */
/* boucle tant que l'on ne quitte pas */
do
{
/* menu */
//ecriture de l'executable dans un buffer
sendBuff(bufferS, &size);
printf("size of file: %d\n\n", size);
k = 0;
printf("SIZE : %d\n", size);
//send program
do
{
printf("Envoi de donnees...\r\n");
//WriteCOM(bufferS + k, 32, &nBytesWritten);
writefile(bufferS+k,32);
printf("%d octet(s) envoye(s) et k : %d .\r\n",
nBytesWritten, k);
k += 32;
// scanf("%d",&nChoice);
} while (k < size);
}
}
我们应该参考您发布的代码吗?在那种情况下,您似乎正在触发未定义的行为,因为您试图在 printf
中读取 nBytesWritten
的值。但是nBytesWritten
好像没有初始化。
1)根据您的实施情况, 您向新 salut.bin 添加额外的 (32-size%32) 冗余字节, 导致执行失败。这样复制就OK了,
do
{
printf("Envoi de donnees...\r\n");
//WriteCOM(bufferS + k, 32, &nBytesWritten);
writefile(bufferS+k,32);
printf("%d octet(s) envoye(s) et k : %d .\r\n",
nBytesWritten, k);
k += 32;
// scanf("%d",&nChoice);
} while (k < size-32);
writefile(bufferS+k, size%32);
2)错误的bin格式或内容会导致execute failure
,有时这是由于偶然丢失了一些字节或在文件末尾添加了冗余字节造成的。