Hello everyone,
I am using Keil uVision2 to write my assembler code. I am always getting the same error. I searhed on Google and everbody says the solution is in the Keil manual but I could not find anything. To make it clear, I would want to say what I did so far.
1. Created a project, 2. Selected Atmel T89C51CC01, 3. Clicked new button and wrote my assembler code, 4. I added .asm code in the project. 5. Compile it and get the warnings.
Here is .plg file:
Build target 'Target 1' assembling STARTUP.A51... assembling defa.asm... linking...
*** WARNING L1: UNRESOLVED EXTERNAL SYMBOL SYMBOL: ?C_START MODULE: STARTUP.obj (?C_STARTUP) *** WARNING L2: REFERENCE MADE TO UNRESOLVED EXTERNAL SYMBOL: ?C_START MODULE: STARTUP.obj (?C_STARTUP) ADDRESS: 000DH Program Size: data=9.0 xdata=0 code=4131 creating hex file from "my"... "my" - 0 Error(s), 2 Warning(s).
Are you mixing 'C' and assembler?
If so, things are far easier if you provide a main() in 'C', and call your assembler from that.
Otherwise, you are going to have to do a lot of work to find out how to manually provide the runtine support required for your 'C' code.
Try putting "unresolved ?C_START" into the 'Search' box on this site; here's just one example: http://www.keil.com/forum/docs/thread398.asp
http://www.keil.com/support/docs/1980.htm
I am newbie in Keil. I just want to write .asm codes to program my microcontroller. My friends recommend Keil for me. Do I have to write main code? Can't I just add .asm files and compile them?
The startup files provided by Keil are for use with 'C' programs - don't use them if you're just writing assembler!
(or, if you do use them, be sure to remove any references to anything to do with 'C' - such as ?C_START)
http://www.keil.com/support/man/docs/c51/c51_ap_startup.htm
Ok. I got it. So, after startup code run, it redirect automatically to my main function. If I want to write .asm codes, I need to use #pragma ASM #pragma ENDASM tags. I have just created a .c file and compile it. I was able to generate .hex file as well. Now, I need to upload this .hex file to my microcontroller using flip. Does this .hex file contain startup code?
"So, after startup code run, it redirect automatically to my main function."
But you only need that if you're writing in 'C' - you said you're not using 'C', just assembler?
"If I want to write .asm codes, I need to use #pragma ASM #pragma ENDASM tags."
Only if you are embedding your assembler within 'C' code - which, you said, you're not?
"I have just created a .c file"
Why?? You said you just wanted to write assembler - not 'C'?!
"Does this .hex file contain startup code?"
The Hex file contains whatever your project contained!
Yes I want to write .asm codes but it doesn't matter whether in C or not. Now I am supposed to see some leds are on but not. Could you please clarify me why this is happening?
Here is my code:
void main(void) { #pragma ASM mov 18h,#01001010b mov 20h,#00100100b mov 28h,#01010010b mov 30h,#01111111b mov 38h,#00110110b #pragma ENDASM }
I can compile it successfully and I upload my .hex file to the microcontroller. Now I read from microcontroller and what I see is
Addr 000200 02 00 10 FF FF FF FF FF FF ...
It generates just 02 00 10 for my whole .hex file. Why it is so small? By the way I set CSEG AT 200h.
Yes I want to write .asm codes but it doesn't matter whether in C or not
ok, now I lost you.
just write in assembler - do not complicate the issue with 'C' !!
I think you probably need to start with a tutorial on the basics of the 8051:
www.8052.com/.../tutorial
See also: http://www.keil.com/books/8051books.asp
And, of course, the so-called "bible" for the 8051:
Chapter 1 - 80C51 Family Architecture: www.nxp.com/.../80C51_FAM_ARCH_1.pdf
Chapter 2 - 80C51 Family Programmer's Guide and Instruction Set: www.nxp.com/.../80C51_FAM_PROG_GUIDE_1.pdf
Chapter 3 - 80C51 Family Hardware Description: www.nxp.com/.../80C51_FAM_HARDWARE_1.pdf
.
mov 18h, #01001010b mov 20h, #00100100b mov 28h, #01010010b mov 30h, #01111111b mov 38h, #00110110b
Using the above references, what do you think should be the result of writing to those particular memory locations.
As they say in exam papers, "explain your working"...
In this example, I tried to send my .hex file to the microcontroller. In order to correct it, I read data from microcontroller and normally I was supposed to see longer sentences because mov 18h, #01001010b would be converted 20 18 4A. Here, 20 is mov, 18 is 18 and 4A is #01001010b. There were 4 lines in my code but when I read from microcontroller I saw just 02 00 10. I supposed something like that,
20 18 4A 20 20 24 20 28 52 20 30 7F 20 38 36 ...
Just throw that example away - it's not worth keeping!
Start again, from scratch, with a pure assembler project.
BTW: if you're using the free evaluation version, be sure to study the Limitations carefully:
http://www.keil.com/demo/limits.asp