CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

Problem of single line of black squares on LCD 1602(16*2)

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
HWGonly1



Joined: 02 Jul 2014
Posts: 15

View user's profile Send private message

Problem of single line of black squares on LCD 1602(16*2)
PostPosted: Sun Jul 06, 2014 4:03 am     Reply with quote

Hi, experienced programmers, I come for help for the second time.
I'm working on PIC16F877 while the LCD only display a single line of black squares.
I've already add delay_ms(500) before and after lcd_init(),I'm wondering why it's still wrong.
It's all working on proteus and I've checked circuit for several times ,I think it's not the fault of wrong circuit.
Here is the flex_lcd.chttp://www.ccsinfo.com/forum/viewtopic.php?t=24661
and this is my code:
Code:
#include"flex_lcd.c"
int32 RunMileage=0;
int mode=0;
int1 flag=TRUE;
int32 Price_calc()
{
int32 Price; //running with this at 100*
if(RunMileage<=2300)
Price=80000;
else if((RunMileage>2300)&&(RunMileage<=35000))
Price=80000+(RunMileage-2300)*26;
else if(RunMileage>35000)
Price=111200+(RunMileage-35000)*35;
return price;
}

void end()
{
lcd_putc('\f');
mode=0;
RunMileage=0;
}

#int_ext
void breakloop()
{
flag=1;
if (++mode==4)
mode=0;
}
void carrying()
{
setup_timer_1(T1_EXTERNAL_SYNC | T1_DIV_BY_1);
set_timer1(0);
}
void main()
{
int16 temp_timer;
int32 Price;
int count=0;
delay_ms(500);
lcd_init();
delay_ms(500);

ext_int_edge(H_TO_L);
clear_interrupt(INT_EXT);
enable_interrupts(INT_EXT);
enable_interrupts(GLOBAL);

while(TRUE)
{
if (flag==TRUE)
{
//note where the flag test is...
flag=FALSE;
switch (MODE) {
case 0:
printf(lcd_putc,"\f\nVacant Car");
break;
case 1:
printf(lcd_putc,"\f\nWelcome");
delay_ms(1000);
carrying();
printf(lcd_putc,"\f\nFare");
mode=2; //automatically advance to 'running'
break;
}

temp_timer=get_timer1();
while(mode==2)
{

temp_timer=get_timer1();
RunMileage=temp_timer*30;
Price=Price_calc();
Price/=100;
printf(lcd_putc,"\f\nFare:");
printf(lcd_putc,"%5.2Lw",Price);
delay_ms(500);
}
if(mode==3)
{
}
}
}


I connect R/W to ground and comment out the defininition of USE_LCD_RW

And connect other pins just as in definition in lcd_flex.c.

And the '\n' doesn't work either,it never change to second line,but it doesn't really matter,but please tell me if you know why,thanks!


Last edited by HWGonly1 on Sun Jul 06, 2014 5:52 am; edited 1 time in total
temtronic



Joined: 01 Jul 2010
Posts: 9282
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Sun Jul 06, 2014 5:10 am     Reply with quote

step number 1. Get rid of 99% of your code and ONLY code for the LCD module! Just create a simple 'Hello LCD' program. Confirm your LCD is properly connected,code uses the correct I/O pins,etc.
Show us that program and we can help...


cheers
jay
HWGonly1



Joined: 02 Jul 2014
Posts: 15

View user's profile Send private message

Change to a simple one,but it still got the same error.
PostPosted: Sun Jul 06, 2014 5:27 am     Reply with quote

temtronic wrote:
step number 1. Get rid of 99% of your code and ONLY code for the LCD module! Just create a simple 'Hello LCD' program. Confirm your LCD is properly connected,code uses the correct I/O pins,etc.
Show us that program and we can help...


cheers
jay


#include"flex_lcd.c"
void main()
{
delay_ms(500);
lcd_init();
delay_ms(500);
printf(lcd_putc,"\f\nVacant Car");
}
HWGonly1



Joined: 02 Jul 2014
Posts: 15

View user's profile Send private message

Change to a simple one,but it still got the same error.
PostPosted: Sun Jul 06, 2014 5:28 am     Reply with quote

temtronic wrote:
step number 1. Get rid of 99% of your code and ONLY code for the LCD module! Just create a simple 'Hello LCD' program. Confirm your LCD is properly connected,code uses the correct I/O pins,etc.
Show us that program and we can help...


cheers
jay


And I haven't connect trimpot to pin 15,16
And I'm using PICKIT3 to download to my PIC16F877,does it matter?
temtronic



Joined: 01 Jul 2010
Posts: 9282
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Sun Jul 06, 2014 6:35 am     Reply with quote

1) trimpot doesn't get connected to 15 and 16. that's 'usually' the LED backlighing connections....trimpot get connected to pin 3(contrast +-.5VDC)

2) I use the PICKit3 to program the 877 all the time

however, if using MPLAB be sure to set the 'build configuration' to 'release' and NOT 'debug'( the factory default).


hth
jay
HWGonly1



Joined: 02 Jul 2014
Posts: 15

View user's profile Send private message

PostPosted: Sun Jul 06, 2014 6:41 am     Reply with quote

temtronic wrote:
1) trimpot doesn't get connected to 15 and 16. that's 'usually' the LED backlighing connections....trimpot get connected to pin 3(contrast +-.5VDC)

2) I use the PICKit3 to program the 877 all the time

however, if using MPLAB be sure to set the 'build configuration' to 'release' and NOT 'debug'( the factory default).


hth
jay


What build configuration?I'm new to CCS .
I clicked project--build configuration, the list only shows gray words"No Build Configurations"
But it build succeed and works well on proteus simulation, and so I don't know why.
Please help me
temtronic



Joined: 01 Jul 2010
Posts: 9282
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Sun Jul 06, 2014 8:41 am     Reply with quote

OK...
Sounds like you have a bad installation of MPLAB.

You should have seen 'release' and 'debug' as the options for the 'build configuration' in the 'project' drop down window.

I'd remove and reinstall MPLAB and try again
Be sure to get the CCS 'plugin' form their website which allows you to use the compiler 'through' the MPLAB IDE.

hth
jay

also please note PROTEUS does NOT simulate a PIC properly.It is FULL of bugs, errors, and faulty DRCs !! Do NOT trust it !!
HWGonly1



Joined: 02 Jul 2014
Posts: 15

View user's profile Send private message

Oh that's too bad!!!I shouldn't have trust proteus
PostPosted: Sun Jul 06, 2014 8:50 am     Reply with quote

temtronic wrote:
OK...
Sounds like you have a bad installation of MPLAB.

You should have seen 'release' and 'debug' as the options for the 'build configuration' in the 'project' drop down window.

I'd remove and reinstall MPLAB and try again
Be sure to get the CCS 'plugin' form their website which allows you to use the compiler 'through' the MPLAB IDE.

hth
jay

also please note PROTEUS does NOT simulate a PIC properly.It is FULL of bugs, errors, and faulty DRCs !! Do NOT trust it !!
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Sun Jul 06, 2014 8:55 am     Reply with quote

HWGonly1,
Your schematic in your original thread shows no crystal oscillator
circuit external to the 16F877. Proteus doesn't care about this.
But in real hardware, this circuit is necessary. Your 16F877 won't do
anything without this circuit.

My advice is to get a different PIC, such as the 16F887, which has an
internal oscillator and doesn't need the crystal circuit. The 16F887 is a
much better PIC for a newbie.

Also, in all of your posted programs, you never show the #include line
for the PIC, the #fuses line, or the the #use delay() line. These lines
should be at the start of the program and are necessary for the PIC to
run correctly in real hardware.
HWGonly1



Joined: 02 Jul 2014
Posts: 15

View user's profile Send private message

PostPosted: Sun Jul 06, 2014 10:35 am     Reply with quote

PCM programmer wrote:
HWGonly1,
Your schematic in your original thread shows no crystal oscillator
circuit external to the 16F877. Proteus doesn't care about this.
But in real hardware, this circuit is necessary. Your 16F877 won't do
anything without this circuit.

My advice is to get a different PIC, such as the 16F887, which has an
internal oscillator and doesn't need the crystal circuit. The 16F887 is a
much better PIC for a newbie.

Also, in all of your posted programs, you never show the #include line
for the PIC, the #fuses line, or the the #use delay() line. These lines
should be at the start of the program and are necessary for the PIC to
run correctly in real hardware.


Thank you for advice,and I really want to accept your advice.
But what I'm working on is my task (I'm a college student),and we were given only 16F877 chip and so it's not what I chose.
So even if I'm newbie,I'm not fortunate to choose what I want to learn.
I still don't know what is oscillator and my RB0 is counting the pulse from NE555(if this is related to oscillator?).

Is the oscillator necessary for all circuit?I don't know about that cause I am very new to it.

I've done the pro-processing(my English is poor) in flex_lcd.c cause when I did in main code but in flex_lcd.c it makes error(such as #device* is needed)

this is my addition to flex_lcd.c
Code:
#include"16F877.h"
#use delay(clock=4000000)
#use rs232(baud=9600,xmit=PIN_D7,rcv=PIN_D0)
#fuses HS, NOWDT, PUT
 
.....


I don't know if it will cause some error, but really thank you for helping me.
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Sun Jul 06, 2014 10:49 am     Reply with quote

The oscillator is the 'heart' that makes the processor work.
Totally essential. The chip can't do anything at all without it.

Your 555, is _an_ oscillator, but is not really suitable, or fast enough to run the PIC. Once running there are circuits in the PIC, hat can 'count' signals from other sources, and it sounds as if this is what you are meant to be doing with the signal from the 555.

The PIC contains 90% of the circuitry needed to make it's oscillator. What it lacks it the bits to actually time the oscillation. Normally a crystal or ceramic resonator connected to it's 'oscillator pins'. As PCM programmer points out some other PIC's have everything included (though less accurate than the crystal).

You need an external crystal and load capacitances connected to the oscillator pins. The PIC data sheet (figure 12-1), shows what is needed.
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Sun Jul 06, 2014 1:53 pm     Reply with quote

This schematic shows the crystal circuit that you need:
http://s21.postimg.org/gkrbc1cav/schema002.jpg
Crystal X1 can be a 4 MHz or 20 MHz crystal, whatever you have in stock.
The two capacitors should be 22 pf (picofarads). That capacitor value
will work fine with either a 4 or 20 MHz crystal.

And you will need a 10K pullup resistor to +5v on the MCLR pin
as shown in the schematic.

And you will need +5v connected to the PIC's Vdd pins, and Ground
connected to the Vss pins.

Proteus ignores all this, but you need it all to make your real hardware
work correctly.
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Sun Jul 06, 2014 2:28 pm     Reply with quote

and, a capacitor with a good high frequency performance (like perhaps a 0.1uF ceramic), _as close as possible to the supply pins on the PIC_.
HWGonly1



Joined: 02 Jul 2014
Posts: 15

View user's profile Send private message

PostPosted: Sun Jul 06, 2014 6:54 pm     Reply with quote

PCM programmer wrote:
This schematic shows the crystal circuit that you need:
http://s21.postimg.org/gkrbc1cav/schema002.jpg
Crystal X1 can be a 4 MHz or 20 MHz crystal, whatever you have in stock.
The two capacitors should be 22 pf (picofarads). That capacitor value
will work fine with either a 4 or 20 MHz crystal.

And you will need a 10K pullup resistor to +5v on the MCLR pin
as shown in the schematic.

And you will need +5v connected to the PIC's Vdd pins, and Ground
connected to the Vss pins.

Proteus ignores all this, but you need it all to make your real hardware
work correctly.


Thank you for advice and now I know there is oscillator on the base I plug PIC in.
I have got the CCS plugin for MPLAB IDE and the circuit still works improperly, just a single line of black squares.
ezflyr



Joined: 25 Oct 2010
Posts: 1019
Location: Tewksbury, MA

View user's profile Send private message

PostPosted: Sun Jul 06, 2014 7:16 pm     Reply with quote

Hi,

HWGonly1 wrote:

Thank you for advice and now I know there is oscillator on the base I plug PIC in.


Who knows what this really means? I haven't a clue! If you are using some sort of a commercial development board, then post a link!

What you really need to do is connect an LED to an I/O pin of your PIC (thru a suitable current limiting resistor), and flash it at a known rate. Make a simple test program to do this, and tell us the results. Turn the LED On for 1 second and then Off for 1 second, and do this repeatedly. This test will tell you (1) if the PIC is actually running, and (2) if it's running at the desired speed. Seriously, don't do anything else until you can perform this test, and tell us the results. Otherwise this thread is going to go no where fast....

John
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group