以前写的一个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. 基于AForge.Net框架的扑克牌识别

    原文:基于AForge.Net框架的扑克牌识别 © 版权所有 野比 2012 原文地址:点击查看 作者:Nazmi Altun Nazmi Altun著,野比 译  下载源代码 - 148.61 KB ...

  2. 通过代理访问nginx和直接访问nginx区别

    80.82.78.38 [23/Sep/2016:05:36:18 +0800] "GET http://www.baidu.com/cache/global/img/gs.gif HTTP ...

  3. zabbix报警把特定的应用集发送给developer

    1.创建新的action 2.创建新的develop用户 3.需要删除组不然会给组里所有人发

  4. 【转】解决java.lang.IllegalStateException: The content of the adapter has changed but ListView...的问题

    原文网址:http://blog.csdn.net/ueryueryuery/article/details/20607845 我写了一个Dialog,Dialog中有一个ListView,想要点Li ...

  5. Exchange Server 2010/2013架构改变

    Exchange Server 2010架构 Exchange Server 2013架构

  6. startActivity与startActivityForResult的使用小结

    1.在一个Activity中想要启动进入另一个Activity时,通常我们使用startActivity这个方法来实现,代码如下: 其中MainActivity为源activity,ActivityL ...

  7. Unity 单元测试(PLUnitTest工具)

    代码测试的由来 上几个星期上面分配给我一个装备系统,我经过了几个星期的战斗写完90%的代码. 后来策划告诉我需求有一定的改动,我就随着策划的意思修改了代码. 但是测试(Xu)告诉我装备系统很多功能都用 ...

  8. 斐波那契数列 Php练手

    数列从第三项开始,每一项都等于前两项之和. F0=0,F1=1,Fn=F(n-1)+F(n-2) 递归版和非递归版. <?php function fib($n){ $array = array ...

  9. Windows7 32位机上,OpenCV中配置GPU操作步骤

    1.  查看本机配置,查看显卡类型是否支持NVIDIA GPU: 2.  从http://www.nvidia.cn/Download/index.aspx?lang=cn下载最新驱动并安装: 3.  ...

  10. 【Spark】Spark的Shuffle机制

    MapReduce中的Shuffle 在MapReduce框架中,shuffle是连接Map和Reduce之间的桥梁,Map的输出要用到Reduce中必须经过shuffle这个环节,shuffle的性 ...