Regards all, This codes generates a hang on cpu . Please kindly take this & guid me : #include <w78e65.H> #include <stdio.h> main() { unsigned char i; TMOD=0x20; SCON=0x52; TH1=0xfa; TR1=1; for(i=0;i<=255;i++) { printf("%bd",i); P2=i; } } /**************************************/
aziz, What everyone here is trying to tell you (with various levels of indirection) is that you need to stop imagining that your printf() will get a character out the serial port instantly. While the 8051 can call the function very quickly, the actual data will take some significant time to be transmitted by the hardware, assuming you're using some close-to-normal baud rate. So, as William, Erik, and others suggest, you need to change your loop to allow this to happen. What's happening NOW is that your program is very quickly calling printf() 255 times, then your program gets to the end and resets. If you are correct about the one character printout, it's because it's all happening in about the time it takes to send one character. I also suspect that you didn't copy-and-paste this code from the editor into the message. I say this because as it's written, the for() loop is infinite. Your test condition is "<= 255", but an unsigned char is always <= 255. So right now, it will get to 255, pass your test condition, be incremented, roll over to 0 and then continue. Try changing your for loop to this and see what happens:
for(i = 0; i < 255; i++) { TI = 0; printf("%bd",i); while(!TI); }
Unless the OP has replaced the standard putchar() function then printf() will wait for TI.
Stefan, Thanks for the tip. I've never actually found a reason to use printf myself, when it's so easy to just load up SBUF. Thanks for pointing that out though, or I could end up further frustrating the original poster.
"I've never actually found a reason to use printf myself, when it's so easy to just load up SBUF." If you think about it it has to wait for TI otherwise it wouldn't be able to output more than one character. How you live without printf() I just can't imagine!
How you live without printf() I just can't imagine! I can, 50+ designs and 600.000+ installed units late, I still have not seen the need to use it. Erik
Stefan, I guess I had always imagined that it handled things via interrupt and a circular buffer or something of the like. In retrospect, I'm not sure how it would have been able to install an ISR via just including stdio.h. :) As far as living without it. I dunno. I've yet to design a product that didn't require my actually using the serial communications channel, so I'd typically just hook into the routines that I wrote, or find some other way to get debug data out. You'd be amazed what you can do with just a few spare pins tied to some inverters. :)
printf()'s job is to format the data ready for output, the actual output is done by putchar() which is called by printf() once for each character. The default putchar() just does polled output via the UART - you can replace it with a function to send the output anywhere you like, eg an LCD. This makes things really flexible. If you wanted printf() to return to the caller before the data has all been transmitted you would need to implement your own buffer and replace putchar() with a function that stuffs a char into that buffer. One thing to be aware of is that the default putchar() translates 0x0a into 0x0d 0x0a sequences and also implements XON/XOFF which can throw up a few surprises if you're not expecting it. Naturally my code always works first time, but if I ever needed to debug something I'm sure I would use printf() a lot...