Cac bác ơi em có 1 thắc mắc không biết hỏi ai. chả la . em dang lap trinh vi điều khiển bằng ngôn ngữ C, Em sử dụng IC 89C52. Em muon lập trình sao cho trong truong trinh cua IC co san 1 chuong trinh. em lập trình thêm vào IC 1 chuong trinh khác mà không mất chương trình kia. Mong cac Pro chỉ giáo. Thanks.
Thông báo
Collapse
No announcement yet.
HƯỚNG DẪN LẬP TRÌNH KEIL C CHO 8051-[Chỉ dành post bài hướng dẫn]
Collapse
X
-
Đơn giản:
- Bạn dùng 1 mạch nạp 89 chẳng hạn như mạch 180s bạn sao chép ct đang có trên rom vào máy tính dưới dạng file hex, và bạn nạp ct mới vào thế là xong (ct dang có trên rom lấy ra dc với điểu kiện người nạp ct đó ko khóa thế là ok)Mạch nạp Pickit 2 SE ---> 170k BH 1 năm
Pic 18F2550 PDIP Thailand bao test 60K/1c
Comment
-
uj!!!Sao cai trang này đính file ntn nhj!!!T gửi wa mail cho nha!!!Last edited by nhom6.cdt4; 22-11-2009, 10:52.perkobo
Comment
-
gui vidieukhien1 : chuong trinh ban viet thieu dau ; tum lum , toi viet lai jum ban day :
#include<AT89x51.h> // Dinh kem file thu vien
#define bat 1 // Dinh nghia gia tri bat den Led
#define tat 0 // Dinh nghia gia tri tat den Led
/*==================khai bao bien==================*/
sbit Led = P1^0; // Khai bao bien Led kieu bit chan P1.0
/*================= Khai bao hàm==================*/
/*------------------------------ham tre -------------------------------------*/
void delay(long time)
{
while(time--);
}
/*--------------------------------ham chinh--------------------------------*/
void main(void)
{
while(1)
{
Led = bat; // bat Led
delay(25000); // tre 1s
Led = tat; // tat Led
delay(25000); //tre 1s
}
}
Comment
-
mình có bài tập nháy led đơn giản cho người mới
#include <REGX51.H>
//******************1 diem sang phai sang trai****************
void motdiemsPsT()
{
unsigned m=0x01;
unsigned k=128;
int tre(int),n,p;
P2=0;
P1=0;
for(n=0;n<=7;n++)
{
P0=m ;tre(50);
m<<=1;
}
P0_7=0;
for(p=0;p<=7;p++)
{
P2=k ;tre(50);
k>>=1;
}
}
//*******************1 diem sang trai sang phai*****************
void motdiemsTsP()
{ unsigned k=0x01;
unsigned m=128;
int tre(int),n,p;
P2=0;
P1=0;
for(n=0;n<=7;n++)
{
P2=k;tre(50);
k<<=1; }
P2_7=0;
for (p=0;p<=7;p++)
{
P0=m;tre(50);
m>>=1; }
}
//*************tat dan tu phai sang trai***********
void tatdanPsT()
{ int i,m=254;
P2=255;
P1=255;
for(i=0;i<=7;i++)
{ P0=m;
tre(50);
m<<=1; }
m=127;
for(i=0;i<=7;i++)
{
P2=m;
tre(50);
m>>=1; }
}
///****************sang dan phai sang trai****************
void sangdanPsT()
{
int i;
int mang1[8]={1,3,7,15,31,63,127, 255};
int mang2[8]={128,192,224,240,248,252,254,255};
P0=0;
P2=0;
for(i=0;i<=7;i++)
{
P0=mang1[i];
tre(50); }
for(i=0;i<=7;i++)
{
P2=mang2[i];
tre(50); }
}
///****************sang dan trai sang phai****************
void sangdanTsP()
{
int i;
int mang1[8]={1,3,7,15,31,63,127, 255};
int mang2[8]={128,192,224,240,248,252,254,255};
P0=0;
P2=0;
for(i=0;i<=7;i++)
{
P2=mang1[i];
tre(50); }
for(i=0;i<=7;i++)
{
P0=mang2[i];
tre(50); }
}
//**********************sang ngoai vao giua********************
void sdvaogiua()
{ int i;
int mang1[8]={1,3,7,15,31,63,127, 255};
P0=0;
P2=0;
for(i=0;i<=7;i++)
{
P2=P0=mang1[i];
tre(50); }
}
//*****************tat giua ra ngoai ******************
void tatgiuara()
{
int i,n=127;
P0=0;
P2=0;
for(i=0;i<=7;i++)
{
P2=P0=n;
tre(50);
n>>=1; }
}
//*************2 diem sang tu giua ra******************
void haidiemsGrN()
{
int i,n=1;
for(i=0;i<=7;i++)
{ P0=n;
P2=n;
tre(50);
n<<=1; }
}
//*************2 diem sang tu ngoaivao giua******************
void haidiemsNvG()
{
int i,n=128;
for(i=0;i<=7;i++)
{ P0=n;
P2=n;
tre(50);
n>>=1; }
}
//*************sang chan tu phai sang trai******************
void sangchanPsT()
{
int i,chan1[4]={1,5,21,85},chan2[4]={128,160,168,170};
P2=0;
P0=0;
for(i=0;i<=3;i++)
{ P0=chan1[i];
tre(50);
}
for(i=0;i<=3;i++)
{ P2=chan2[i];
tre(50);
}
}
//*************sang le tu trai sang phai******************
void sangleTsP()
{
int i,le1[4]={171,175,191,255},le2[4]={213,245,253,255};
for(i=0;i<=3;i++)
{
P2=le1[i];
tre(50);
}
for(i=0;i<=3;i++)
{
P0=le2[i];
tre(50);
}
}
//********* Ham tre ****************
int tre(int x)
{
int i,j;
for(i=0;i<=x;i++)
for(j=0;j<=500;j++)
{}
}
//*********hamchinh**************
void main()
{
while(1)
{
tre(50) ;
sangchanPsT();tre(50);
sangleTsP() ;tre(50);
haidiemsGrN();tre(50);
haidiemsNvG();tre(50);
sdvaogiua();tre(50);
tatgiuara();tre(50);
motdiemsPsT();tre(50);
sangdanTsP();tre(50);
tatdanPsT();tre(50);
motdiemsTsP(); tre(50);
sangdanPsT();tre(50);
}
}
Comment
-
3. Một ví dụ hoàn thiện về lập trình C cho 8051
#include<AT89X52.h>
#include<stdio.h>
#define strai3 P0_7
#define strai2 P0_6
#define strai1 P0_5
#define strai0 P0_4
#define sphai0 P0_3
#define sphai1 P0_2
#define sphai2 P0_1
#define sphai3 P0_0
//////////////////////////
#define mtraif P1_0
#define mtraib P1_1
#define mphaif P1_2
#define mphaib P1_3
#define dc1f P1_6
#define dc1b P1_7
Lập trình C cho VXL - Cơ bản VAGAM - giotdang
#define dc2f P1_4
#define dc2b P1_5
//////////////////////////
#define f_an0 P2_0
#define f_an1 P2_1
#define f_an2 P2_2
#define f_an3 P2_3
//////////////////////////
#define dc3f P2_4
#define dc3b P2_5
//////////////////////////
#define start P3_6
#define ctht1_batdau P3_1
#define ctht2_ketthuc P3_2
#define ctht3 P3_3
#define ctht4 P3_4
#define ctht5 P3_5
#define ctht6 P3_6
//////////////////////////
#define tien 1
#define lui 0
//////////////////////////
#define v_cham_trai 50
#define v_cham_phai 50
#define delta_v_cham_trai 20
#define delta_v_cham_phai 20
#define v_nhanh_trai 100
#define v_nhanh_phai 100
#define v_quay_trai 40
#define v_quay_phai 60
////////////////////////
//vach trang sensor=1 vach xanh sensor=0
int t=0,i=0,j=0,k=0;
int vtrai=100,vphai=100;
int PWMC=0;
int dem=0;
int dirtrai=tien,dirphai=tien;
int phuongan=0;
///////////////////////////
void dithang(int v_left,int v_right);
void dithangcham(int v_left,int v_right);
void stop(void);
void quayphai(void);
void quaytrai(void);
void ragach(void);
void pwm(void) interrupt 1 ;
void khoitao(void);
void hanhtrinh(void);
void ham(int time,int trai,int phai);
void ham2(void);
//========================================
void main(void)
{
khoitao();
khoidongthang();
hanhtrinh();
ragach();
stop();
}
//==========================================
void khoitao(void)
{
TMOD=0x02;
TH0=0xE1; TR0=1; IE=0x82;
P1=0x00;P2=0x00;P3=0x00;
while(!start) stop();
}
//==========================================
void khoidongthang(void)
Lập trình C cho VXL - Cơ bản VAGAM - giotdang
{
for(i=0;i<300;i++)
{
dirtrai=tien;dirphai=tien;
vtrai=40; vphai=40;
}
}
//==========================================
void khoidongquay(void)
{
dirtrai=tien;dirphai=tien;
vtrai=90; vphai=80;
for(i=1;i<=50;i++);
vtrai=52; vphai=40;
for(i=1;i<=580;i++);
ham(90,20,20);
do
{
dirtrai=tien;dirphai=lui;
vtrai=33;vphai=10;
}
while(!strai3);
for(i=1;i<=40;i++)
{
dirtrai=tien;dirphai=lui;
vtrai=33; vphai=9;
}
do
{
dirtrai=lui;dirphai=tien;
vtrai=15;vphai=32;
}
while(!strai0);
ham(100,20,20);
dirtrai=tien;dirphai=tien;
}
//==========================================
void quayphai(void)
{
int ktra=0;
dirtrai=tien;dirphai=lui;
do
{
vtrai= v_quay_trai;vphai= v_quay_phai;
if (sphai3) ktra++;
}
while(ktra<20);
stop();
for(i=1;i<1000;i++){};
dirtrai=tien; dirphai=tien;
}
////////////////////////////////////
void quaytrai(void)
{
int ktra=0;
dirtrai=lui;dirphai=tien;
do
{
vtrai= 60; vphai= 40;
if (strai3)ktra++;
}
while(ktra<20);
stop();
for(i=1;i<1000;i++){};
dirtrai=tien; dirphai=tien;
}
//+++++++++++++++++++++++++++++++++++++
//vach trang sensor=1 vach xanh sensor=0
void stop(void)
{
vtrai=0; vphai=0;
Lập trình C cho VXL - Cơ bản VAGAM - giotdang
}
//================================================== =====================================
void dithang(int v_left,int v_right)
{
if(!(strai0||strai1||strai2||strai3||sphai0||sphai 1||sphai2||sphai3)) // di thang
{
dirphai=tien;dirtrai=tien;
vtrai=v_left;vphai=v_right;
}
else
if((strai0&&strai1&&sphai0&&sphai1))
{ j=0;
for(i=1;i<=15;i++)
if((strai0&&strai1&&sphai0&&sphai1)) j++;
if(j>=10) { dem=dem+1;t=1 ;}
else t=0;
while(t)//cho qua vach trang
{
{ //di thang
dirphai=tien;dirtrai=tien;
vtrai=40;vphai=40;
}
k=0;
for(i=1;i<=20;i++)
if(!(strai3||strai2||sphai3||sphai2)) k++;
if(k>15) t=0;
}
}
else if ((sphai2||sphai3)) //re phai lon
{
dirtrai=tien;dirphai=tien;
vtrai=60;vphai=0;}
else if ((strai0||strai1))
//retrainho
{
dirtrai=lui;dirphai=tien;
vtrai=1;vphai=60;
}
else if ((sphai0||sphai1))
//rephainho
{
dirtrai=tien;dirphai=lui;
vtrai=60;vphai=1;
}
else if ((strai2||strai3))
//re trai lon
{
dirtrai=tien;dirphai=tien;
vtrai=0;vphai=60;}
}
////////////////////////////
void ragach(void)
{
while(!ctht2_ketthuc)
{
dirtrai=tien;dirphai=tien;
vtrai=25;vphai=25;
dc1f=1;dc1b=0;
}
dc1f=0;dc1b=0;
//---------------------------------------
for(t=1;t<=5;t++)
{
for(i=1;i<=10000;i++){
dirtrai=tien;dirphai=tien;
vtrai=25;vphai=25;}
Lập trình C cho VXL - Cơ bản VAGAM - giotdang
for(i=1;i<=10000;i++){
dirtrai=lui;dirphai=lui;
vtrai=0;vphai=0;}
}
//-------------------------
dirtrai=lui;dirphai=lui;
vtrai=25;vphai=25;
for(i=1;i<=2000;i++);
}
//////////////////////////
void pwm(void) interrupt 1
{
PWMC++;
if(PWMC==100) PWMC=0;
if(PWMC<vtrai)
{
mtraif=dirtrai;
mtraib=!dirtrai;
}
else
{
mtraif=0;
mtraib=0;
}
if(PWMC<vphai)
{
mphaif=dirphai;
mphaib=!dirphai;
}
else
{
mphaif=0;
mphaib=0;
}
}
void ham(int time,int trai,int phai)
{
int g;
for(g=0;g<=time;g++)
{
vphai=phai;vtrai=trai;
dirtrai=tien;dirphai=tien;
dirtrai=lui;dirphai=lui;
}
dirtrai=tien;dirphai=tien;
vphai=0;vtrai=0;
}
Chúc các bạn học lập trình C cho vi xử lý thật nhanh nhé . Đọc phần lý thuyết cơ bản
sau đó đọc bài ví dụ cuối cùng .
Nếu bạn còn gì chưa hiểu , hãy post lên để nhóm vagam giúp các bạn .
Thân
Lê Ngọc Tuấn – giotdang1985@yahoo.com
mình thấy bài nay của bạn tuấn đang từ lâu lắm rồi ở mấy trang đầu
Comment
-
Nguyên văn bởi hagasy Xem bài viếtCác anh chị ởi cho em hỏi một số điểm trong đoạn code này
Đây là mạch của nó ạ
Đây là code hiển thị chữ chạy ra 3 led matrix dùng IC đệm dịch 74HC595
thứ nhât
Chỗ đó tại sao phải tạo xung cạnh xuống trong khi muốn cho con 595 chạy thì cần phải xung cạnh lên ?
2..
min1=24 và max1=32 nghĩa là gì
3.
khi xuất ra tại sao lại -8 rồi -16 ?
4.
Đoạn chuơng trình trên nghĩa là sao, tại sao lại so sánh min1 với 100 và z với 700 để làm gì , em không hiểu
5. Đối với bài này là xuất ra 3 led matrix thôi vậy nếu em muốn nâng lên 5 led matrix thì em sẽ thay đổi những điểm nào trong bài này a.
Mong các anh chị giúp em tí, em xin chân thành cảm ơn ạ
Mail:hagasy@gmail.com
6.
Còn chỗ y&=0x80 có tác dụng gì rồi đem vào so sánh if(y==0x80) ser=1 else ser=0 để làm gì em chưa hiểu lắm, mong các pro giải thích cặn kẽ hộ em ah
while(z++)
{
if(min==max)
{
min1++;
max1++;
min=min1;
max=max1;
}
if(min1==100)
{
min1=24;
max1=32;
min=min1;
max=max1;
}
if(z==700)
{
z=0;
}
}
Comment
-
Ko Build All trong KeilC-3uVision Development Kit
Hi all,
Mình ko hiểu sao lại báo lỗi này khi đăng ký License management như đã chỉ dẫn. Thông báo lỗi thế này"*** ERROR R230: RENEW LICENSE ID CODE (LIC) Running with Code Size Limit: 32k", mình đã đổi LIC liên tục nhưng cái nào cũng bị thế, tháo ra cài lại vẫn như vậy? Thậm chí cài lại hệ điều hành.
Cảm ơn.
Comment
-
chào các PRO tôi mới tìm hiểu về 8051 có bài toán này nghĩ mãi không ra thuật giải mong các PRO chỉ giáo :
có 8 nút bấm nối với P1; 8 led nối với P2
khi bấm một hoặc nhiều nút bất kỳ thì các led tương đương tại P2 sẽ nhấp nháy liên tục (các led phải nhấp nháy cùng tần số ; các phím có thể nhả ngay hoặc vẫn giữ trạng thái nhấn )
Comment
Bài viết mới nhất
Collapse
-
Trả lời cho Mạch nguồn đôi dùng 7812 và 7912bởi tmcodonThank bác nhá. Tìm mãi mới thấy. Giờ vọc đã xem sao...
-
Channel: Hỗ trợ học tập
hôm nay, 10:39 -
-
bởi tungdqEm cần tìm sơ đồ mạch một số Main máy tính đời cao như Asrock B560M-HDV, các cao nhân chỉ giúp với. Thank!
-
Channel: Các mạch điện ứng dụng
Hôm qua, 08:27 -
-
Trả lời cho Kiểm tra biến ápbởi lamvu0677nhân tiện cho mình hỏi thêm về cái phần test hipot (cao áp),là để kiểm tra độ bền cách điện giưa các cuộn dây,mà thấy thông số test thường ở mức 4kvac,vậy nếu mấy con fail đó xài bình thường vẫn dduocj phải không ạ,vì điện mình làm gì lên tới mức đó
-
Channel: Điện tử dành cho người mới bắt đầu
10-11-2024, 08:52 -
-
Trả lời cho Kiểm tra biến ápbởi lamvu0677máy đo số vòng thì cty có ,mà nó to quá,tưởng có máy nào gọn gọn bỏ túi được thì tiện hơn,vì đi lại nhiều...
-
Channel: Điện tử dành cho người mới bắt đầu
10-11-2024, 08:47 -
-
bởi tmcodonMình thấy diễn đàn có chuyên mục quảng cáo rồi mà. Bạn đóng góp để mở luồng riêng
-
Channel: Hướng dẫn sử dụng diễn đàn
09-11-2024, 13:36 -
-
bởi Nicole08Xin chào mọi người, tôi đã sử dụng Flashforge Inventor 2 được gần 5 năm và rất hài lòng với nó, nhưng tuần trước đã xảy ra sự cố. Có vẻ như động cơ bước đưa sợi in vào đầu nóng đã bị hỏng. Mọi thứ khác có vẻ ổn trên máy...
-
Channel: Điện tử dành cho người mới bắt đầu
09-11-2024, 12:55 -
Comment