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
 
  • Lọc
  • Giờ
  • Show
Clear All
new posts

  • 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.

    Comment


    • Đơ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


          • R0bocon

            cho mình xin một số code về Robo với!!!

            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ết
                  Cá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
                  Mình đã hiểu nhiều phần rồi nhưng chỗ câu hỏi 4 của mình vẫn chưa hiểu , bạn nào có thể trả lời giúp mình với
                  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;
                  }
                  }
                  Last edited by hagasy; 29-11-2009, 22:51. Lý do: update

                  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


                    • bạn thử làm như thế nay.

                      bạn vào phần license management. copy nội dung ở Computer ID.sau đó mở keil_lic ra.paste nội dung đó vào mục: External CID code.những phần khác làm như hướng dẫn khác.mình phải làm như vậy với con laptop của minh moi được.mình không đính kèm file ảnh được.

                      Comment


                      • chào mọi người mình đang tập viết c cho 8051, mình không hiểu mấy về cách khai báo các hàm. mong mọi người giúp đỡ :d

                        Comment


                        • bây giờ em mới bắt đầu học lập trình cho vi điều khiển mà không biết bắt đầu từ đâu, anh nào đã học rồi có thể hướng dẫn em được không. Em cám ơn nhiều

                          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


                            • các anh cao thủ 8051 ai có ct mô phỏng cho em vơi nha. " đang tập làm lên ko bít gì giúp em vơi nhá".
                              " quet 4 led 7 thanh hien thi 0-9 (BCD) su dung vxl 8051 "
                              anh nào có cho em vơi nhá thanks nhiu

                              Comment


                              • void Delay(unsigned int n)
                                {
                                unsigned int i,j;
                                for (i=0;i<n;i++)
                                for (j=0;j<100;j++);
                                }
                                các bạn cho mình hỏi: biến n ở đây có kiểu dữ liệu là unsigned int, có phải biến n ở đây có giá trị là 65535, nếu không phải thì biến n có giá trị là bao nhiêu vậy. mong mọi người để ý giúp đỡ

                                Comment

                                Về tác giả

                                Collapse

                                kien_tran Tìm hiểu thêm về kien_tran

                                Bài viết mới nhất

                                Collapse

                                Đang tải...
                                X