In this tutorial we see how to setup Keil4 for generating .hex file.
Keil software can be downloaded from
this link.
Download and install the Keil C51 for 8051.
data:image/s3,"s3://crabby-images/ea2c2/ea2c2a5b2c350758ec432288db9587da34bedde2" alt="01Kiel.PNG"
Keil Setup Steps
Step1: Open the Keil software and select the New Microvision project from Project Menu as shown below.
data:image/s3,"s3://crabby-images/265e0/265e00f4853f7ed3998200bc3714db22bdc4f211" alt="8051 Keil 01.png"
Step2: Browse to your project folder and provide the project name and save it.
data:image/s3,"s3://crabby-images/501f7/501f73c5d081674040081d40b407cd4b501b1ee3" alt="8051 Keil 02.png"
Step3: Once the project is saved a new pop up “Select Device for Target” opens, Select the required 8051 series controller and click on OK.
- Atmel->AT89s52
- NXP->P89V51RD2
- Nuvoton-> W78E052D
Since all the controller follow the same 8051 architecture, any of the above mentioned controller can be selected.
data:image/s3,"s3://crabby-images/d11b7/d11b71882a5aad4f982df9cba6cda1995d840caa" alt="8051 Keil 03.png"
Step4:Select Atmel->At89s52 and click OK.
data:image/s3,"s3://crabby-images/1a9ce/1a9cede4bcfd49302d251b29f2a34943f9a27414" alt="8051 Keil 04.png"
Step5:8051 doesn't need the startup code, click on
NO option to proceed.
data:image/s3,"s3://crabby-images/422b7/422b78ade6b3ea326a1f7f723f989f7b79e84a46" alt="8051 Keil 05.png"
Step6: Create a new file to write the program.
data:image/s3,"s3://crabby-images/04532/045327e0f58e696ec74e2d91622402ce6eac2207" alt="8051 Keil 06.png"
Step7: Type the code or Copy paste the below code snippet and save the file as main.c
data:image/s3,"s3://crabby-images/9f68c/9f68c5fcef262f2f997bbcc86fb604d48340e3b7" alt="8051 Keil 07.png"
| // Program by UdayaPrakashJayaraman |
| #include <reg51.h>
|
| void DELAY_ms(unsigned int ms_Count) |
| { |
| unsigned int i,j; |
| for(i=0;i<ms_Count;i++) |
| { |
| for(j=0;j<100;j++); |
| } |
| } |
| int main() |
| { |
| |
| while(1) |
| { |
| P0 = 0xff; /* Turn ON all the leds connected to Ports */ |
| P1 = 0xff; |
| P2 = 0xff; |
| P3 = 0xff; |
| DELAY_ms(500); |
| |
| P0 = 0x00; /* Turn OFF all the leds connected to Ports */ |
| P1 = 0x00; |
| P2 = 0x00; |
| P3 = 0x00; |
| DELAY_ms(500); |
| } |
|
|
| return (0); | |
| } | | | | |
Step8:Save the file as main.c
data:image/s3,"s3://crabby-images/40af6/40af684dbca858fe1cbe6de07cab2efa8ba4604a" alt="8051 Keil 08.png"
Step9:Add the file to the project using the option
Add files to Source Group.
data:image/s3,"s3://crabby-images/c0e53/c0e53bdfaa0d739b54577e5017e2866a357ac8aa" alt="8051 Keil 09.png"
Step10: Add the recently saved file to the project.
data:image/s3,"s3://crabby-images/001ed/001edd14af971d52023caf7f0e07710bc5d1a640" alt="8051 Keil 10.png"
Step11:Now the main.c file should appear in Project Source Group.
data:image/s3,"s3://crabby-images/ec590/ec59062c5b9855f7523bae93f0aefea60894e906" alt="8051 Keil 11.png"
Step12:Build the project and fix the compiler errors/warnings if any.
data:image/s3,"s3://crabby-images/d6e81/d6e81880b262d0c90ecdcf828d124a3320658773" alt="8051 Keil 12.png"
Step13:Code gets compiled with no errors and .hex file is still not generated.
data:image/s3,"s3://crabby-images/8f1fa/8f1fa66d38bde65e1bd7947c9c8285e026cc15c5" alt="8051 Keil 13.png"
Enable Hex File Generation
Step14:Click on
Target Options to select the option for generating .hex file.
data:image/s3,"s3://crabby-images/c205c/c205c9f899f0a0a5d85258c85c16a69e06f84383" alt="8051 Keil 14.png"
Step15: Rebuild the target to generate the .hex file.
data:image/s3,"s3://crabby-images/c3122/c3122334897eeeb2a9e4f52409576c3886474f50" alt="8051 Keil 15.png"
Step16: Check teh project folder for generated .hex file.
data:image/s3,"s3://crabby-images/dfbe8/dfbe878af8e6df31f661098b468844ebb3c8327b" alt="8051 Keil 16.png"
Uploading the Hex file
After generating the .hex file check the below tutorials for uploading it.
- Uploading Hex File Using USBasp Programmer Progisp
Have a opinion, suggestion , question or feedback about the article let it out here!