導航:首頁 > 操作系統 > 單片機dsport

單片機dsport

發布時間:2022-12-28 05:44:57

① 請教下單片機中什麼叫埠位

在單片機中!每一個埠都對應一個bit位!我們可以直接操作單片機的埠!!

例如:P1^1 = 0;就是將P1埠的第二位拉低。P1^1 = 1;就是將P1埠的第二位拉拉高。

計算機中的操作數有三類:立即數(常數)、寄存器操作數、存儲器操作數,所以定址方式就是針對這三類操作數進行的。
立即數和寄存器操作數的定址比較簡單,對應的是立即定址和寄存器定址,比較多的是存儲器定址方式,有直接定址(指令中可以看到內存的地址)、寄存器間接定址(寄存器的內容作為內存的地址),從寄存器間接定址進一步發展就有:相對寄存器定址、基址變址定址和相對基址變址定址。
定址格式中,加方括弧的是地址,沒加方括弧的是操作數,比如:2000H是立即數,[2000H]是內存的地址;BX是寄存器BX裡面的數據,[BX]是BX的數據作地址。
1、MOV ES,AX 都是寄存器定址
2、ADD DS:[12H],AL 源:寄存器定址 目的:直接定址
3、SUB BX,1200H 源:立即定址 目的:寄存器定址
4、SHR AX,1 源:立即定址 目的:寄存器定址
5、MOV CX.LAB1[BX] 源:相對寄存器定址 目的:寄存器定址
6、SBB AX,[BX] 源:寄存器間接定址 目的:寄存器定址
7、OR DX,-360H[SI] 源:相對寄存器定址 目的:寄存器定址
8、ADC VAR1,CX 源:寄存器定址 目的:直接定址
9、XOR [DI],AX 源:寄存器定址 目的:寄存器間接定址

這只是給你復習單片機使用!具體源操作數指接收的數據 包括地址等。目的操作數指結果。

② 51單片機的串列通信

這個是單片機用18b20採集溫度,傳給電腦的程序;電腦那端用VB里的串口控制項就能捕獲了,你可以吧裡面發送出去的數據換成你採集的 你想加我的qq也行
-----------------------------------------
#include <AT89X51.H>
#include <intrins.h>
#define Key_UP P1_0
#define Key_DOWN P1_1
#define Key_SET P1_2
#define RelayOutPort P2_0
#define LEDPort P0
#define DELPort P2_1
#define LEDTwoC P3_6
#define LEDThreeC P3_7
#define TMPort P2_7
#define INBUF_LEN 5 //數據長度
unsigned char inbuf1[INBUF_LEN]={'0','0','0','0','0'};//發送緩沖區
unsigned char inbuf2[50];//接收緩沖區
unsigned char count3;
void init_serialcomm( void )
{
SCON = 0x50 ; //SCON: serail mode 1, 8-bit UART, enable ucvr
TMOD |= 0x20 ; //TMOD: timer 1, mode 2, 8-bit reload
PCON |= 0x80 ; //SMOD=1;
TH1 = 0xFA ; //Baud:4800 fosc=11.0592MHz
IE |= 0x90 ; //Enable Serial Interrupt
TR1 = 1 ; // timer 1 run
}
//向串口發送一個字元
void send_char_com( unsigned char ch)
{
SBUF=ch;
while (TI== 0 );
TI= 0 ;
}
//向串口發送一個字元串,strlen 為該字元串長度
void send_string_com( unsigned char *str, unsigned int strlen)
{
unsigned int k= 0 ;
do
{
send_char_com(*(str + k));
k++;
} while (k < strlen);
}
//串口接收中斷函數
void serial () interrupt 4 using 3
{
if (RI) //RI==開始接收
{
unsigned char ch;
RI = 0 ; //軟體RI=0
ch=SBUF;
if (ch> 1 )
{
count3= 0 ;
inbuf2[count3]=ch;
}
else
{
count3++;
inbuf2[count3]=ch;
}
}
} unsigned char code LEDDis[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0xFF,0xBF}; //0-9的LED筆劃,0xFF為空,0xF7為負號
unsigned char dis_8[12]={'0','1','2','3','4','5','6','7','8','9',' ','-'};
static unsigned char bdata StateREG; //可位定址的狀態寄存器
sbit DS1820ON = StateREG^0; //DS1820是否存在
sbit SetTF = StateREG^1; //是否是在溫度設置狀態
sbit KeySETDown = StateREG^2; //是否已按過SET鍵標識
sbit PowTF = StateREG^3; //電源電源標識
sbit KeyTF = StateREG^4; //鍵盤是否允許//sbit KeySETDowning = StateREG^5; //SET是否正在按下
static unsigned char bdata TLV _at_ 0x0029; //溫度變數高低位
static unsigned char bdata THV _at_ 0x0028;
static signed char TMV; //轉換後的溫度值
static unsigned char KeyV,TempKeyV; //鍵值
static unsigned char Second;
static unsigned char flag;
static signed char TMRomV _at_ 0x0027; //高溫限制
static signed char TMSetV _at_ 0x0026; //溫度設定值
static unsigned char KSDNum; //SET鍵連按時的採集次數
static unsigned char IntNum,IntNum2,IntNum3; //中斷發生次數,IntNum用於SET長按檢測,IntNum2用於設定狀態時LED閃爍
static signed char LED_One,LED_Two,LED_Three; //LED的顯示位 LED_One為十位,LED_Two為個位
static unsigned char Sign; //負號標識void main(void)
{ void InitDS1820(void); //定義函數
void ROMDS1820(void);
void TMVDS1820(void);
void TMRDS1820(void);
void TMWDS1820(void);
void TMREDS1820(void);
void TMERDS1820(void);
void ReadDS1820(void);
void WriteDS1820(void);
void Delay_510(void);
void Delay_110(void);
void Delay_10ms(void);
void Delay_4s(void);
void V2ToV(void);

DELPort=1;
StateREG = 0; //初始化變數
SetTF = 0;
PowTF = 0; //關電源
THV = 0;
TLV = 0;
TMV = 0;
KeyV = 0;
TempKeyV = 0;
KSDNum = 0;
IntNum = 0;
IntNum2 = 0;
IntNum3 = 0;
LED_One = 0;
LED_Two = 0; InitDS1820(); //初始化
ROMDS1820(); //跳過ROM
TMERDS1820(); //E2PRAM中溫度上限值調入RAM
InitDS1820(); //初始化
ROMDS1820(); //跳過ROM
TMRDS1820(); //讀出溫度指令
ReadDS1820(); //讀出溫度值和上限值
TMSetV = TMRomV; //拷貝保存在DS18B20ROM里的上限值到TMSetV EA = 1; //允許CPU中斷
ET0 = 1; //定時器0中斷打開
TMOD = 0x1; //設定時器0為模式1,16位模式
TH0=0xB1;
TL0=0xDF; //設定時值為20000us(20ms)
TR0 = 1;

while(1){ //開始定時
if (flag==0){
if (Second==1){
Delay_4s();
Delay_4s();
Delay_4s();
Delay_4s();
Delay_4s();
Delay_4s();

DELPort=0;
Second=0;
}
}
}

}//定時器0中斷外理中鍵掃描和顯示
void KeyAndDis_Time0(void) interrupt 1 using 2
{
TH0=0xB1;
TL0=0xDF; //設定時值為20000us(20ms) LEDPort = 0xFF;

if (inbuf2[0]==0x33){
send_char_com('O');
send_char_com('O');
send_char_com('O');
SetTF = 1;
//send_string_com(inbuf2,1);
//BEEP=0;
//RELAY=0;
send_char_com('O');
//inbuf2[0]=0x00;
inbuf2[0]=0x00;
} if (inbuf2[0]==0x36){//send_string_com(inbuf2,1);
//BEEP=1;
send_char_com('N');
send_char_com('N');
send_char_com('N');
SetTF = 0;inbuf2[0]=0x00;} if (inbuf2[0]==0x34){
KeyV=2;
//send_string_com(inbuf2,1);
//BEEP=0;
//RELAY=0;
TMSetV = TMSetV - 1;
inbuf2[0]=0x00;
} if (inbuf2[0]==0x35){//send_string_com(inbuf2,1);
//BEEP=1;
//RELAY=1;
TMSetV = TMSetV + 1; //上調溫度
inbuf2[0]=0x00;
} if (inbuf2[0]==0x74){
KeyV=2;
//send_string_com(inbuf2,1);
//BEEP=1;
//RELAY=1;
} if (inbuf2[0]==0x90){
KeyV=1;
//send_string_com(inbuf2,1);
//BEEP=1;
//RELAY=1;
}
if (!Key_UP)
KeyV = 1;
if (!Key_DOWN)
KeyV = 2;
if (!Key_SET)
KeyV = 3;
//KeySETDowning = 0; //清除
if (KeyV != 0) //有鍵按下
{
Delay_10ms(); //延時防抖 按下10ms再測
if (!Key_UP)
TempKeyV = 1;
if (!Key_DOWN)
TempKeyV = 2;
if (!Key_SET)
TempKeyV = 3;
if (KeyV == TempKeyV) //兩次值相等為確定接下了鍵
{
if (KeyV == 3) //按下SET鍵,如在SET狀態就退出,否則進入
{
//KeySETDowning = 1; //表明SET正在按下

PowTF = 0; //電源標識開
if (!KeyTF)
if (SetTF){
send_char_com('N');
send_char_com('N');
send_char_com('N');
SetTF = 0; //標識位標識退出設定

InitDS1820(); //初始化
ROMDS1820(); //跳過ROM
TMWDS1820(); //寫溫度上限指令
WriteDS1820(); //寫溫度上限到DS18B20ROM
WriteDS1820(); //寫溫度上限到DS18B20ROM
WriteDS1820(); //寫溫度上限到DS18B20ROM
InitDS1820(); //初始化
ROMDS1820(); //跳過ROM
TMREDS1820(); //溫度上限值COPY回E2PRAM
}
else {
send_char_com('O');
send_char_com('O');
send_char_com('O');
SetTF = 1;}

if (!KeySETDown) //沒有第一次按下SET時,KeySETDown標識置1
KeySETDown = 1;
else
KSDNum = KSDNum + 1; //前一秒內有按過SET則開始計數
}
if (SetTF) //在SET狀態下
{

if ((KeyV == 1) && (!KeyTF))
TMSetV = TMSetV + 1; //上調溫度
if ((KeyV == 2) && (!KeyTF))
TMSetV = TMSetV - 1; //下調溫度
if (TMSetV <= 20) //限制溫度上下限
TMSetV = 20;
if (TMSetV >= 75)
TMSetV = 75;
}
if ((!KeyTF) && (IntNum3 == 0)) KeyTF = 1; //當鍵盤處於可用時,鎖定
}
}
KeyV = 0;
TempKeyV = 0; //清空變數准備下次鍵掃描 if (!PowTF)
{
InitDS1820(); //初始化
ROMDS1820(); //跳過ROM
TMVDS1820(); //溫度轉換指令 Delay_510();
Delay_510(); //延時等待轉換完成 InitDS1820(); //初始化
ROMDS1820(); //跳過ROM
TMRDS1820(); //讀出溫度指令
ReadDS1820(); //讀出溫度值 V2ToV(); //轉換顯示值
if (TMV > TMSetV) //根據採集到的溫度值控制繼電器
{
RelayOutPort = 0;
flag=0;
}
else
{
RelayOutPort = 1;
DELPort=1;
Second=1;
flag=1;
} if (SetTF) IntNum2 = IntNum2 + 1; //用於閃爍計數
if (IntNum2 > 50 ) IntNum2 = 0;
if (KeyTF) IntNum3 = IntNum3 + 1; //用於防止按鍵連按
if (IntNum3 > 25)
{
IntNum3 = 0;
KeyTF = 0;
} if ((SetTF) && (IntNum2 < 25)) goto InitEnd; //計數在後半段時顯示

LEDPort = LED_Two;
LEDTwoC = 0;
Delay_510();
LEDTwoC = 1; //顯示十位數
LEDPort = LED_Three;
LEDThreeC = 0;
Delay_510();
LEDThreeC = 1; //顯示個位數
}
InitEnd:;
}void V2ToV(void) //數值轉換
{
TLV = TLV >> 4;
THV = THV << 4; //讀出的高低位數值移位
TMV = TLV | THV; //合並高低位放入TM為實際溫度值
Sign = 0;
if (SetTF || !Key_SET)
Sign = TMSetV >> 7; //取符號
else
Sign = TMV >> 7; if (Sign)
{
if (SetTF || !Key_SET)
{
LED_One = (~(TMSetV-1)) / 100; //SET狀態下顯示設定值
LED_Two = ((~(TMSetV-1)) - LED_One * 100)/10;
LED_Three = (~(TMSetV-1)) - LED_One * 100 - LED_Two * 10;
inbuf1[0]=dis_8[LED_Two];
inbuf1[1]=dis_8[LED_Three];
//inbuf1[2]=dis_8[ LED_Three];
inbuf1[2]=0x0d;
inbuf1[3]=0x0a;
}
else
{
LED_One = (~(TMV-1)) / 100; //轉換百位值
LED_Two = ((~(TMV-1)) - LED_One * 100)/10;
LED_Three = (~(TMV-1)) - LED_One * 100 - LED_Two * 10;
inbuf1[0]=dis_8[LED_Two];
inbuf1[1]=dis_8[LED_Three];
inbuf1[2]=dis_8[0];
inbuf1[3]=0x0d;
inbuf1[4]=0x0a;
}
}
else
{
if (SetTF || !Key_SET)
{
LED_One = (TMSetV) / 100; //SET狀態下顯示設定值
LED_Two = (TMSetV - LED_One * 100)/10;
LED_Three = TMSetV - LED_One * 100 - LED_Two * 10;
inbuf1[0]=dis_8[LED_Two];
inbuf1[1]=dis_8[LED_Three];
inbuf1[2]=dis_8[0];
inbuf1[3]=0x0d;
inbuf1[4]=0x0a;
}
else
{
LED_One = (TMV) / 100; //轉換百位值
LED_Two = (TMV - LED_One * 100)/10;
LED_Three = TMV - LED_One * 100 - LED_Two * 10;
inbuf1[0]=dis_8[LED_Two];
inbuf1[1]=dis_8[LED_Three];
inbuf1[2]=dis_8[0];
inbuf1[3]=0x0d;
inbuf1[4]=0x0a;
}
} init_serialcomm(); //初始化串口//while ( 1 )
//{
send_string_com(inbuf1,INBUF_LEN); //轉LED欄位
if (LED_One) //超過百時十位的處理
LED_Two = LEDDis[LED_Two];
else
{
if (LED_Two == 0)
LED_Two = LEDDis[10];
else
LED_Two = LEDDis[LED_Two];
}
if (Sign)
LED_One = LEDDis[11];
else
{
if (LED_One == 0)
LED_One = LEDDis[10];
else
LED_One = LEDDis[LED_One];
}
LED_Three = LEDDis[LED_Three];
}void InitDS1820(void) //初始化DS1820
{

}void ROMDS1820(void) //跳過ROM匹配
{}void TMVDS1820(void) //溫度轉換指令
{}void TMRDS1820(void) //讀出溫度指令
{}void TMWDS1820(void) //寫入溫度限制指令
{}void TMREDS1820(void) //COPY RAM to E2PRAM
{}void WriteDS1820(void) //寫入溫度限制值
{
}void ReadDS1820(void) //讀出溫度值
{}void Delay_510(void) //延時510微秒
{
}void Delay_10ms(void) //延時10ms
{
}void Delay_4s(void) //延時4s
{}

③ 普通單片機與加有前綴ds的單片機有什麼區別

都是Microchip公司的PIC系列的單片機。
但你說的後者PIC30F2010不存在。不信去PIC單片機的官方網站查:www.microchip.com
PIC單片機有很多種。PIC10、PIC12、PIC16、PIC18這些都是8位的單片機
而你說的dsPIC30和dsPIC33系列單片機是屬於帶DSP(數字信號處理)功能的16位單片機。而PIC24系列是跟dsPIC30系列單片機相似,就是不帶DSP的16位單片機。
還有就是PIC32系列是32位的單片機,是microchip為了和ARM爭奪高端32位嵌入式晶元市場而生產地。

補充:有dsPIC字樣的是帶DSP功能的16位單片機,可以理解為有ds字樣的就是DSP晶元。DSP晶元:數字處理晶元,可以在一個時鍾周期里完成一個MAC,就是16位乘上16位數,其積再加上一個32位數這兩個操作一個時鍾周期完成。在dsPIC中,就是兩個晶振周期完成,如果晶振是4MHz的話,就是說上述乘法和加法的操作能在2微秒內完成。這MAC是衡量DSP晶元的一個指標。還有就是FFT(快速傅里葉變換)等等。
PIC18和PIC24系列的也有內部的乘法器,但他們的乘法器速度遠遠追不上DSP晶元的MAC。 你可以看看網路對DSP的詳解。
DSP怎麼用,舉個例子:有的語音DSP晶元,可以做一個數字濾波器,兩個人同時說話,麥克風錄入這些聲音到這個濾波器里,濾波器的喇叭可以實時算出某個人的聲音,並且只輸入這個人的聲音(實時的,旁觀者根本分辨不出延時)。這就是DSP晶元的快速數字運算能力所決定的。不要跟我說計算機的CPU也有這么快,計算機的微處理器只是頻率高,在某些工程數學運算場合,它根本比不上DSP晶元。
至於Microchip的dsPIC30系列,因為它是面向於對電機、變頻器的數字控制,所以它要實現上述的語音實時濾波比較困難。至於dsPIC33系列的,因為我沒用過這系列的DSP,所以不敢確定是否能實現上述功能。

使用DSP晶元的快速運算功能需要編程者有《信號與系統》《復變函數》《有限元分析》《小波變換》等等的研究生才學的課程,如果只是拿來做普通單片機,那就太大材小用了。

④ dsPIC單片機片子寫不進程序

首先准備好51單片機最小系統板和燒錄器。
打開stcisp燒錄軟體選擇好單片機型號,接著把燒錄器與51單片機最小系統連線,插入電腦。
然後點擊下載選項。然後對單片機重新上電,不久後軟體界面右下角顯示框顯示正在重新握手成功。完成以上設置後,即可完成給單片機燒錄程序。

閱讀全文

與單片機dsport相關的資料

熱點內容
考駕照怎麼找伺服器 瀏覽:882
阿里雲伺服器如何更換地區 瀏覽:970
手機app調音器怎麼調古箏 瀏覽:501
銳起無盤系統在伺服器上需要設置什麼嗎 瀏覽:17
紅旗計程車app怎麼應聘 瀏覽:978
如何編寫linux程序 瀏覽:870
吉利車解壓 瀏覽:248
java輸入流字元串 瀏覽:341
安卓軟體沒網怎麼回事 瀏覽:785
dvd壓縮碟怎麼導出電腦 瀏覽:274
冒險島什麼伺服器好玩 瀏覽:541
如何在伺服器上做性能測試 瀏覽:793
命令序列錯 瀏覽:259
javaif的條件表達式 瀏覽:576
手機app上傳的照片怎麼找 瀏覽:531
雲伺服器面臨哪些威脅 瀏覽:748
c語言各種編譯特點 瀏覽:177
路由器多種加密方法 瀏覽:604
程序員阻止電腦自動彈出定位 瀏覽:168
如何做伺服器服務商 瀏覽:763