lpc1788IO口模拟IIC

#ifndef __MYIIC_H_

#define __MYIIC_H_

#include "common.h"

#include "delay.h"

#include "debugserial.h"

//sda 027 scl 028

//IO方向设置

#define IIC1_SDA_IN()  P0dir(27) = 0

#define IIC1_SDA_OUT() P0dir(27) = 1

//IO操作函数

#define IIC1_READ_SDA   P0in(27)    //输入SDA

void my_iic_init(void);                 //初始化IIC的IO口

void my_iic_start(void);                //发送IIC开始信号

void my_iic_stop(void);                 //发送IIC停止信号

void my_iic_sendByte(u8 txd);           //IIC发送一个字节

u8   my_iic_readByte(void); //IIC读取一个字节

u8   my_iic_waitAck(void);              //IIC等待ACK信号

void my_iic_ack(void);                  //IIC发送ACK信号

void my_iic_nAck(void);                 //IIC不发送ACK信号

#endif

#include "myiic.h"

//该驱动针对模拟IIC操作

void my_iic_init(void)                  //初始化IIC的IO口

{

LPC_SC->PCONP |= (1<<15);

LPC_IOCON->P0_27 = 0x00;//选择gpio功能,禁止迟滞 不反向 正常推挽

LPC_IOCON->P0_27 |= (1<<8);//与引脚配置相关 根据实际引脚进行修改

LPC_IOCON->P0_28 = 0x00;//选择gpio功能,禁止迟滞 不反向 正常推挽

LPC_IOCON->P0_28 |= (1<<8);//与引脚配置相关 根据实际引脚进行修改

P0dir(27) = 1;//scl输出

P0dir(28) = 1;//sda输出

P0high(27) = 1;//初始化都是高电平

P0high(28) = 1;

}

void my_iic_start(void)             //发送IIC开始信号

{

IIC1_SDA_OUT();     //sda线输出

P0high(27)=1;       //SDA HIGH

P0high(28)=1;       //SCL HIGH

DelayUs(5);

P0low(27)=1;        //SDA LOW

DelayUs(5);

P0low(28)=1;        //SCL LOW

}

void my_iic_stop(void)                  //发送IIC停止信号

{

IIC1_SDA_OUT();     //sda线输出

P0high(28)=1;       //SCL HIGH

P0low(27)=1;        //SDA LOW

DelayUs(5);

P0high(27)=1;       //发送I2C总线结束信号 SDA HIGH

DelayUs(5);

}

void my_iic_sendByte(u8 txd)            //IIC发送一个字节

{

u8 t;

IIC1_SDA_OUT();

for(t=0;t<8;t++)

{

if(((txd&0x80)>>7))

P0high(27) = 1;

else

P0low(27) = 1;

txd<<=1;

P0high(28)=1;   //SCL HIGH

DelayUs(5);

P0low(28)=1;    //SCL LOW

DelayUs(5);

}

}

u8   my_iic_readByte(void)  //IIC读取一个字节

{

unsigned char i,receive=0;

IIC1_SDA_IN();//SDA设置为输入

for(i=0;i<8;i++ )

{

receive<<=1;

P0high(28)=1;           //SCL HIGH

DelayUs(5);

if(IIC1_READ_SDA)receive++;

P0low(28)=1;            //SCL LOW

DelayUs(5);

}

return receive;

}

u8   my_iic_waitAck(void)               //IIC等待ACK信号

{

u8 ucErrTime=0;

IIC1_SDA_OUT();

P0high(27)=1;       //SDA HIGH

DelayUs(5);

IIC1_SDA_IN();              //SDA设置为输入

P0high(28)=1;               //SCL HIGH

DelayUs(5);

while(IIC1_READ_SDA)

{

ucErrTime++;

DelayUs(1);

if(ucErrTime>250)

{

my_iic_stop();

return 1;

}

}

P0low(28)=1;                //时钟输出 SCL LOW

DelayUs(5);

return 0;

}

void my_iic_ack(void)                   //IIC发送ACK信号

{

IIC1_SDA_OUT();

P0low(27)=1;        //SDA LOW

DelayUs(2);

P0high(28)=1;       //SCL HIGH

DelayUs(5);

P0low(28)=1;        //SCL LOW

DelayUs(5);

}

void my_iic_nAck(void)                  //IIC不发送ACK信号

{

IIC1_SDA_OUT();

P0high(27)=1;       //SDA HIGH

DelayUs(2);

P0high(28)=1;       //SCL HIGH

DelayUs(5);

P0low(28)=1;        //SCL LOW

DelayUs(5);

}

时间: 2024-09-29 02:02:32

lpc1788IO口模拟IIC的相关文章

51单片机GPIO口模拟串口通信

51单片机GPIO口模拟串口通信 标签: bytetimer终端存储 2011-08-03 11:06 6387人阅读 评论(2) 收藏 举报 本文章已收录于: 分类: 深入C语言(20) 作者同类文章X 1 #include "reg52.h" 2 #include "intrins.h" 3 #include "math.h" 4 #include "stdio.h" 5 sbit BT_SND =P1^5; 6 sbit

stm32软件模拟IIC读取PX4FLOW光流传感器数据

这段时间在做全国光电设计大赛,用到了px4的px4flow光流传感器,用软件模拟iic读取数据不定期会导致px4flow死机,查了资料和光流的源码,发现这个光流用了stm32的硬件iic,所以对软件模拟iic的时序要求可能更高一点所以在原子哥的iic程序上做了修改,代码测验后已经不会死机,做个笔记,保存一下. 1 #include "myiic.h" 2 #include "delay.h" 15 16 //初始化IIC 17 void IIC_Init(void)

单片机模拟 IIC 总线与 EEPROM(AT24C02)通信

数据有效性: 起始和终止信号时序: 设备地址: 写字节时序: 读数据时序: 函数模拟 IIC 总线 时序: /**************************************/ /******模拟I2C总线操作函数*************/ /**************************************/ //延时函数 void Delay() { ; ; } //初始化 void I2C_Init() { SDA = 1; SCL = 1; } //起始信号 vo

GPIO模拟IIC接口信号质量分析

信号质量有问题的波形001: 信号质量有问题的波形002: 从上图可以看出,GPIO口模拟的I2C接口,电平都存在半高的情况. 因为MFI芯片的I2C采用的GPIO口模拟I2C接口来实现的此功能,原SCL采用的GPB7(内部默认为上拉状态),因为GPIO资源的调整,SCL改为GPD12(内部默认为下拉状态),因SCL对应的GPIO口内部有下拉电阻,导致在输出为高电平时,上升沿慢的台阶出现.软件后面把GPD12的内部下拉电阻disable之后,测试的波形如上图所示,从上图可以看出SCL时钟信号已经

用s5pc100的GPIO模拟IIC

转载:http://blog.chinaunix.net/uid-26833883-id-3823530.html 一.硬件连线 先来看看LM75硬件的上的连线: 其中I2C_SDA0是数据线,I2C_SCL0是时钟线,它们分别接到s5pc100的GPD3和GPD4,如下图所示 在模拟IIC的时候,用GPD3引脚发送数据或读取数据,用GPD4引脚提供时钟信号即可. 二.数据结构 由于s5pc100的GPD这一组的引脚很多,不好单独对其中的某一个引脚操作,为了能单独对其中的某一个管脚单独操作,这里

stm32 普通IO口模拟串口通信

普通IO口模拟串口通信 串口通信协议 串口传输 默认 波特率9600 1起始位 1停止位 其他0 数据位是8位(注意图上的给错了). 传输时,从起始位开始,从一个数据的低位(LSB)开始发送,如图从左向右的顺序,对电平拉高或拉低,最后停止位时拉高. 波特率大小,改变延时时间即可.例如9600 波特率    根据公式 : 1/9600=0.000104s(大致) 也就是说每发送1bit延时104us (下面我用9600波特率来说,代码用的是19200) 串口发送       将电平拉低 延时104

使用linux内核hrtimer高精度定时器实现GPIO口模拟PWM,【原创】

关键词:Android  linux hrtimer 蜂鸣器  等待队列 信号量 字符设备 平台信息:内核:linux3.4.39 系统:android/android5.1平台:S5P4418  作者:庄泽彬(欢迎转载,请注明作者) 邮箱:[email protected] 程序描述:本文控制的设备是无源蜂鸣器,由于无源蜂鸣器是需要产生一定的频率的PWM才能够控制蜂鸣器,不像有源蜂鸣器,只需要提供高低电平就可以控制蜂鸣器.linux内核普通的定时器,由于具有一定的局限性,不能达到纳秒级别的定时

模拟IIC协议时序

IIC是飞利浦公司开发的两线式串行总线,主要应用在单片机和外围电子器件之间的数据通讯. IIC总线优点是节约总线数,稳定,快速,是目前芯片制造上非常流行的一种总线,大多数单片机已经片内集成了IIC总线接口,无需用户自己模拟,只需配置相关寄存器即可使用,但是,为了更好地理解IIC总线协议,可以自行按照IIC时序图进行模拟,加深理解. IIC总线有两条串行线,其一是时钟线SCK,其二是数据线SDA. 在寻常的应用之中,单片机常常作为主机,外围器件作为从机使用. 每一个从机器件都拥有唯一的一个地址,这

用I/O口模拟总线时序

在做总线通信过程中,我们很少会用到这样方法,一般在我们选择MCU的时候都会带有你所需要的通信接口.但是,对于一些简单的通信应该用的场合,一般在一些传感器的数据通信过程中,传感器厂商会将通信协议做一些改变,这些通信协议也没有一个标准的协议规定.以至于传感器的兼容性很差,甚至有时候找不到能够与其通信的MCU,这个时候有一种方法就是用I/O口来模拟通信总线(由于I/O速度的限制一般只适用于低速的通信总线)的时序.之前,用I2C通信做一个温湿度测量的工程,本篇文章就以一个例子来看看如何用I/O口对总线时