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

I2C stuck on first task (pic16f877a)
Goto page 1, 2  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
rlabee



Joined: 25 Jan 2023
Posts: 7

View user's profile Send private message

I2C stuck on first task (pic16f877a)
PostPosted: Wed Jan 25, 2023 10:09 am     Reply with quote

Hi all,

I've been browsing this forum for a while now, but never made an account. Although I've learned a lot from all of you guys I'm stuck on my project.

The assignment is to make a miniature elevator that works and shows messages regarding the elevator on a 2x16 LCD.

My problem here is that the elevator works (kind off, still under construction) and the LCD was showing the correct information. Until i had a power loss. Now the whole program seems to be stuck at the very beginning.

I've tried programming everything on another 16F877A chip but it still has the same problems.

I also had 4.7k pull-up resistors between the SDA and SCL lines.

I hope somebody can help me with this problem, I'm stuck on it for days now.

I would also like to mention that every tip or trick anyone can give about programming or making my program easier is more than welcome.

Down below my code. Thanks in advance!

(Excuse my English, I'm Dutch)

Code:
#include <16f877a.h>
#include <STDIO.h>
#fuses   HS,NOWDT
#use     delay(clock=20000000)
#use     I2C(MASTER, SCL=PIN_C3, SDA=PIN_C4, SLOW)

int16    a, b, c, d, i, r, v, x;
char     j;

unsigned char        address[1]                    =  {0x4E};                    //adres van de 2x16 segment display
unsigned char        LCD                           =  0;

const unsigned char  begane_grond[32]              =  {"Begane grond                    "};     // 0x00
const unsigned char  eerste_ver[32]                =  {"Verdieping 1                    "};     // 0x01
const unsigned char  tweede_ver[32]                =  {"Verdieping 2                    "};     // 0x02
const unsigned char  derde_ver[32]                 =  {"Verdieping 3                    "};     // 0x03
const unsigned char  begin[32]                     =  {" Lift start op                  "};     // 0x04
const unsigned char  Naarbeganegrond[32]           =  {"Lift gaat naar  Begane grond    "};     // 0x05
const unsigned char  man_bed[32]                   =  {"Lift wordt hand-  matig bediend "};     // 0x06
const unsigned char  Alarmtxt[32]                  =  {"ALARM! STAY CALM LIFT VERPLAATST"};     // 0x07
const unsigned char  Noodstoptxt[32]               =  {"NOODSTOP        HULP IS ONDERWEG"};     // 0x08
const unsigned char  omhoog[32]                    =  {"  Lift gaat          OMHOOG     "};     // 0x09
const unsigned char  omlaag[32]                    =  {"  Lift gaat          OMLAAG     "};     // 0x10

void     lcd_send_cmd (unsigned char data, unsigned char adres)                  //versturen van een instructie naar een display
{
   unsigned char data_l, data_u;                                                 //Benodigd omdat display in 4-wire mode wordt gebruikt. Eerst sturen van b7-b4, vervolgd door b3-b0
   data_l = (data<<4)&0xf0;                                                      //select lower nibble by moving it to the upper nibble position
   data_u = data&0xf0;                                                           //select upper nibble
 
   i2c_start();                                                                  //opstarten van i2c communicatie
   i2c_write(address[adres]);                                                    //selecteren van de juiste display adres                             
   i2c_write(data_u|0x0C);                                                       //enable =1 and rs =0
   i2c_write(data_u|0x08);                                                       //enable =0 and rs =0

   i2c_write(data_l|0x0C);                                                       //enable =1 and rs =0
   i2c_write(data_l|0x08);                                                       //enable =0 and rs =0
   i2c_stop();                                                                   //stoppen van i2c communicatie
   delay_ms(5);                                                                  //benodigd om het proces te vertragen
}
void     lcd_send_data (unsigned char data, unsigned char adres)                 //versturen van de karakters naar een display (Display Data RAM (DDRAM)
{
   unsigned char data_l, data_u;                                                 //Benodigd omdat display in 4-wire mode wordt gebruikt. Eerst sturen van b7-b4, vervolgd door b3-b0
   data_l = (data<<4)&0xf0;                                                      //select lower nibble by moving it to the upper nibble position
   data_u = data&0xf0;                                                           //select upper nibble
     
   i2c_start();                                                                  //opstarten van i2c communicatie
   i2c_write(address[adres]);                                                    //selecteren van de juiste display adres
   i2c_write(data_u|0x0D);                                                       //enable =1 and rs =1
   i2c_write(data_u|0x09);                                                       //enable =0 and rs =1

   i2c_write(data_l|0x0D);                                                       //enable =1 and rs =1
   i2c_write(data_l|0x09);                                                       //enable =0 and rs =1
   i2c_stop();                                                                   //stoppen van i2c communicatie
   delay_ms(5);                                                                  //benodigd om het proces te vertragen
}
void     lcd_init (unsigned char adres)                                          //Klaarzetten van het display
{
   lcd_send_cmd (0x02, adres);                                                   //Return Home instructie 
   lcd_send_cmd (0x28, adres);                                                   //4-bit bus mode, 2-line display mode en 5x8 dots display format
   lcd_send_cmd (0x0C, adres);                                                   //Display aan, Cursor aan, knipperende Cursor uit
   lcd_send_cmd (0x80, adres);                                                   //Zet cursor op punt 0,0 van het display
   delay_ms(5);                                                                  //benodigd om het proces te vertragen
}
void     Display (char keuze){                                                   // void voor woorden naar LCD te sturen

 if (keuze == 0x00)
   {                                             
      lcd_init(LCD);                                                             //initialiseren van LCD
      for (j = 0; j < 33; j++)                                                   //for loop die het woord afloopt
         {                                                 
         lcd_send_data(begane_grond[j],LCD);                       
         if (j > 14 && j < 16)                                                   //Als j gelijk is aan 15, naar volgende regel van lcd
            {                                                                   
            lcd_send_cmd (0xC0,LCD);                                              //Zet display op de 2de regel
            }
         }
      }
   }                                         
         
 if (keuze == 0x01)
   {
   lcd_init(LCD);                                                           
   for (j = 0; j < 33; j++)
      {
      lcd_send_data(eerste_ver[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }

if (keuze == 0x02)
   {
   lcd_init(LCD);                                                         
   for (j = 0; j < 33; j++)
      {
      lcd_send_data(tweede_ver[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }
         
if (keuze == 0x03)
   {
   lcd_init(LCD);                                                           
   for (j = 0; j < 33; j++)
      {
      lcd_send_data(derde_ver[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }
         
if (keuze == 0x04)
   {
   lcd_init(LCD);                                                           
   for (j = 0; j < 33; j++)
      {
      lcd_send_data(begin[j],LCD);
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      if (j > 19 && j < 25)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   delay_ms(500);
   keuze = 0x05;
   }

                                                                         
if (keuze == 0x05)
   {
   lcd_init(LCD);                                                           
   for (j = 0; j < 33; j++)
      {
      lcd_send_data(Naarbeganegrond[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }
         
if (keuze == 0x06)
   {
   lcd_init(LCD);                                                           
   for (j = 0; j < 33; j++)
      {
      lcd_send_data(man_bed[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }
         
if (keuze == 0x07)
   {
   lcd_init(LCD);                                                           
   for (j = 0; j < 33; j++)
      {
      lcd_send_data(Alarmtxt[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }

if (keuze == 0x08)
   {
   lcd_init(LCD);                                                           
   for (j = 0; j < 33; j++)
      {
      lcd_send_data(Noodstoptxt[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }

if (keuze == 0x09)
   {
   lcd_init(LCD);                                                           
   for (j = 0; j < 33; j++)
     {
     lcd_send_data(omhoog[j],LCD);                       
     if (j > 14 && j < 16)
         {
        lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }

if (keuze == 0x10)
   {
   lcd_init(LCD);                                                           
   for (j = 0; j < 33; j++)
      {
      lcd_send_data(omlaag[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }
}
void     locatie()
{
   if (input(PIN_A2) == 0){v = 0;}
   if (input(PIN_A3) == 0){v = 1;}
   if (input(PIN_A4) == 0){v = 2;}
   if (input(PIN_A5) == 0){v = 3;}
}
void     pwm_up()
{
   for (i=0; i<254; i++)
      {     
      if (i == 253) break;
      set_pwm1_duty(i);
      delay_ms(3);
      }
}
void     pwm_down()
{
   for (i = 255; i > 75; i--)
      {
      if (i == 76) break;
      set_pwm1_duty(i);
      delay_ms(3);
      }                                               
}
void     handmatig()
{
   Display(0x06);
   if (input(PIN_A0) == 1 && input(PIN_A1) == 0 )
      {
      output_high(PIN_C1);
      delay_ms(5);
      pwm_up();

      while (input(PIN_A0) == 1 && input(PIN_A1) == 0 )
         {
         i = 255;
         delay_ms(5);
         set_pwm1_duty(i);
     
         if (input(PIN_A0) == 0)
            {   
            pwm_down();
            delay_ms(2);
            output_low(PIN_C1);
            delay_ms(2);
            set_pwm1_duty(0);           
            }
         }   
      }
   
   if (input(PIN_A1) == 1 && input(PIN_A0) == 0 )
      {
      output_low(PIN_C1);
      delay_ms(10);
      pwm_up() ;     
     
      while (input(PIN_A1) == 1 && input(PIN_A0) == 0 )
         {
         i = 255;
         delay_ms(2);
         set_pwm1_duty(i);
           
         if (input(PIN_A1) == 0)
            {   
            pwm_down();
            delay_ms(2);
            set_pwm1_duty(0);
            }
         }
      }
}
void     beganegrond()
{
   if (input(PIN_D7) == 1 && v > 0 )
   {
      output_low(PIN_C1);
      r = 0;                                                                     //0 dus de lift moet omlaag     
      Display(0x10);   
      delay_ms(5);

      pwm_up();
     
      while (input(PIN_A2) == 1)
         {
         set_pwm1_duty (100);
         a = 1;
         if (input(PIN_A2) == 0) break;
         }
     
      Display(0x00);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A2) == 1 && a == 1)
         {
         set_pwm1_duty(30);
         if (input(PIN_A2) == 0)
            {
            a = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   }
}
void     verdieping1()
{
   if (input(PIN_D6) == 1 && v > 1 || input(PIN_D5) == 1 && v > 1)               // verdieping is groter dan 1 dus lift moet naar beneden
   {
      output_low(PIN_C1);
      delay_ms(5);
      pwm_up();
      Display(0x10);
      if (input(PIN_D6) == 1) r = 0;                                                   
      while (input(PIN_A3) == 1)
         {
         set_pwm1_duty (100);
         b = 1;
         if (input(PIN_A3) == 0) break;
         }

      Display(0x01);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A3) == 1 && b == 1)
         {
         set_pwm1_duty(30);
         Display(0x01);
         if (input(PIN_A3) == 0)
            {
            b = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   }   
   
   else if (input(PIN_D6) == 1 && v < 1 || input(PIN_D5) == 1 && v < 1)
   {
      output_high(PIN_C1);
      delay_ms(5);
      pwm_up();
      Display(0x09);
     
      while (input(PIN_A3) == 1)
         {
         set_pwm1_duty (100);
         b = 1;
         if (input(PIN_A3) == 0) break;
         }

      Display(0x01);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A3) == 1 && b == 1)
         {
         set_pwm1_duty(30);
         Display(0x01);
         if (input(PIN_A3) == 0)
            {
            b = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   }   
}
void     verdieping2()
{
   if (input(PIN_D4) == 1 && v > 2 || input(PIN_D3) == 1 && v > 2)
   {
      output_low(PIN_C1);
      delay_ms(5);
      pwm_up();
      Display(0x10);
     
      while (input(PIN_A4) == 1)
         {
         set_pwm1_duty (100);
         c = 1;
         if (input(PIN_A4) == 0) break;
         }
     
      Display(0x02);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A4) == 1 && c == 1)
         {
         set_pwm1_duty(30);
         if (input(PIN_A4) == 0)
            {
            c = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   }   
   
   else if (input(PIN_D4) == 1 && v < 2 || input(PIN_D3) == 1 && v < 2)
   {
      output_high(PIN_C1);
      delay_ms(5);
      pwm_up();
      Display(0x09);
     
      while (input(PIN_A4) == 1)
         {
         set_pwm1_duty (100);
         c = 1;
         if (input(PIN_A4) == 0) break;
         }

      Display(0x02);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A4) == 1 && c == 1)
         {
         set_pwm1_duty(30);
         if (input(PIN_A4) == 0)
            {
            c = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   } 
}
void     verdieping3()
{
   if (input(PIN_D2) == 1 && v < 3)
   {
      output_high(PIN_C1);
      delay_ms(5);
      pwm_up();
      Display(0x09);
     
      while (input(PIN_A5) == 1)
         {
         set_pwm1_duty (100);
         d = 1;
         if (input(PIN_A5) == 0) break;
         }

      Display(0x03);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A5) == 1 && d == 1)
         {
         set_pwm1_duty(30);
         if (input(PIN_A5) == 0)
            {
            d = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   }     
}
void     stoplift()
{
   if (input(PIN_B0) == 1)                                                       // Eindschakelaars
   {
      set_pwm1_duty(0);
      output_low(PIN_C1);
           
      if (input(PIN_B0) == 1 && input(PIN_B1) == 1)
      {
         output_low(PIN_C1);
         delay_ms(50);
         set_pwm1_duty(50);
         delay_ms(2500);
      }
      if (input(PIN_B0) == 1 && input(PIN_B2) == 1)
         {
         output_high(PIN_C1);
         delay_ms(50);
         set_pwm1_duty(50);
         delay_ms(2500);
         }
   }
}
void     start()
{
   Display(0x04);
   if (x < 2 && input(PIN_A2) == 1)
      {
      while ( x == 0)
         {
         output_low(PIN_C1);
         set_pwm1_duty(100);
     
         if (input(PIN_A2) == 0) x = 1;
         }

      delay_ms(10);
     
      if ( input(PIN_A2) == 0 || x == 1)
         {
         output_low(PIN_C1);
         set_pwm1_duty(50);
         delay_ms(750);
         
         while (input(PIN_A2)== 1)
            {         
            set_pwm1_duty(25);
            delay_ms(5);
            if (input(PIN_A2) == 0)
               {
               set_pwm1_duty(0);
               x = 2;
               break;
               }
            }
         }
      }
}
void     noodstop()
{
   Display(0x08);
   if (input(PIN_B5) == 1)
      {
      while (input(PIN_B5) == 1)
         {
         set_pwm1_duty(0);
         }
      }
   if (input(PIN_B5) == 1)
      {
      while (input(PIN_B5) == 0)
         {
         handmatig();
         }
      }
}
void     alarm()
{
   Display(0x07);
}


#INT_EXT
void stoplift();

void main()
{
   enable_interrupts(INT_EXT);                                                  //Interrupt aanzetten van externe pin B0
   setup_timer_2(T2_DIV_BY_16,255,1);
   setup_CCP1(CCP_PWM);
   
   output_low(PIN_C0);
   output_low(PIN_C1);
   output_low(PIN_C2);
   set_pwm1_duty(0);
 
   a, b, c, d = 0;
   i = 0;
   x = 0;
   
//   start();
   
   while(input(PIN_D0) == 0 || input(PIN_D1) == 0)
      {
      locatie();
     
      if (input(PIN_D0) == 1) noodstop();
      else if (input(PIN_D1) == 1) alarm();
      else if (input(PIN_B5) == 0)
         {
         handmatig();
         set_pwm1_duty(0);
         }
     
      else 
         {
         set_pwm1_duty(0);
         delay_ms(5);
         
         locatie();
         beganegrond();
         verdieping1();
         verdieping2();
         verdieping3();
         }     
      }
}
Ttelmah



Joined: 11 Mar 2010
Posts: 19513

View user's profile Send private message

PostPosted: Wed Jan 25, 2023 11:51 am     Reply with quote

There is a big issue with your counts.

Your 32 character arrays have entries from 0 to 31. You try to send
characters from 0 to 32....

You are enabling INT_EXT, but not INT_GLOBAL.

I don't see how the code ensures that lcd_init will be called?. This
needs to happen at the start after a few hundred mSec to allow the
display to wake.
PrinceNai



Joined: 31 Oct 2016
Posts: 479
Location: Montenegro

View user's profile Send private message

PostPosted: Wed Jan 25, 2023 12:28 pm     Reply with quote

Code:

void     Display (char keuze)


You could shorten your code by doing lcd_init(LCD); only once when you call the function, before you check keuze. Using else if instead of if. This way you are always checking everything, even if the first if was already true.
temtronic



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

View user's profile Send private message

PostPosted: Wed Jan 25, 2023 1:01 pm     Reply with quote

Usually an 'lcdinit()' function is only called once at the beginning of main() to setup the LCD module as required( say put into 4bit mode ). At least that's how all the 'HD44780' (?) modules are done.

Perhaps post the make/model info of the I2C LCD module you're using, to help us, help you.
PrinceNai



Joined: 31 Oct 2016
Posts: 479
Location: Montenegro

View user's profile Send private message

PostPosted: Wed Jan 25, 2023 1:08 pm     Reply with quote

Quote:

Usually an 'lcdinit()' function is only called once at the beginning of main() to setup the LCD module as required( say put into 4bit mode ).


Exactly. I noticed no LCD driver library is used and didn't follow it. Normally this is done so, and then just call something like LcdClear to erase everything and get back to a starting position for a new write. No need to set the mode every time.
rlabee



Joined: 25 Jan 2023
Posts: 7

View user's profile Send private message

PostPosted: Thu Jan 26, 2023 12:47 am     Reply with quote

Hi all,

Thanks for replying and helping me out with this.

So to start
Quote:
Your 32 character arrays have entries from 0 to 31. You try to send
characters from 0 to 32....

you're right about this one, didn't notice this and changed it.

Quote:
You are enabling INT_EXT, but not INT_GLOBAL.

I've put int global in the code to, but is there anymore i need to add? I thought, because it has no further function with it, i could let it out.

Quote:
I don't see how the code ensures that lcd_init will be called?. This
needs to happen at the start after a few hundred mSec to allow the
display to wake.

I've put the LCD_init() at the front in main now. I called lcd_init() every time when it needed to send something to the display, just like PrinceNai and temtronic said.

Quote:
Using else if instead of if.

Thanks for this tip!

Quote:
Perhaps post the make/model info of the I2C LCD module you're using, to help us, help you.

I don't now exactly what you mean with this, but i'm using a PCF8574 I2C LCD module.

Quote:
Exactly. I noticed no LCD driver library is used and didn't follow it. Normally this is done so, and then just call something like LcdClear to erase everything and get back to a starting position for a new write. No need to set the mode every time.

That's true, I didn't use a LCD driver library because the flex_lcd driver on this forum didn't seem to work for me.
I will look into this option again and try to make it work.

so the new code right now is:
Code:
#include <16f877a.h>
#include <STDIO.h>
#fuses   HS,NOWDT
#use     delay(clock=20000000)
#use     I2C(MASTER, SCL=PIN_C3, SDA=PIN_C4, SLOW)

int16    a, b, c, d, i, r, v, x;
char     j;

unsigned char        address[1]                    =  {0x4E};                    //adres van de 2x16 segment display
unsigned char        LCD                           =  0;

const unsigned char  begane_grond[32]              =  {"Begane grond                    "};     // 0x00
const unsigned char  eerste_ver[32]                =  {"Verdieping 1                    "};     // 0x01
const unsigned char  tweede_ver[32]                =  {"Verdieping 2                    "};     // 0x02
const unsigned char  derde_ver[32]                 =  {"Verdieping 3                    "};     // 0x03
const unsigned char  begin[32]                     =  {" Lift start op                  "};     // 0x04
const unsigned char  Naarbeganegrond[32]           =  {"Lift gaat naar  Begane grond    "};     // 0x05
const unsigned char  man_bed[32]                   =  {"Lift wordt hand-  matig bediend "};     // 0x06
const unsigned char  Alarmtxt[32]                  =  {"ALARM! STAY CALM LIFT VERPLAATST"};     // 0x07
const unsigned char  Noodstoptxt[32]               =  {"NOODSTOP        HULP IS ONDERWEG"};     // 0x08
const unsigned char  omhoog[32]                    =  {"  Lift gaat          OMHOOG     "};     // 0x09
const unsigned char  omlaag[32]                    =  {"  Lift gaat          OMLAAG     "};     // 0x10

void     lcd_send_cmd (unsigned char data, unsigned char adres)                  //versturen van een instructie naar een display
{
   unsigned char data_l, data_u;                                                 //Benodigd omdat display in 4-wire mode wordt gebruikt. Eerst sturen van b7-b4, vervolgd door b3-b0
   data_l = (data<<4)&0xf0;                                                      //select lower nibble by moving it to the upper nibble position
   data_u = data&0xf0;                                                           //select upper nibble
 
   i2c_start();                                                                  //opstarten van i2c communicatie
   i2c_write(address[adres]);                                                    //selecteren van de juiste display adres                             
   i2c_write(data_u|0x0C);                                                       //enable =1 and rs =0
   i2c_write(data_u|0x08);                                                       //enable =0 and rs =0

   i2c_write(data_l|0x0C);                                                       //enable =1 and rs =0
   i2c_write(data_l|0x08);                                                       //enable =0 and rs =0
   i2c_stop();                                                                   //stoppen van i2c communicatie
   delay_ms(5);                                                                  //benodigd om het proces te vertragen
}
void     lcd_send_data (unsigned char data, unsigned char adres)                 //versturen van de karakters naar een display (Display Data RAM (DDRAM)
{
   unsigned char data_l, data_u;                                                 //Benodigd omdat display in 4-wire mode wordt gebruikt. Eerst sturen van b7-b4, vervolgd door b3-b0
   data_l = (data<<4)&0xf0;                                                      //select lower nibble by moving it to the upper nibble position
   data_u = data&0xf0;                                                           //select upper nibble
     
   i2c_start();                                                                  //opstarten van i2c communicatie
   i2c_write(address[adres]);                                                    //selecteren van de juiste display adres
   i2c_write(data_u|0x0D);                                                       //enable =1 and rs =1
   i2c_write(data_u|0x09);                                                       //enable =0 and rs =1

   i2c_write(data_l|0x0D);                                                       //enable =1 and rs =1
   i2c_write(data_l|0x09);                                                       //enable =0 and rs =1
   i2c_stop();                                                                   //stoppen van i2c communicatie
   delay_ms(5);                                                                  //benodigd om het proces te vertragen
}
void     lcd_init (unsigned char adres)                                          //Klaarzetten van het display
{
   lcd_send_cmd (0x02, adres);                                                   //Return Home instructie 
   lcd_send_cmd (0x28, adres);                                                   //4-bit bus mode, 2-line display mode en 5x8 dots display format
   lcd_send_cmd (0x0C, adres);                                                   //Display aan, Cursor aan, knipperende Cursor uit
   lcd_send_cmd (0x80, adres);                                                   //Zet cursor op punt 0,0 van het display
   delay_ms(5);                                                                  //benodigd om het proces te vertragen
}
void     Display (char keuze){                                                   // void voor woorden naar LCD te sturen

 if (keuze == 0x00)
   {                                                                             
      for (j = 0; j < 32; j++)                                                   //for loop die het woord afloopt
         {                                                 
         lcd_send_data(begane_grond[j],LCD);                       
         if (j > 14 && j < 16)                                                   //Als j gelijk is aan 15, naar volgende regel van lcd
            {                                                                   
            lcd_send_cmd (0xC0,LCD);                                              //Zet display op de 2de regel
            }
         }
      }
   }                                         
         
 else (keuze == 0x01)
   {                                                           
   for (j = 0; j < 32; j++)
      {
      lcd_send_data(eerste_ver[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }

else (keuze == 0x02)
   {                                                         
   for (j = 0; j < 32; j++)
      {
      lcd_send_data(tweede_ver[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }
         
else (keuze == 0x03)
   {                                                         
   for (j = 0; j < 32; j++)
      {
      lcd_send_data(derde_ver[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }
         
else (keuze == 0x04)
   {                                                         
   for (j = 0; j < 32; j++)
      {
      lcd_send_data(begin[j],LCD);
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      if (j > 19 && j < 25)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   delay_ms(500);
   keuze = 0x05;
   }

                                                                         
else (keuze == 0x05)
   {                                                           
   for (j = 0; j < 32; j++)
      {
      lcd_send_data(Naarbeganegrond[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }
         
else (keuze == 0x06)
   {                                                           
   for (j = 0; j < 32; j++)
      {
      lcd_send_data(man_bed[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }
         
else (keuze == 0x07)
   {                                                           
   for (j = 0; j < 32; j++)
      {
      lcd_send_data(Alarmtxt[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }

else (keuze == 0x08)
   {                                                           
   for (j = 0; j < 32; j++)
      {
      lcd_send_data(Noodstoptxt[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }

else (keuze == 0x09)
   {                                                         
   for (j = 0; j < 32; j++)
     {
     lcd_send_data(omhoog[j],LCD);                       
     if (j > 14 && j < 16)
         {
        lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }

else (keuze == 0x10)
   {                                                           
   for (j = 0; j < 32; j++)
      {
      lcd_send_data(omlaag[j],LCD);                       
      if (j > 14 && j < 16)
         {
         lcd_send_cmd (0xC0,LCD);
         }
      }
   }
   }
}
void     locatie()
{
   if (input(PIN_A2) == 0){v = 0;}
   if (input(PIN_A3) == 0){v = 1;}
   if (input(PIN_A4) == 0){v = 2;}
   if (input(PIN_A5) == 0){v = 3;}
}
void     pwm_up()
{
   for (i=0; i<254; i++)
      {     
      if (i == 253) break;
      set_pwm1_duty(i);
      delay_ms(3);
      }
}
void     pwm_down()
{
   for (i = 255; i > 75; i--)
      {
      if (i == 76) break;
      set_pwm1_duty(i);
      delay_ms(3);
      }                                               
}
void     handmatig()
{
   Display(0x06);
   if (input(PIN_A0) == 1 && input(PIN_A1) == 0 )
      {
      output_high(PIN_C1);
      delay_ms(5);
      pwm_up();

      while (input(PIN_A0) == 1 && input(PIN_A1) == 0 )
         {
         i = 255;
         delay_ms(5);
         set_pwm1_duty(i);
     
         if (input(PIN_A0) == 0)
            {   
            pwm_down();
            delay_ms(2);
            output_low(PIN_C1);
            delay_ms(2);
            set_pwm1_duty(0);           
            }
         }   
      }
   
   if (input(PIN_A1) == 1 && input(PIN_A0) == 0 )
      {
      output_low(PIN_C1);
      delay_ms(10);
      pwm_up() ;     
     
      while (input(PIN_A1) == 1 && input(PIN_A0) == 0 )
         {
         i = 255;
         delay_ms(2);
         set_pwm1_duty(i);
           
         if (input(PIN_A1) == 0)
            {   
            pwm_down();
            delay_ms(2);
            set_pwm1_duty(0);
            }
         }
      }
}
void     beganegrond()
{
   if (input(PIN_D7) == 1 && v > 0 )
   {
      output_low(PIN_C1);
      r = 0;                                                                     //0 dus de lift moet omlaag     
      Display(0x10);   
      delay_ms(5);

      pwm_up();
     
      while (input(PIN_A2) == 1)
         {
         set_pwm1_duty (100);
         a = 1;
         if (input(PIN_A2) == 0) break;
         }
     
      Display(0x00);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A2) == 1 && a == 1)
         {
         set_pwm1_duty(30);
         if (input(PIN_A2) == 0)
            {
            a = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   }
}
void     verdieping1()
{
   if (input(PIN_D6) == 1 && v > 1 || input(PIN_D5) == 1 && v > 1)               // verdieping is groter dan 1 dus lift moet naar beneden
   {
      output_low(PIN_C1);
      delay_ms(5);
      pwm_up();
      Display(0x10);
      if (input(PIN_D6) == 1) r = 0;                                                   
      while (input(PIN_A3) == 1)
         {
         set_pwm1_duty (100);
         b = 1;
         if (input(PIN_A3) == 0) break;
         }

      Display(0x01);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A3) == 1 && b == 1)
         {
         set_pwm1_duty(30);
         Display(0x01);
         if (input(PIN_A3) == 0)
            {
            b = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   }   
   
   else if (input(PIN_D6) == 1 && v < 1 || input(PIN_D5) == 1 && v < 1)
   {
      output_high(PIN_C1);
      delay_ms(5);
      pwm_up();
      Display(0x09);
     
      while (input(PIN_A3) == 1)
         {
         set_pwm1_duty (100);
         b = 1;
         if (input(PIN_A3) == 0) break;
         }

      Display(0x01);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A3) == 1 && b == 1)
         {
         set_pwm1_duty(30);
         Display(0x01);
         if (input(PIN_A3) == 0)
            {
            b = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   }   
}
void     verdieping2()
{
   if (input(PIN_D4) == 1 && v > 2 || input(PIN_D3) == 1 && v > 2)
   {
      output_low(PIN_C1);
      delay_ms(5);
      pwm_up();
      Display(0x10);
     
      while (input(PIN_A4) == 1)
         {
         set_pwm1_duty (100);
         c = 1;
         if (input(PIN_A4) == 0) break;
         }
     
      Display(0x02);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A4) == 1 && c == 1)
         {
         set_pwm1_duty(30);
         if (input(PIN_A4) == 0)
            {
            c = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   }   
   
   else if (input(PIN_D4) == 1 && v < 2 || input(PIN_D3) == 1 && v < 2)
   {
      output_high(PIN_C1);
      delay_ms(5);
      pwm_up();
      Display(0x09);
     
      while (input(PIN_A4) == 1)
         {
         set_pwm1_duty (100);
         c = 1;
         if (input(PIN_A4) == 0) break;
         }

      Display(0x02);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A4) == 1 && c == 1)
         {
         set_pwm1_duty(30);
         if (input(PIN_A4) == 0)
            {
            c = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   } 
}
void     verdieping3()
{
   if (input(PIN_D2) == 1 && v < 3)
   {
      output_high(PIN_C1);
      delay_ms(5);
      pwm_up();
      Display(0x09);
     
      while (input(PIN_A5) == 1)
         {
         set_pwm1_duty (100);
         d = 1;
         if (input(PIN_A5) == 0) break;
         }

      Display(0x03);
      set_pwm1_duty (50);
      delay_ms(250);
      while (input(PIN_A5) == 1 && d == 1)
         {
         set_pwm1_duty(30);
         if (input(PIN_A5) == 0)
            {
            d = 2;
            set_pwm1_duty (0);
            break;
            }
         }
   }     
}
void     stoplift()
{
   if (input(PIN_B0) == 1)                                                       // Eindschakelaars
   {
      set_pwm1_duty(0);
      output_low(PIN_C1);
           
      if (input(PIN_B0) == 1 && input(PIN_B1) == 1)
      {
         output_low(PIN_C1);
         delay_ms(50);
         set_pwm1_duty(50);
         delay_ms(2500);
      }
      if (input(PIN_B0) == 1 && input(PIN_B2) == 1)
         {
         output_high(PIN_C1);
         delay_ms(50);
         set_pwm1_duty(50);
         delay_ms(2500);
         }
   }
}
void     start()
{
   Display(0x04);
   if (x < 2 && input(PIN_A2) == 1)
      {
      while ( x == 0)
         {
         output_low(PIN_C1);
         set_pwm1_duty(100);
     
         if (input(PIN_A2) == 0) x = 1;
         }

      delay_ms(10);
     
      if ( input(PIN_A2) == 0 || x == 1)
         {
         output_low(PIN_C1);
         set_pwm1_duty(50);
         delay_ms(750);
         
         while (input(PIN_A2)== 1)
            {         
            set_pwm1_duty(25);
            delay_ms(5);
            if (input(PIN_A2) == 0)
               {
               set_pwm1_duty(0);
               x = 2;
               break;
               }
            }
         }
      }
}
void     noodstop()
{
   Display(0x08);
   if (input(PIN_B5) == 1)
      {
      while (input(PIN_B5) == 1)
         {
         set_pwm1_duty(0);
         }
      }
   if (input(PIN_B5) == 1)
      {
      while (input(PIN_B5) == 0)
         {
         handmatig();
         }
      }
}
void     alarm()
{
   Display(0x07);
}


#INT_EXT
void stoplift();

void main()
{
   enable_interrupts(GLOBAL);                                                    //Global interrupts aanzetten
   enable_interrupts(INT_EXT);                                                   //Interrupt aanzetten van externe pin B0
   setup_timer_2(T2_DIV_BY_16,255,1);
   setup_CCP1(CCP_PWM);
   
   output_low(PIN_C0);
   output_low(PIN_C1);
   output_low(PIN_C2);
   set_pwm1_duty(0);
   
   delay_ms(200);
   lcd_init();                                                                   // Initialiseer LCD
   delay_ms(500);
   
   a, b, c, d = 0;
   i = 0;
   x = 0;
   
//   start();
   
   while(input(PIN_D0) == 0 || input(PIN_D1) == 0)
      {
      locatie();
     
      if (input(PIN_D0) == 1) noodstop();
      else if (input(PIN_D1) == 1) alarm();
      else if (input(PIN_B5) == 0)
         {
         handmatig();
         set_pwm1_duty(0);
         }
     
      else 
         {
         set_pwm1_duty(0);
         delay_ms(5);
         
         locatie();
         beganegrond();
         verdieping1();
         verdieping2();
         verdieping3();
         }     
      }
}


sorry for the long post, my program seems to be huge. That's why i'm happy with all the tips and tricks.
Ttelmah



Joined: 11 Mar 2010
Posts: 19513

View user's profile Send private message

PostPosted: Thu Jan 26, 2023 1:59 am     Reply with quote

The 'flex' driver is for a parallel connected LCD, not an I2C one. This is
the I2C flex driver:
[url]
http://www.ccsinfo.com/forum/viewtopic.php?t=54063&highlight=i2c+lcd+driver
[/url]
rlabee



Joined: 25 Jan 2023
Posts: 7

View user's profile Send private message

PostPosted: Thu Jan 26, 2023 2:35 am     Reply with quote

Thanks for the i2c link.

The only problem is that it isn't working for me.
even the test program given with the i2c flex driver wont work.
Ttelmah



Joined: 11 Mar 2010
Posts: 19513

View user's profile Send private message

PostPosted: Thu Jan 26, 2023 2:40 am     Reply with quote

Are you sure your I2C LCD, is a 5v device?. a lot are not.
Post the part number of the LCD, a preferably a link to it's datasheet.
rlabee



Joined: 25 Jan 2023
Posts: 7

View user's profile Send private message

PostPosted: Thu Jan 26, 2023 2:47 am     Reply with quote

Well, i have multiple LCD laying around. To test I use the one that came with the easypic v7 (which works on i2c before the program got stuck).
I also have a HD44780 https://www.sparkfun.com/datasheets/LCD/HD44780.pdf

which also worked before the program got stuck. So i hope it isn't because i have the wrong lcd's.
Ttelmah



Joined: 11 Mar 2010
Posts: 19513

View user's profile Send private message

PostPosted: Thu Jan 26, 2023 3:07 am     Reply with quote

I'm now really puzzled. The standard LCD on an EasyPIC, is not an I2C LCD,
but a standard parallel one.
The setup for the EZ-Flex driver for this would be:
Code:

#define LCD_DB4   PIN_B0
#define LCD_DB5   PIN_B1
#define LCD_DB6   PIN_B2
#define LCD_DB7   PIN_B3

#define LCD_RS    PIN_B4
#define LCD_RW    PIN_A0 //Not used
#define LCD_E     PIN_B5

//#define USE_RW_PIN   1


It'd want the standard EZ-Flex driver code.
I cannot see how your display could have worked!...
rlabee



Joined: 25 Jan 2023
Posts: 7

View user's profile Send private message

PostPosted: Thu Jan 26, 2023 3:13 am     Reply with quote

This one came with it
https://www.mikroe.com/lcd-2x16-blue

And it still works with my beginning code (not the one on this page). My other LCD also works with my beginning code through i2c.
Ttelmah



Joined: 11 Mar 2010
Posts: 19513

View user's profile Send private message

PostPosted: Thu Jan 26, 2023 4:17 am     Reply with quote

That is _not_ an I2C LCD. Cannot work with I2C code.
You must have been using some other code without realising it.
Possibly loading the compilers own LCD library for example.
rlabee



Joined: 25 Jan 2023
Posts: 7

View user's profile Send private message

PostPosted: Thu Jan 26, 2023 4:55 am     Reply with quote

oh, that's strange.
maybe that's the reason the program gets stuck?

Which LCD is the best, in your opinion, to work with?
PrinceNai



Joined: 31 Oct 2016
Posts: 479
Location: Montenegro

View user's profile Send private message

PostPosted: Thu Jan 26, 2023 8:06 am     Reply with quote

You are not using "else if" in your function. I really don't know how a sequence of elses only work.
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Goto page 1, 2  Next
Page 1 of 2

 
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