S3C2440硬件IIC详解
S3C2440A RISC微处理器可以支持一个多主控IIC 总线串行接口。一条专用串行数据线(SDA)和一条专用串行时钟线(SCL)传递连接到IIC总线的总线主控和外设之间的信息。SDA和SCL线都为双向的
图上可见,IIC时钟从PCLK产生,并同时受到IICSTAT控制,IIC数据实际上是由一个移位寄存器送出,当IIC处于从机状态的时候,有一个地址比较器来检测IIC总线,使用IIC总线主要有以下寄存器需要设置
1. 设置相应的端口复用为IIC端口,启用IIC时钟,连接IIC的中断,自然还需要设置IIC相应的中断,这些在上一节已经描述过,现在不赘述
2. 设置控制寄存器
设置应答使能IIC时钟,IIC发送时钟,IIC中断等
3. 设置想要发送的从机地址
4. 修改IIC总线的状态,并启用发送
5. 在发送过程中,检测IIC不同的状态作相应的操作
具体使用过程将下列代码
Iic.c
#include "iic.h" u8 flag = 0; //中断标志(在中断子程序里清零,即未中断flag=1,中断后flag=0) void __irq I2CInt(void) //中断子程序
{
rSRCPND |= BIT_IIC;//清除源挂起
rINTPND |= BIT_IIC;//清除中断挂起
flag=0;
} void I2CInit(void)
{
rCLKCON |= (1<<16); //打开IIC时钟
rGPEUP |= 0xc000; //关上拉 rGPECON &= ~0xf0000000;
rGPECON |= 0xa0000000; //GPE15:IICSDA , GPE14:IICSCL pISR_IIC=(unsigned)I2CInt; //设置中断程序地址 rSRCPND |= BIT_IIC;//清除源挂起
rINTPND |= BIT_IIC;//清除中断挂起
rINTMOD &= ~BIT_IIC;//设置中断模式为IRQ模式 //使能应答, IIC总线时钟IICCLK=PCLK/16, 使能中断, 发送时钟IICCLK/16
rIICCON = (1<<7) | (0<<6) | (1<<5) | (0xf); rIICADD = 0x10; //2440 从机地址 = [7:1] 0位自动代表输入输出
rIICSTAT = 0x10; //IIC总线数据输出使能(Rx/Tx)
rINTMSK &=~(BIT_IIC); //开中断源
} //IIC主机发送数据,
void IICMasterWriteData(u8 data)
{
flag=1;
rIICDS = data; //从器件地址写入数据移位寄存器
rIICSTAT=0xf0; //主发模式,产生起始信号,使能Rx/Tx
rIICCON &=~0x10; //清除Tx/Rx中断挂起标志
while(flag==1) //等待发送完成
DelayMs(1);
} //IIC从机发送数据
void IICSlverWriteData(u8 data)
{
flag=1;
rIICDS = data;
rIICSTAT=0xb0; //主接收模式,使能Rx/Tx
rIICCON &=~0x10; //清除Tx/Rx中断挂起标志
while(flag==1) //等待发送完成
DelayMs(1);
} //iic普通数据发送,应该在配置好主机发送或者从机发送之后
void IICWriteData(u8 data)
{
flag=1;
rIICDS = data; //写入存储字节的地址到数据移位寄存器
rIICCON &=~0x10; //清除Tx/Rx中断挂起标志
while(flag==1) //等待发送完成
DelayMs(1);
}
//iic禁止发送接收中断
void IICStopRxTx(void)
{
rIICSTAT = 0xd0; //禁止Rx/Tx
rIICCON = 0xaf; //Resumes IIC operation. iic复位操作
DelayMs(1);
} //iic禁止接收中断
void IICStopRx(void)
{
rIICSTAT = 0x90; //Stop MasRx condition
rIICCON = 0xaf; //Resumes IIC operation.
DelayMs(1); //Wait until stop condtion is in effect.
}
Iic.h
#ifndef __IIC_H_
#define __IIC_H_
#include "2440addr.h"
#include "def.h"
#include "uart0.h"
#include "delay.h" extern u8 flag; void I2CInit(void);
void IICMasterWriteData(u8 data);
void IICSlverWriteData(u8 data);
void IICWriteData(u8 data);
void IICStopRxTx(void);
void IICStopRx(void); #endif
At24c02.c
#include "at24c02.h" void AtWriteByte(u8 regAddr,u8 data)
{
IICMasterWriteData(AT_DEVICE_ADDR); IICWriteData(regAddr); IICWriteData(data); IICStopRxTx();
} u8 AtReadByte(u8 regAddr)
{
u8 temp = 0;
IICMasterWriteData(AT_DEVICE_ADDR);
IICWriteData(regAddr);
IICSlverWriteData(AT_DEVICE_ADDR);
//注意:读取下面这个字节必须进行,因为在发送带有读命令的从设备地址后,
//AT24C02A会再返回一个从设备地址信息或从设备内存地址信息作为应答,所以
//一定要把该字节读取后抛弃,因为它不是我们所要读取的信息;也就是一次伪读取过程
flag=1;
temp=rIICDS;
rIICCON &=~0x10; //清除Tx/Rx中断挂起标志
while(flag==1)
DelayMs(1); rIICCON=0x2f; //Resumes IIC operation.禁止应答
temp=rIICDS;
DelayMs(1); IICStopRx(); //Wait until stop condtion is in effect.
return temp;
} //返回1检测失败 返回0检测成功
u8 AtCheck(void)
{
u8 test = 0x88;
AtWriteByte(0x01,test);
DelayMs(10);
test = 0x99;
test = AtReadByte(0x01);
if(test == 0x99)return 1;
else return 0;
}
At24c02.h
#ifndef __AT24C02_H_
#define __AT24C02_H_ #include "iic.h" #define AT_DEVICE_ADDR 0xa0 void AtWriteByte(u8 regAddr,u8 data); u8 AtReadByte(u8 regAddr); u8 AtCheck(void); #endif
注意发送过程中附带起始信号以及模式的转变,以及中断接收到信号之后数据的变化
S3C2440硬件IIC详解的更多相关文章
- S3C2440时钟系统详解
在讲述系统时钟之前,因为这些设备都是挂靠在系统时钟上的,所以必须先说系统时钟,S3C2440的时钟系统如下 外部时钟源分两种,晶振或者外部频率,由om3-2选择,时钟电路根据两种选择也有两种 我们来分 ...
- IIC详解
(1)概述 I2C(Inter-Integrated Circuit BUS) 集成电路总线,该总线由NXP(原PHILIPS)公司设计,多用于主控制器和从器件间的主从通信,在小数据量场合使用,传输距 ...
- s3c2440存储控制器详解
从上图可知,外部内存类的设备与存储管理器相连,那么CPU是怎样访问到内存的呢?通过存储管理器.CPU比较单纯,只会按照指令执行,CPU只负责发出地址,怎样找到内存类设备呢?这些都交给存储管理器来管理. ...
- STM32硬件调试详解
STM32的基本系统主要涉及下面几个部分: 一.电源 1).无论是否使用模拟部分和AD部分,MCU外围出去VCC和GND,VDDA.VSSA.Vref(如果封装有该引脚)都必需要连接,不可悬空: 2) ...
- S3C2440 TFTLCD驱动详解
S3C2440自带有LCD控制器,该控制器主要有以下接口 仅仅说TFT显示器,TFT显示器的时序如下 TFT显示器的驱动是以行列的形式逐点扫描过来的,驱动时钟有三种,一种是行时钟,一种是列时钟,还有一 ...
- s3c2440系统时钟详解
一.S3C2440系统时钟体系 S3C2440的时钟控制逻辑可以外接晶振,然后通过内部电路产生时钟源:也可以直接使用内部提供的时钟源,他们通过引脚的设置来选择.时钟逻辑给整个芯片提供了3中时钟:FCL ...
- Android--hardwareAccelerated 硬件加速详解 android:largeHeap="true"
做项目时,引导页面的ViewPager报了OOM异常,图片并不大,在清单文件Application节点中添加了两行代码就解决了这个问题 android:hardwareAccelerated=&quo ...
- Android:BLE智能硬件开发详解
目录 前言 BLE是个什么鬼 BLE中的角色分工 主要的关键词和概念 GATT(Generic Attribute Profile ) Characteristic Service Android如何 ...
- S3C2440内存控制器详解
S3C2440A Memory Map after Reset S3C2440的内存空间划分为不同的块,当CPU向内存控制器发出地址,内存控制器根据地址范围,发出对应片选信号到片选引脚,实现对不同设备 ...
随机推荐
- Android 系统编译
最近研究了下Android 的编译系统,下面结合编译我们自己的产品 mobot 来对整个编译系统进行必要的介绍,方便大家今 后对默认编译的修改. 先列出几个觉得重要的Make 文件: build/bu ...
- lucene-SpanFirstQuery 和SpanNearQuery 跨度查询
1.SpanFirstQuery查询 对出现在一个域中前n个位置的跨度查询. public void testSpanFirstQuery() throws Exception{ SpanzFirts ...
- 8--UI 初步认识 简易计算器
UI是App的根基:一个App应该是先有UI界面,然后在UI的基础上增加实用功能(2)UI相对简单易学:UI普遍是学习过程中最简单的一块,能快速拥有成就感和学习兴趣(3)UI至关重要:开发中的绝大部分 ...
- MFC设置窗体大小SetWindowPos
SetWindowPos(NULL,0,0,200,300,SWP_NOMOVE); 表示不考虑(0,0),仅仅将大小改为200x300,位置不变 SetWindowPos(NULL,0,0,2 ...
- Redis(1)在windows环境下的安装和测试
初次准备使用redis,一个著名的nosql缓存数据库. 这里是第一天,就简单写一下windows下的安装,遇到的一些问题,然后简单的使用和测试,之后会在代码中使用和测试. 之后还会在生产环境中进行测 ...
- MyEclipse8.5优化经验
第一步: 取消自动validation validation有一堆,什么xml.jsp.jsf.js等等,我们没有必要全部都去自动校验一下,只是需要的时候才会手工校验一下! 取消方法: ...
- Eclipse的Java工作集和多工程构建路径
一.Java工作集: Eclipse有一个小功能,就是创建Java Working Set.它的作用是解决Package Explorer窗格中创建很多工程时出现拥挤的麻烦. 在创建(New对话框)时 ...
- HDU 2546 饭卡 01背包变形
题目大意:中文题就不多说了 题目思路:由题意可知,只要高于5元,就可以随便刷,那我们就把最贵的留在最后刷.但是如果低于5元就什么也不能刷(哪怕你要买的物品价格不足五元),所以我们可以先求出(n-5)元 ...
- NSDate,NSCalendar
NSLog(@"%@",[NSDate date]); 打印结果: 2015-06-30 08:42:14 +0000 把它转换成2015年6月30日 8时42分14秒 怎么转? ...
- linux 备份系统
切换到root用户 切换到根目录 tar cvpzf backup.tgz --exclude=/proc --exclude=/lost+found --exclude=/backup.tgz -- ...