为了增加大家 DIY 的乐趣,XiaomaGee今天为大家只做了一篇使用iTool2内置的USB转I2C来读写EEPROM的方法和代码。

iTool2简介

iTool2为银杏公司面向电子类研发工程师推出的一款多功能调试工具箱,其具有使用方便、功能强大等诸多优点。本文利用iTool2内置的USB转 I2C功能,基于MinGW32平台完成对24XX系列的EEPROM的读写。

MinGW平台

平台简介

MinGW是Minimalist GNU for Windows的缩写。它是一个可自由使用和自由发布的Windows特定头文件和使用GNU工具集导入库的集合,允许你在GNU/Linux和Windows平台生成本地的Windows程序而不需要第三方C运行时(C Runtime)库。(摘自于百度百科)。

下载与安装

MinGW可以通过以太网自由获取,其官方网址如下:

http://www.mingw.org

可以通过官网的Download 标签下载MinGW最新的发行版的安装工具。下面地址不保证长期有效:

http://nchc.dl.sourceforge.net/project/mingw/Installer/mingw-get-setup.exe

下载后运行可执行文件,它便会自行下载并安装MinGW32 工具集,默认文件夹为C盘根目录下。

添加系统路径

由于MinGW工具为命令行运行,并且没有IDE,为了方便使用,一般需要把工具集加入到系统路径里面。具体方法为在“系统属性”里的“环境变量”功能里的 Path 变量下加入如下路径。(根据安装目录决定)

c:\MinGW\bin;

源文件组成

代码基于MinGW开发平台的,包含以下源文件:

1、  ico.rc   可执行程序图标资源描述

2、  itool2.ico  可执行程序图标文件

3、  main.c    主程序

4、  usb.c     usb转i2c功能底层代码

5、  usb.h     usb转 i2c 功能头文件

6、  makefile  makefile文件

构建可执行文件

若MinGW平台安装成功且路径配置好,通过命令提示符进入源文件文件夹后,可执行下面命令完成程序编译。

出现上图消息即说明工程编译构建成功。同时也会在本文件夹内产生一个名字为iTool2_eeprom.exe的可执行文件,如下图所示。

硬件连接

由于没有定制化的硬件测试平台,所以本技术笔记硬件需要自行搭建,且只适合有一定动手能力的朋友,硬件连接如下图所示。

图中8脚芯片实为24LC04B,与iTool2连接共有四根线,分别为I2C的SDA / SCL信号线及3.3V / GND 供电线。

软件流程图

为了更好的对EEPROM 进行读写测试,本软件按照如下流程图进行测试。

首先产生100个字节随机数(以时间为种子);然后把100个字节按顺序写入EEPROM中,写入完成后再把100个字节读出来并与写入的数值进行匹配,然后显示匹配结果。

执行结果

相关资源及连接

1、iTool2简易手册:

http://files.cnblogs.com/files/xiaomagee/iTool2%E6%89%8B%E5%86%8CV1.0.pdf

2、iTool2 购买地址:

https://item.taobao.com/item.htm?id=19090288084

3、代码包下载:

http://pan.baidu.com/s/1mgixgDU

4、本文PDF 下载:

http://pan.baidu.com/s/1kTvqxBD

附录:核心代码

usb.c:

 /*
* USB.C
*
* CH341H Driver.
* Designed By XiaomaGee 2015.11.05
*
*
*/ //--------------include files----------------//
#include <stdio.h>
#include <stdlib.h>
#include "usb.h" //--------------function prototype----------------// FP1_FT ch341_open,ch341_get_descr,ch341_close,ch341_set_stream,ch341_write_eeprom,ch341_read_eeprom;
FP2_FT ch341_get_driver_ver;
FP3_FT ch341_get_device_name; static int initialize_ch341(void);
static int open(unsigned long int);
static int close(unsigned long int);
static int set_stream(unsigned long int /* device_id */,unsigned long int /* mode */);
static int write_eeprom(unsigned long int /* device_id */,unsigned long int /* eeprom type */,unsigned long int /* address */,unsigned long int /* length */, unsigned char * /* buffer*/); static int read_eeprom(unsigned long int /* device_id */,unsigned long int /* eeprom type */,unsigned long int /* address */,unsigned long int /* length */, unsigned char * /* buffer*/); static unsigned long int get_driver_ver(unsigned long int);
static void * get_device_name(unsigned long int); //--------------varitable-----------------//
HMODULE ch341_handle; USB_T usb={
.initialize=initialize_ch341,
.open = open,
.close = close,
.set_stream = set_stream,
.get_driver_ver = get_driver_ver,
.get_device_name = get_device_name,
.write_eeprom = write_eeprom,
.read_eeprom = read_eeprom
}; //---------------function------------------//
/*
* write_eeprom
*
*
*
*/
static int write_eeprom(unsigned long int device_id ,unsigned long int type,unsigned long int address,unsigned long int length, unsigned char * buffer)
{
return ch341_write_eeprom(device_id,type,address,length,buffer);
}
/*
* read_eeprom
*
*
*
*/
static int read_eeprom(unsigned long int device_id ,unsigned long int type,unsigned long int address,unsigned long int length, unsigned char * buffer)
{
return ch341_read_eeprom(device_id,type,address,length,buffer);
} /*
* open
*
*
*
*/
static int open(unsigned long int id)
{
return ch341_open(id);
} /*
* close
*
*
*
*/
static int close(unsigned long int id)
{
int i; i=ch341_close(id);
FreeLibrary(ch341_handle); return i; }
/*
*
* set_stream
*
*
*
*/
static int set_stream(unsigned long int id,unsigned long mode)
{
return ch341_set_stream(id,mode);
}
/*
*
* get_driver_ver
*
*
*
*/ static unsigned long int get_driver_ver(unsigned long int id)
{
return ch341_get_driver_ver(id);
}
/*
* get_device_name
*
*
*
*/ static void * get_device_name(unsigned long int id)
{
return ch341_get_device_name(id);
} /*
* initialize
*
*
*
*/ static int initialize_ch341(void)
{ ch341_handle=LoadLibrary("CH341DLL.DLL"); ch341_open=GetProcAddress(ch341_handle,"CH341OpenDevice");
ch341_close=GetProcAddress(ch341_handle,"CH341CloseDevice");
ch341_get_descr=GetProcAddress(ch341_handle,"CH341GetDeviceDescr");
ch341_get_device_name=(FP3_FT)GetProcAddress(ch341_handle,"CH341GetDeviceName");
ch341_get_driver_ver=(FP2_FT)GetProcAddress(ch341_handle,"CH341GetDrvVersion"); ch341_set_stream=GetProcAddress(ch341_handle,"CH341SetStream"); ch341_read_eeprom = GetProcAddress(ch341_handle,"CH341ReadEEPROM");
ch341_write_eeprom = GetProcAddress(ch341_handle,"CH341WriteEEPROM"); return ;
}
 #include <stdio.h>
#include <stdlib.h>
#include <windows.h>
#include <math.h>
#include <time.h>
#include "usb.h" #define REV "0.1" /*
*
* initialize
*
*
*/ int initialize(void)
{
int len=,ver=;
char *p;
int i;
unsigned long int t;
unsigned char buf[]; usb.initialize(); system("cls");
printf("╔════════════════╗\r\n");
printf("║ ║\r\n");
printf("║ iTool2 I2C 功能测试程序 V%s ║\r\n",REV);
printf("║ ║\r\n");
printf("╠════════════════╣\r\n");
printf("║ Gingko Technology Co.,Ltd. ║\r\n");
printf("╚════════════════╝\r\n\r\n"); if(usb.open() == -){
printf("# 错误! 未连接 iTool2!\r\n");
return -;
}else {
printf("# 连接 iTool2 ............ 成功!\r\n\r\n");
} usb.set_stream(,0x80); return ;
} /*
*
* I2C test
*
*/
int i2c_test(void)
{
unsigned char write_buffer[];
unsigned char read_buffer[];
int i,j; printf("# 产生 100 字节随机数...... \r\n\r\n");
srand(time(NULL));
for(i = ; i < ; i ++)write_buffer[i] = rand()%; //打印随机数到屏幕
for(i = ; i < ; i ++){
for(j = ; j < ; j ++)printf(" %02X",write_buffer[i* + j]);
printf("\r\n");
}
printf("\r\n# 把随机数写入eeprom...... \r\n\r\n");
usb.write_eeprom(,,,,write_buffer); printf("# 从eeprom中读取数据...... \r\n\r\n");
memset(read_buffer,,); usb.read_eeprom(,,,,read_buffer); //打印随机数到屏幕
for(i = ; i < ; i ++){
for(j = ; j < ; j ++)printf(" %02X",read_buffer[i* + j]);
printf("\r\n");
} printf("\r\n# 测试 I2C 接口 .......... "); if(memcmp(write_buffer,read_buffer,) ==)printf("成功!");
else printf("失败!"); return ;
} /*
*
*
* main
*
*
*/
int main(int argc, char *argv[])
{
if(initialize() == -)goto end; i2c_test(); usb.close(); end: printf("\r\n\r\n");
system("Pause"); return ;
}

 makefile:

itool2_eeprom:main.o usb.o ico.o
gcc -o itool2_eeprom main.o usb.o ico.o
main.o:main.c
gcc -c main.c
usb.o:usb.c usb.h
gcc -c usb.c
ico.o:itool2.ico ico.rc
windres -i ico.rc -O coff -o ico.o
clean:
del *.o itool2_eeprom.exe *.*~

【应用笔记】【AN002】通过iTool2基于MinGW平台读写EEPROM的更多相关文章

  1. 搭建基于MinGW平台的《OpenGL蓝皮书(OpenGL SuperBibe 5th)》示例代码编译环境

    副标题:搭建基于MinGW平台的<OpenGL超级宝典>(OpenGL蓝皮书第5版)GLTools 编译环境.示例代码:Triangle.cpp @ SB5.zip 以下内容以及方法均参考 ...

  2. APPCAN学习笔记001---app高速开发AppCan.cn平台概述

    1.APPCAN学习笔记---app高速开发AppCan.cn平台概述 1. 平台概述 技术qq交流群:JavaDream:251572072 AppCan.cn开发平台是基于HTML5技术的跨平台移 ...

  3. 基于java平台的常用资源整理

    这里整理了基于java平台的常用资源 翻译 from :akullpp | awesome-java 大家一起学习,共同进步. 如果大家觉得有用,就mark一下,赞一下,或评论一下,让更多的人知道.t ...

  4. 基于X86平台的PC机通过网络发送一个int(32位)整数的字节顺序

    1.字节顺序 字节顺序是指占内存多于一个字节类型的数据在内存中的存放顺序,通常有小端.大端两种字节顺序.小端字节序指低字节数据存放在内存低地址处,高字节数据存放在内存高地址处:大端字节序是高字节数据存 ...

  5. 基于Linux平台的libpcap源码分析和优化

    目录 1..... libpcap简介... 1 2..... libpcap捕包过程... 2 2.1        数据包基本捕包流程... 2 2.2        libpcap捕包过程... ...

  6. 这里整理了基于java平台的常用资源

    这里整理了基于java平台的常用资源 翻译 from :akullpp | awesome-java 大家一起学习,共同进步. 如果大家觉得有用,就mark一下,赞一下,或评论一下,让更多的人知道.t ...

  7. 基于微软平台IIS/ASP.NET开发的大型网站有哪些呢?

    首先说明一下,本文绝不是要说Microsoft平台多么好,多么牛.只是要提醒一些LAMP/JAVA平台下的同志们,微软平台不至于像你们说的,和想象的那么不堪!只是你们自己不知道而已.同时,也希望广大M ...

  8. 基于android平台的斗地主AI

    本软件是基于android平台的斗地主AI,我们在源代码的基础之上,旨在改进AI的算法,使玩家具有更丰富的体验感,让NPC可以更为智能. (一)玩法解析: (1)发牌和叫牌:一副扑克54张,先为每个人 ...

  9. 一个基于.NET平台的自动化/压力测试系统设计简述

    AutoTest系统设计概述 AutoTest是一个基于.NET平台实现的自动化/压力测试的系统,可独立运行于windows平台下,支持分布式部署,不需要其他配置或编译器的支持.(本质是一个基于协议的 ...

随机推荐

  1. 【动态规划】skiing_深度搜索_动态规划

    问题 B: [动态规划]skiing 时间限制: 1 Sec  内存限制: 128 MB提交: 28  解决: 11[提交][状态][讨论版] 题目描述 Michael喜欢滑雪百这并不奇怪, 因为滑雪 ...

  2. Maven简介

    转载地址:http://www.cnblogs.com/itech/archive/2011/11/01/2231837.html Ant是软件构建工具,Maven的定位是软件项目管理和理解工具.Ma ...

  3. Integer取值范围和NumberFormatException的解决

    项目有个查询当地新闻的接口,从GEO文件中取得code,后台查询. 下午测试的时候查询日本:3920000000,结果报java.lang.NumberFormatException,数字格式化异常, ...

  4. 关于WM_CTLCOLOREDIT的处理的一些问题

    在为duilib封装系统控件的过程中, 再一次遇到了系统EDIT控件文字颜色/文字背景颜色的处理问题. 不要小看这个消息, 她很可能不会让你如愿以偿. 其实我要的目的很简单: 1. 改变文字颜色    ...

  5. Android JNI(转)

    JNI,全称Java Native Interface,是用于让运行在JVM中的Java代码和运行在JVM外的Native代码(主要是C或者C++)沟通的桥梁.代码编写者即可以使用JNI从Java的程 ...

  6. Codeforces Round #Pi (Div. 2) B. Berland National Library set

    B. Berland National LibraryTime Limit: 2 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest ...

  7. CodeForces 505B Mr. Kitayuta's Colorful Graph

    Mr. Kitayuta's Colorful Graph Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d ...

  8. WPF之资源字典zz

    最近在看wpf相关东西,虽然有过两年的wpf方面的开发经验,但是当时开发的时候,许多东西一知半解,至今都是模模糊糊,框架基本是别人搭建,自己也就照着模板写写,现在许多东西慢慢的理解了,回顾以前的若干记 ...

  9. ural 1242. Werewolf

    1242. Werewolf Time limit: 1.0 secondMemory limit: 64 MB   Knife. Moonlit night. Rotten stump with a ...

  10. Assets/Sciprts/GameSciprt.js(97,46): BCE0044: expecting :, found ','.

    function BuildDeck() { var totalRobots:int=4; var card:Object; var i:int; for(i=0;i<totalRobots;i ...