您的位置 首页 被动

TEA5767的简略收音机规划

TEA5767是飞利浦公司生产的一款收音机芯片,很多手机,MP3、MP4里的收音机功能都是于他实现的。TEA5767HN基本资料:高灵敏、低

TEA5767是飞利浦公司出产的一款收音机芯片,许多手机,MP3、MP4里的收音机功用都是于他完成的。

  TEA5767HN 基本资料:
   高活络、低噪声高频放大器,
   收音频率:87.6MHz~108MHz,(支撑频率范围在76MHz~87.5MHz 之间的学校收音频道),
   LC 调谐振荡器使本钱更低,RF AGC 电路
   内置调频中频挑选 ,I2C 总线操控
   内置FM 立体声解调器 ,PLL 组成调谐解码器
   两个可编程端口 ,软静音,SNC(立体声噪声消除)
   自适应立体声解码,主动查找功用
   等候形式,需求一个32.768KHz 晶体
   40 脚LQFP 封装

CPU:STC89C54RD+
晶震:40M

#include
#include
#include

sbit SDA_5767=P1^0; //数据
sbit SCL_5767=P1^1; // 时钟
sbit BUS_MODE=P1^2; // 总线挑选
sbit BUS_ENABLE=P1^3; // 总线使能

#define max_freq 108000 //108Mhz
#define min_freq 87500 //87.5Mhz
#define max_pll 0x339b //108MHz时的pll.
#define min_pll 0x299d //87.5MHz时的pll.
#define KEY P2 //P2口作为按键

#define WADDR 0XC0 //写地址
#define RADDR 0XC1 //读地址

unsigned char write_data[5]={0x2b,0x05,0x61,0x11,0x40}; //每次写入5字节 注释如下(感觉有用的注下 具体了解看手册)
//write_data[0] 第二位为1为查找形式 后6为表明收音机频率的高6位
//write_data[1] 表明收音机频率的低8位
//write_data[2] 最高位表明查找形式是向上仍是向下 后两位表明查找的活络度 第四位立体声和单声道挑选位后四为左右声道设置
//write_data[3] 第三位表明日本频率和世界频率挑选位 第四位 震动频率挑选位(与第五字节最高位一起决议)第七为数字降噪功用挑选
//write_data[4] 最高位决议内部震动频率
unsigned char read_data[5]; //读取5字节 读以上各寄存器的状况 主要是频率读取

unsigned long frequencry=0; //32位读取频率数据
unsigned int pll; //16位转化数据

void delay(void) //延时函数
{
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
}

void start_5767(void)//开始
{
BUS_ENABLE=1;
SDA_5767=1;
SCL_5767=1;
delay();
SDA_5767=0;
delay();
SCL_5767=0;
}

void stop_5767(void)//中止
{
SDA_5767=0;
SCL_5767=1;
delay();
SDA_5767=1;
delay();
SCL_5767=0;
BUS_ENABLE=0;
}

void Check_Ack(void) //查看应对信号
{
SDA_5767=1;
SCL_5767=1;
F0=0;
delay();
if(SDA_5767) //假如数据为高 置位非应对标志FO
F0=1; //通用标志位 PSW状况寄存器
SCL_5767=0; //预备下一改变数据
}

void Ack(void) //发呼应信号
{
SDA_5767=0;
delay();
SCL_5767=1;
delay();
SCL_5767=0;
}

void no_Ack(void) //发非呼应信号
{
SDA_5767=1;
SCL_5767=0;
delay();
SCL_5767=1; //迫使数据传输完毕
delay();
}

void send_byte(unsigned char temp) //发送一字节数据
{
unsigned char i=8;
while(i–)
{
SDA_5767=(bit)(temp&0x80);
SCL_5767=1;
delay();
SCL_5767=0;
temp<<=1;
}
SCL_5767=0;
delay();
SDA_5767=1; //开释SDA数据线
}

unsigned char read_byte(void) //读一字节数据
{
unsigned char i=8;
unsigned char temp;
while(i–)
{
temp<<=1;
if(SDA_5767)
temp++;
SCL_5767=1;
delay();
SCL_5767=0;
}
SCL_5767=0;
delay();
SDA_5767=1; //开释SDA数据线
return (temp);
}

void write_radio()
{
unsigned char i;
start_5767();
send_byte(WADDR);
Check_Ack();
if(F0)
{
no_Ack();
return;
}
Ack();
for(i=0;i<5;i++)
{
send_byte(write_data[i]);
Check_Ack();
if(F0)
{
no_Ack();
return;
}
Ack();
}
stop_5767();
}

void read_radio()
{
unsigned char i;
start_5767();
send_byte(RADDR);
Check_Ack();
if(F0)
{
no_Ack();
return;
}
Ack();
for(i=0;i<5;i++)
{
read_data[i]=read_byte();
Check_Ack();
if(F0)
{
no_Ack();
return;
}
Ack();
}
stop_5767();
}

unsigned int get_radio() //获得频率数据
{
unsigned char tmp_h,tmp_l;
read_radio();
tmp_h=read_data[0]&0x3f;
tmp_l=read_data[1];
return (tmp_h<<8|tmp_l);
}

void get_frequencry() //将数据转化为规范频率
{
unsigned char tmp_data;
unsigned int pll_data;
pll_data=get_radio();
tmp_data=read_data[2]&0x10;
if(tmp_data)
frequencry= (pll_data*32768/4-225000)/1000; //(单位KHZ)
else
frequencry= (pll_data*32768/4+225000)/1000; // (单位KHZ)
}

void get_pll() //将频率转化数据
{
unsigned char tmp_data;
unsigned int pll_data;
unsigned long tmp_pll;
pll_data=get_radio();
tmp_data=read_data[2]&0x10;
if(tmp_data)
tmp_pll=(frequencry+255000)*4/32768;// (单位HZ)
else
tmp_pll=(frequencry-255000)*4/32768; //(单位HZ)
pll=(unsigned int)(tmp_pll/1000); //(单位 KHZ)
}

void search(bit mode) //手动搜台
{
get_frequencry();
if(mode)
{
frequencry+=100;
if(frequencry>max_freq)
frequencry=87500;
}
else
{
frequencry-=100;
if(frequencry frequencry=108000;
}
get_pll();
write_data[0]=(pll>>8)&0x3f;
write_data[1]=pll&0xff;
write_data[2]=0x61;
write_data[3]=0x11;
write_data[4]=0x40;
write_radio();
}

void auto_search(bit mode) //主动搜台
{
get_frequencry();
get_pll();
if(mode)
{
write_data[2]=0xe1;
if(pll>max_pll)
pll=min_pll;
}
else
{
write_data[2]=0x61;
if(pllpll=max_pll;
}
write_data[0]=(pll>>8)&0x3f+0x40; //主动搜台
write_data[1]=pll&0xff;
write_data[2]=0x61;
write_data[3]=0x11;
write_data[4]=0x40;
write_radio();
read_radio();
while(!(read_data[0]&0x80)) //最高位为1 电台安排妥当 不然一直读
{
read_radio();
}
}

void delay_xms(unsigned int count) //1MS延时函数
{
register unsigned char j;
while (count –)
{
for (j=0;j<230;j++);
}
}

unsigned char GetKey() //键盘处理函数
{
unsigned char m,n,e=0xff;

KEY = 0x0f; //键盘口置00001111
if (KEY != 0x0f) //查寻键盘口的值是否改变
{
delay_xms(20); //延时20毫秒
if (KEY != 0x0f) //有键按下处理
{
m = KEY; //键值放入寄存器m
}
KEY = 0xf0; //将键盘口置为11110000
n = KEY; //将第2次获得值放入寄存器n
m |= n;
switch(m)
{
case 0x7e: e = 0x00; break;
case 0xbe: e = 0x01; break;
case 0xde: e = 0x02; break;
case 0xee: e = 0x03; break;
case 0x7d: e = 0x04; break;
case 0xbd: e = 0x05; break;
case 0xdd: e = 0x06; break;
case 0xed: e = 0x07; break;
case 0x7b: e = 0x08; break;
case 0xbb: e = 0x09; break;
case 0xdb: e = 0x0a; break;
case 0xeb: e = 0x0b; break;
case 0x77: e = 0x0c; break;
case 0xb7: e = 0x0d; break;
case 0xd7: e = 0x0e; break;
case 0xe7: e = 0x0f; break;
default: break;
}
}

KEY = 0x0f;
while (KEY != 0x0f);

return (e);
}

void main(void)
{
unsigned char i;
TMOD = 0x11;
TH0 = 0x5d;
TL0 = 0x3d;
TR0 = 0;
TH1 = 0x5d;
TL1 = 0x3d;
TR1 = 0;
PCON = 0x00;
SCON = 0xD0;
IP = 0x14;
EX0 = 1;
IT0 = 1;
ET0 = 1;
EX1 = 1;
IT1 = 1;
ES = 0;
EA = 0;
BUS_MODE=0;
write_radio();//初始写入 90M
frequencry = 90000;

while(1)
{
i = GetKey();

switch (i)
{
case 0x00:
search(1);
break;

case 0x01:
search(0);
break;


case 0x02:
auto_search(1);
break;

case 0x03:
auto_search(0);
break;

default: break;
}
}
}

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/ziliao/beidong/263114.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部