calculate MAC,Lisence,Checksum and generate muti-file
/*************************************************************************
* calculate MAC,Lisence,Checksum and generate muti-file
* 声明:
* 1. 以升序的方式批量生成MAC地址方法;
* 2. 以升序、降序的方式批量生成数字形式的Lisence方法;
* 3. 以累加的方式计算MAC地址、Lisence的Checksum;
* 4. 不提供源数据处理文件,仅仅是处理数据代码;
* 5. 本软件主要是为后续软件开发提供更好的解决数据处理的方式。
* 6. 本人并没有对代码进行优化,主要是考虑到保留编写代码过程中的一些细节。
*
* 2015-8-24 晴 深圳 南山平山村 曾剑锋
************************************************************************/
#include <stdio.h>
#include <string.h>
#include <stdlib.h> #define debug #ifdef debug
#define Debug(...) fprintf(stdout,"debug: " __VA_ARGS__);
#else
#define Debug(...)
#endif int htoi( char s[] );
int createDir( const char *sPathName );
int changeLisenceByte( char * lisenceByte, int number );
void calculateNextMacAddress( int mac[], int i );
void calculateNextLisence( char lisence[], int i ); int main ( int argc, char ** argv ) { int i = ;
int ret = ;
int count = ;
int mac[] = {};
char lisence[] = {};
FILE *mtd5OutFile = NULL;
FILE *mtd6OutFile = NULL;
char readBuffer[] = {}; if ( argc != ) { // check arguments number
printf ( " USAGE:\n" );
printf ( " macLis <mac> <lisence> <count>\n" );
printf ( " example:\n" );
printf ( " macLis 11:22:33:44:55:66 20150609622300214 10 \n" );
return -;
} printf ( "mac : %s\n", argv[] );
printf ( "lisence : %s\n", argv[] );
printf ( "count : %s\n", argv[] ); for ( i = ; i < ; i++ ) {
argv[][ ( i + ) * - ] = '\0'; // change ':' to '\0'
mac[i] = htoi ( argv[] + ( i * ) );
}
Debug ( "mac : %2x:%2x:%2x:%2x:%2x:%2x\n", mac[], mac[], mac[], mac[], mac[], mac[] ); memcpy ( lisence, argv[], sizeof(lisence) - );
Debug ( "lisence : %s\n", lisence ); count = atoi ( argv[] ); // how many diretory to generate
Debug ( "count : %d\n", count); FILE *mtd5SourceFile = fopen ( "temp5", "rb" ); // open input file with binary
FILE *mtd6SourceFile = fopen ( "temp6", "rb" ); char dirPath[] = {};
char outMtd5FilePath[] = {};
char outMtd6FilePath[] = {};
char macString[] = {};
long sum = ; for ( i = ; i < count ; i++ ) { sprintf ( dirPath, "%03d", i ); // generator diretory
sprintf ( outMtd5FilePath, "%03d/temp5", i ); // generator temp5 file
sprintf ( outMtd6FilePath, "%03d/temp6", i ); // generator temp6 file createDir( dirPath );
mtd5OutFile = fopen ( outMtd5FilePath, "w+b" ); // open output file with binary
mtd6OutFile = fopen ( outMtd6FilePath, "w+b" ); rewind ( mtd5SourceFile ); // go head
rewind ( mtd6SourceFile ); // copy file content
while ( ret = fread ( readBuffer, , sizeof(readBuffer), mtd5SourceFile ) )
fwrite ( readBuffer, , sizeof(readBuffer), mtd5OutFile ); // copy file content
while ( ret = fread ( readBuffer, , sizeof(readBuffer), mtd6SourceFile ) )
fwrite ( readBuffer, , sizeof(readBuffer), mtd6OutFile ); // generate mac string and write to file
sprintf ( macString, "%c%c%c%c%c%c", mac[], mac[], mac[], mac[], mac[], mac[] );
fseek(mtd5OutFile, (0x670) + , SEEK_SET);
fwrite ( macString, , , mtd5OutFile );
fseek(mtd6OutFile, (0x30) + , SEEK_SET);
fwrite ( macString, , , mtd6OutFile ); // write Lisence number to file
fseek(mtd5OutFile, (0x680) + , SEEK_SET);
fwrite ( lisence, , , mtd5OutFile );
fseek(mtd6OutFile, (0x40) + , SEEK_SET);
fwrite ( lisence, , , mtd6OutFile ); // clear the data has used
bzero ( dirPath, sizeof(dirPath) );
bzero ( outMtd5FilePath, sizeof(outMtd5FilePath) );
bzero ( outMtd6FilePath, sizeof(outMtd5FilePath) ); // change MAC address with increase number 1
calculateNextMacAddress( mac, );
// change lisence with decrease number 1
calculateNextLisence( lisence, - ); /**
* go to calculate checksum
*/ // read check data from file
bzero ( readBuffer, sizeof(readBuffer) );
fseek ( mtd5OutFile, (0x640) + 0x0d, SEEK_SET );
fread ( readBuffer, , *, mtd5OutFile); // add all data as checksum, be carefull to use unsigned char to keep data was byte
int j = ;
sum = ;
for ( j = ; j < ( * ); j++ )
sum += ( unsigned char ) readBuffer[j]; // must type change to keep is positive
char checkSum[] = {};
sprintf ( checkSum, "%04x", sum );
Debug ( " temp5 checkSum: %s\n", checkSum ); // write checksum to file
fseek ( mtd5OutFile, (0x640) + 0x08, SEEK_SET );
fwrite ( &sum, , , mtd5OutFile); bzero ( readBuffer, sizeof(readBuffer) );
bzero ( checkSum, sizeof(checkSum) ); // work way as above
fseek ( mtd6OutFile, (0x000) + 0x09, SEEK_SET );
fread ( readBuffer, , *, mtd6OutFile); sum = ;
for ( j = ; j < ( * ); j++ )
sum += ( unsigned char ) readBuffer[j]; // must type change to keep is positive
sprintf ( checkSum, "%04x", sum );
Debug ( " temp6 checkSum: %s\n", checkSum ); fseek ( mtd6OutFile, (0x000) + 0x04, SEEK_SET );
fwrite ( &sum, , , mtd6OutFile); bzero ( readBuffer, sizeof(readBuffer) ); // flush to file and close
fflush ( mtd5OutFile );
fclose ( mtd5OutFile ); fflush ( mtd6OutFile );
fclose ( mtd6OutFile );
} fclose ( mtd5SourceFile );
fclose ( mtd6SourceFile ); return ;
} int htoi(char s[])
{
int i;
int n = ; // skip "0x" or "0X"
if (s[] == '' && (s[]=='x' || s[]=='X')) {
i = ;
} else {
i = ;
} for (; (s[i] >= '' && s[i] <= '') || (s[i] >= 'a' && s[i] <= 'z') || (s[i] >='A' && s[i] <= 'Z'); ++i) { if (tolower(s[i]) > '') {
n = * n + ( + tolower(s[i]) - 'a');
} else {
n = * n + (tolower(s[i]) - '');
} } return n;
} int createDir(const char *sPathName)
{
char DirName[];
int i;
int len = strlen ( DirName ); strcpy ( DirName, sPathName ); if ( DirName[ len- ] != '/' )
strcat ( DirName, "/" ); len = strlen ( DirName ); for ( i = ; i < len; i++ ) {
if ( DirName[i] == '/' ) {
DirName[i] = ;
if( access ( DirName, NULL ) != ) {
if(mkdir(DirName, )==-) {
perror("mkdir error");
return -;
}
}
DirName[i] = '/';
}
} return ;
} /**
* i: this can only be positive
*/
void calculateNextMacAddress( int mac[], int i ) { int macByte5 = ( i + mac[] ) % ;
int macByte4 = ( ( i + mac[] ) / + mac[] ) % ;
int macByte3 = ( ( ( ( i + mac[] ) / ) + mac[] ) / + mac[] ) % ;
int macByte2 = ( ( ( ( ( i + mac[] ) / ) + mac[] ) / + mac[] ) / + mac[] ) % ;
int macByte1 = ( ( ( ( ( ( i + mac[] ) / ) + mac[] ) / + mac[] ) / + mac[] ) / + mac[] ) % ;
int macByte0 = ( ( ( ( ( ( ( i + mac[] ) / ) + mac[] ) / + mac[] ) / + mac[] ) / + mac[] ) / + mac[] ) % ; mac[] = macByte0;
mac[] = macByte1;
mac[] = macByte2;
mac[] = macByte3;
mac[] = macByte4;
mac[] = macByte5; Debug ( "calculate next Mac : %02x:%02x:%02x:%02x:%02x:%02x\n", macByte0, macByte1, macByte2, macByte3, macByte4, macByte5 );
} void calculateNextLisence( char lisence[], int i ) {
int tmp = ;
tmp = changeLisenceByte( &lisence[], i );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp );
tmp = changeLisenceByte( &lisence[], tmp ); Debug ( "calculate next lisence : %s\n", lisence );
} /**
* number: this can be positive or negative
*/
int changeLisenceByte( char * lisenceByte, int number ) {
int tmp = ;
if ( ( lisenceByte[] - ) + number < ) {
tmp = ( ( lisenceByte[] - ) + number ) / - ;
lisenceByte[] = ( + ( ( lisenceByte[] - ) + number ) % ) + ;
} else {
tmp = ( ( lisenceByte[] - ) + number ) / ;
lisenceByte[] = ( ( lisenceByte[] - ) + number ) % + ;
} return tmp;
}
calculate MAC,Lisence,Checksum and generate muti-file的更多相关文章
- 【MySQL】InnoDB: Error: checksum mismatch in data file 报错
参考:http://www.jb51.net/article/66951.htm 用5.7版本启动原5.5实例后,再用5.5启动出现以下报错 InnoDB: Error: checksum misma ...
- Generate BKS File( Bouncy Castle KeyStore)
echo "Enter BKS output file name : \c" read filename echo "Enter BKS Password : \c&qu ...
- generate eml file
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD ...
- Generate input file for OVITO
using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Tex ...
- Mac Terminal open app with a file opened
open -a /Applications/Sublime Text.app test.cpp
- Mac OS build caffe2 Error:This file was generated by an older version of protoc which is
问题所在 我们可以发现这个错误跟protobuf的版本有关,因此我们可以执行script/diagnose_protobuf.py 我们可以看到,pip install protobuf 和 brew ...
- Windows平台CUDA开发之前的准备工作
CUDA是NVIDIA的GPU开发工具,眼下在大规模并行计算领域有着广泛应用. windows平台上面的CUDA开发之前.最好去NVIDIA官网查看说明,然后下载对应的driver. ToolKits ...
- How to generate a new dictionary file of mmseg
How to generate a new dictionary file of mmseg 0.Usage about mmseg-node memtioned in github : var mm ...
- IAR EWARM Checksum Technical Note
IELFTOOL Checksum - Basic actions EW targets: ARM, RH850, RX, SH, STM8 EW component: General issues ...
随机推荐
- 代码中特殊的注释技术 -- TODO、FIXME和XXX的用处
借鉴地址:https://www.cnblogs.com/pengyingh/articles/2445826.html 在阅读一些代码时,经常会遇到诸如:TODO.FIXME和XXX的单词,它们是有 ...
- Beta冲刺
第一天 日期:2018/6/24 1 今日完成任务情况. 妥志福.牛瑞鑫: 完成任务:数据库设计完成数据导入成功 王胜海.马中林: 完成任务:代码规范检查 董润园.邓英蓉: 完成任务:平台基本功能黑盒 ...
- JS中Ajax的同步和异步
ajax同步 : 意味着此时请求Server后,JS代码不再继续执行,等待Server返回后才继续往下执行. ajax异步 : 意味着此时请求Server后,JS代码继续执行,不管Server什么时候 ...
- 拓扑排序 Topological Sort
2018-05-02 16:26:07 在计算机科学领域,有向图的拓扑排序或拓扑排序是其顶点的线性排序,使得对于从顶点u到顶点v的每个有向边uv,u在排序中都在v前.例如,图形的顶点可以表示要执行的任 ...
- 递推2--过河卒(Noip2002)
递推2--过河卒(Noip2002) 一.心得 写出递推公式就OK了,具体编程还是很简单的 二.题目及分析 过河卒(NOIp2002) [问题描述] 棋盘上A点有一个过河卒,需要走到目标B点.卒行走的 ...
- SVN同步版本库与网站目录
如何创建SVN版本库及同步文件到WEB目录 来源:空谷 一 安装与配置SVN 1.安装subversion centos: yum install subversion ubuntu: apt-get ...
- [.NET开发] 浅说C#异步和同步
提到异步,那么与之对应的是什么呢?同步.那么C#的异步和同步是如何工作的呢? 首先,我们先来看看栗子: 新建一个控制台应用程序,在Program文件中添加如下代码: 1 static void Mai ...
- 单细胞 RNA-seq 10X Genomics
单细胞流程跑了不少,但依旧看不懂结果,是该好好补补了. 有些人可能会误会,觉得单细胞的RNA-seq数据很好分析,跟分析常规的RNA-seq应该没什么区别.今天的这篇文章2015年3月发表在Natur ...
- English trip -- VC(情景课)4 B Parts of the body 身体部位
xu言: ... Words eye 读音同 I 眼睛 nose 鼻子 ear 耳朵 tooth 牙齿 mouth 嘴 hair 头发 eyebrow 眉毛 cheek 脸颊 n ...
- Linux Used内存到底哪里去了?
原创文章,转载请注明: 转载自系统技术非业余研究 本文链接地址: Linux Used内存到底哪里去了? 前几天 纯上 同学问了一个问题: 我ps aux看到的RSS内存只有不到30M,但是free看 ...