以前写的一个Atmel的S5X的下载程序,其中有支持HEX格式的文件,所以将这个程序贴出来,程序的意思是将输入的HEX文件转换为BIN格式的文件,并存储到文件中,注意不支持64K的扩展模式。

int CFlashP51App::HexToBin(CString hexfile, CString binfile)
{
    CFile fhex, fbin;
    CString pBuffer;
    BYTE len, len1, len2, len_at_max=;
    ;
    ;

    if(!(fhex.Open(hexfile, CFile::modeRead, NULL)))  //// 打开文件
        ;
    if(!(fbin.Open(binfile, CFile::modeCreate|CFile::modeWrite, NULL)))
        ;

    char *buffer = new char [fhex.GetLength()];  //// 分配内存
    fhex.Read(buffer, fhex.GetLength());
    pBuffer = buffer;

    nEnd = pBuffer.Find(":00000001");     //// 以此来判断文件格式是否为HEX
    )    //先判断文件结尾处
    {
     //        AfxMessageBox("*.Hex文件转换失败(未找到\":00000001\"记录)!");
        ;
    }
    n = ;
    while(n < nEnd)        // 首先得到bin文件的长度
    {
        if(buffer[n] == ':')
        {
            CharToByte(&buffer[n+], &len);
            CharToByte(&buffer[n+], &len1);
            CharToByte(&buffer[n+], &len2);
            start_addr = (len1<<) + len2;    // 起始地址
            /*
             *    有的HEX文件中间会有"空洞",只靠计算前面每一行数据的大小
             *  可能会出现错误,因此得到最大的地址值和最大地址值这一行的
             *  数据大小来得到BIN文件的大小,实际上准确上因该采用此法,前
             *  面的方法没有去掉,可以去掉
             *
             */
            if(start_addr >= start_addr_max)
            {
                start_addr_max = start_addr;
                len_at_max = len;
            }
            bin_length += len;
            n += len*+;    // 没有加上回车符号
        }
        else
            n++;
    }
    start_addr_max += len_at_max;
    if(start_addr_max >= bin_length)
        bin_length = start_addr_max;

    BYTE *bbuf = new BYTE [bin_length];  //// 分配内存
    ; i<bin_length; i++)
        bbuf[i] = 0xff;
    n = ;
    while(n < nEnd)        // 向BIN文件缓冲区写数据
    {
        if(buffer[n] == ':')
        {
            CharToByte(&buffer[n+], &len);
            CharToByte(&buffer[n+], &len1);
            CharToByte(&buffer[n+], &len2);
            start_addr = (len1<<) + len2;    // 起始地址
            ; i<len; i++)
            {
                CharToByte(&buffer[n++i*], &len1);
                bbuf[start_addr+i] = len1;
            }
            n += len*+;    // 没有加上回车符号
        }
        else
            n++;
    }
    fbin.Write(bbuf, bin_length);

    fhex.Close();
    fbin.Close();
    delete [] buffer;
    delete [] bbuf;
    return bin_length;
}

BOOL CFlashP51App::CharToByte(char *pChar, BYTE *pByte)
{
    char h,l;
    h = pChar[]; //高4位
    l = pChar[]; //低4位
    ')
        l = l - ';
    else if(l>='a' && l<='f')
        l = l - 'a' + 0xa;
    else if(l>='A' && l<='F')
        l = l - 'A' + 0xa;
    else
        return FALSE;

    ')
        h = h - ';
    else if(h>='a' && h<='f')
        h = h - 'a' + 0xa;
    else if(h>='A' &&h <='F')
        h = h - 'A' + 0xa;
    else
        return FALSE;
    *pByte = (BYTE)h* + l;
    return TRUE;
}

HEX转BIN源码分析(51系列)的更多相关文章

  1. Kafka源码分析系列-目录(收藏不迷路)

    持续更新中,敬请关注! 目录 <Kafka源码分析>系列文章计划按"数据传递"的顺序写作,即:先分析生产者,其次分析Server端的数据处理,然后分析消费者,最后再补充 ...

  2. Docker源码分析(八):Docker Container网络(下)

    1.Docker Client配置容器网络模式 Docker目前支持4种网络模式,分别是bridge.host.container.none,Docker开发者可以根据自己的需求来确定最适合自己应用场 ...

  3. 【OpenCV】SIFT原理与源码分析:方向赋值

    <SIFT原理与源码分析>系列文章索引:http://www.cnblogs.com/tianyalu/p/5467813.html 由前一篇<关键点搜索与定位>,我们已经找到 ...

  4. 【OpenCV】SIFT原理与源码分析:关键点搜索与定位

    <SIFT原理与源码分析>系列文章索引:http://www.cnblogs.com/tianyalu/p/5467813.html 由前一步<DoG尺度空间构造>,我们得到了 ...

  5. Shiro 源码分析

    http://my.oschina.net/huangyong/blog/215153 Shiro 是一个非常优秀的开源项目,源码非常值得学习与研究. 我想尝试做一次 不一样 的源码分析:源码分析不再 ...

  6. UiAutomator源码分析之获取控件信息

    根据上一篇文章<UiAutomator源码分析之注入事件>开始时提到的计划,这一篇文章我们要分析的是第二点: 如何获取控件信息 我们在测试脚本中初始化一个UiObject的时候通常是像以下 ...

  7. Appium Android Bootstrap源码分析之控件AndroidElement

    通过上一篇文章<Appium Android Bootstrap源码分析之简介>我们对bootstrap的定义以及其在appium和uiautomator处于一个什么样的位置有了一个初步的 ...

  8. 【MyBatis源码分析】select源码分析及小结

    示例代码 之前的文章说过,对于MyBatis来说insert.update.delete是一组的,因为对于MyBatis来说它们都是update:select是一组的,因为对于MyBatis来说它就是 ...

  9. MyBatis源码分析之环境准备篇

    前言 之前一段时间写了[Spring源码分析]系列的文章,感觉对Spring的原理及使用各方面都掌握了不少,趁热打铁,开始下一个系列的文章[MyBatis源码分析],在[MyBatis源码分析]文章的 ...

随机推荐

  1. 直接修改别人jar包里面的class文件 工具:jclasslib

    出于某些原因 需要把别人jar包里面的class修改一下信息 配置文件*.properties MANIFEST.MF 这些东西可以直接用记事本打开修改 然后替换掉就OK.. 在网上游荡了半天,没有找 ...

  2. bzoj4034

    http://www.lydsy.com/JudgeOnline/problem.php?id=4034 树链剖分. 跟NOI2015的“软件包管理”一模一样..... 河南的爽死了...... #i ...

  3. bzoj2965

    http://www.lydsy.com/JudgeOnline/problem.php?id=2965 http://www.tsinsen.com/A1385 平面图网络流. 首先我们要将平面图转 ...

  4. C#中单问号,双问号的用法(转)

    原文:http://hi.baidu.com/guodong828/blog/item/c78fc23f847314cb7d1e7193.html 单问号---用于给变量设初值的时候,给变量(int类 ...

  5. VC++中的类的内存分布(上)

    0.序 目前正在学习C++中,对于C++的类及其类的实现原理也挺感兴趣.于是打算通过观察类在内存中的分布更好地理解类的实现.因为其实类的分布是由编译器决定的,而本次试验使用的编译器为VS2015 RC ...

  6. java实现矩阵连乘的动态规划

    package com.cjs.algorithm; public class DynamicPlan { /** * 此方法用来求解矩阵连乘的最小数乘次数 * * @param p * 传入的要连乘 ...

  7. map循环遍历删除

    typedef map<string,int> MapFileList; int main() { MapFileList m_SingleList; m_SingleList.inser ...

  8. IEEE论文格式要求

    0.特别提示:本次会议要求各位作者根据审稿意见进行认真修改,然后经过大会主席的检查合格才允许上传IEEE eXpress,主要的目的是为了保证论文集的质量,不让论文格式出现五花八门的情况,确保会议后被 ...

  9. 第24讲 UI_布局 之帧布局 表格布局 绝对布局

    第24讲 UI_布局 之帧布局 表格布局 绝对布局 3. FrameLayout(帧布局) 帧布局是从屏幕的左上角(0,0)坐标开始布局,多个组件层叠排序,后一个组件总会将前一个组件所覆盖,除非最后一 ...

  10. mysql 存储过程 计算报表

    把用例执行情况mysql表汇总起来 proc_write_report 汇总执行用例表中的测试数据 写入report 表,report表包括字段 report_id(自增)execution_flag ...