/*************************************************************************
* 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的更多相关文章

  1. 【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 ...

  2. Generate BKS File( Bouncy Castle KeyStore)

    echo "Enter BKS output file name : \c" read filename echo "Enter BKS Password : \c&qu ...

  3. generate eml file

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD ...

  4. Generate input file for OVITO

    using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Tex ...

  5. Mac Terminal open app with a file opened

    open -a /Applications/Sublime Text.app test.cpp

  6. 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 ...

  7. Windows平台CUDA开发之前的准备工作

    CUDA是NVIDIA的GPU开发工具,眼下在大规模并行计算领域有着广泛应用. windows平台上面的CUDA开发之前.最好去NVIDIA官网查看说明,然后下载对应的driver. ToolKits ...

  8. 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 ...

  9. IAR EWARM Checksum Technical Note

    IELFTOOL Checksum - Basic actions EW targets: ARM, RH850, RX, SH, STM8 EW component: General issues ...

随机推荐

  1. python 插值查找

    def binary_search(lis, key): low = 0 high = len(lis) - 1 time = 0 while low < high: time += 1 # m ...

  2. unable to find resource 'xxx\xx\overview.vm' in any resource loader.

    ResourceManager : unable to find resource 'C:\Test\TestConfig\overview.vm' in any resource loader.or ...

  3. 【转】float类型在内存中的表示

    http://www.cnblogs.com/onedime/archive/2012/11/19/2778130.html http://blog.csdn.net/adream307/articl ...

  4. [原][osg][osgEarth][粒子特效]关于粒子特效库在osgEarth中,位置摆放问题,跟踪节点移动问题

    首先粒子在地球上位置摆放很简单: //传入的经纬度坐标 osg::Vec3d geoPoint; const SpatialReference* latLong = SpatialReference: ...

  5. [源][osg][osgBullet]osgBullet例子介绍

    1.BasicDemo 基本样例 一个小玩具飞机坠落,一个立方体盒子在转圈 2.centerofmass 质心 3.collision 碰撞检测 这里有一个大神自己改的例子: http://blog. ...

  6. 《剑指offer》第四题(二维数组中的查找)

    // 二维数组中的查找 // 题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按 // 照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个 // 整数,判断数组 ...

  7. Faster R-CNN: Towards Real-Time Object Detection with Region Proposal Networks论文理解

    一.创新点和解决的问题 创新点 设计Region Proposal Networks[RPN],利用CNN卷积操作后的特征图生成region proposals,代替了Selective Search ...

  8. idea忽略文件

  9. pv、uv、ip、tps、qps 等术语简单释义

    跟网站打交道,经常可以听到数据分析之类的专有名词,如pv多少.ip多少.tps多少之类的问题.下面就这些常见的数据给出英文全称及其释义. PV 即 page view,页面浏览量,用户每一次对网站中的 ...

  10. ubuntu 用户和root权限转换

    1,用户权限要转换为root 输入:sudo su   或者sudo -i  然后按照提示输入相应的密码你就可以转化为root用户了. 2,root权限切换成用户权限 输入:su  如果是服务器那就输 ...