|
|
View previous topic :: View next topic |
Author |
Message |
ezflyr
Joined: 25 Oct 2010 Posts: 1019 Location: Tewksbury, MA
|
|
Posted: Mon Nov 21, 2016 11:49 am |
|
|
Hi Mahatia,
Fundamentally, this is a 'help you do it' forum, not a 'do it for you' forum. IOW, we are happy to make suggestions and comment on *your* code, but we aren't going to write code for you.
I suspect you lost the interest of many with these words: "when I simulate it with Proteus". I know that many people, particularly students, favor Proteus for simulations, but those of us that build hardware and write code for a living recognize that Proteus can be a rat hole of wasted time, and so we tend to tune out.....
If you want to add some input buttons to your project, I recommend that you search for and implement PCM programmers 'button' routine. For a couple of switches it works great, and handles all the debounce issues you are likely to face.
Use the buttons to change some temporary time variables, eg. TempHours, TempMinutes, TempSeconds, etc., and then pass these variable to a routine that updates the real time clock. This is a fairly advanced topic, so we are here to help, but you've got to run with the ball first!
FWIW, I built a nice clock based on the DS3231 RTC and a 128x64 GLCD display a couple of years ago. It's got three push buttons, 'Mode/Enter', 'Inc', and 'Dec'. The Mode/Enter button allows me to step thru menus (Time set, Alarm set, etc.), and settings within menus, and the Inc(rement) and Dec(rement) buttons allow me to change the values contained on the menus. Once all the values have been set to my satisfaction, I use all these temporary values to update the RTC. _________________ John
If it's worth doing, it's worth doing in real hardware! |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9274 Location: Greensville,Ontario
|
|
Posted: Mon Nov 21, 2016 4:11 pm |
|
|
re:
Quote: |
But could tell me why the seconds takes a long time to increments when I simulate it with Proteus? this is my code:
|
the simple answer is that Proteus is BUSTED !! You should never,ever trust Proteus to be 100% accurate and functional. I could write a book about the shortfalls and errors within Proteus,actually thought that, but life is way to short.
Besides too few these days actually read books, or 500 page datasheets...
There are 2 certainties about Proteus
1) just because it 'works' within the simulation there is NO guarantee it WILL work in the 'real world'.
2) if it does work in the 'real world', it might not in Proteus.
Jay |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Mon Nov 21, 2016 6:01 pm |
|
|
mahatia wrote: |
#define Device_Address_DS1307_EEPROM 0xD0
void Write_Byte_To_DS1307_RTC(unsigned char, unsigned char);
unsigned char Read_Byte_From_DS1307_RTC(unsigned char);
void Write_Bytes_To_DS1307_RTC(unsigned char,unsigned char*,unsigned char);
void Read_Bytes_From_DS1307_RTC(unsigned char,unsigned char*,unsigned int);
void Set_DS1307_RTC_Time(unsigned char,unsigned char,unsigned char,unsigned char);
unsigned char* Get_DS1307_RTC_Time(void);
void Set_DS1307_RTC_Date(unsigned char,unsigned char,unsigned char,unsigned char);
unsigned char* Get_DS1307_RTC_Date(void);
|
The ds1307.h file (above) has no relation to the functions in ds1307.c
that you posted. Are you secretly using a different ds1307 driver than
the one you posted ? You said earlier about the ds1307.c you posted:
Quote: | I found this driver in this forum but I get many errors when I use it with my code |
What ds1307 driver are you actually using ? Post it or post a link to it.
If you're using one that has the same functions as shown in bold above
then post it. I want to see it. |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9274 Location: Greensville,Ontario
|
|
Posted: Tue Nov 22, 2016 6:12 am |
|
|
this...
#define Device_Address_DS1307_EEPROM 0xD0
isn't quite true
At least I'm not aware of any EEPROM in a DS1307.
There is a small amount of battery backed CMOS RAM that I use for 'parameter' storage though. It's faster,simpler and 'byte' accessable unlike most EEPROMs
My gut tells me the OP has a mishmash of driver code and really neds to erase ALL of it and just use the 100% WORKING CCS driver.
Jay |
|
|
mahatia
Joined: 14 Nov 2016 Posts: 23
|
|
Posted: Wed Nov 23, 2016 4:38 am |
|
|
Hello PCM programmer! I want to give you thanks for the several helps you've give for me!
At the beginning, I used the code that I've found here but I had got some problems with the PIC12F's ROM and I've changed it!
Now, i try to adjust minute and hour, I wrote this code but it doesn't work normally! I have already done all that I know! These are my codes:
I2C_LCD.c
Code: | #include <12F675.h>
#device *= 16
#fuses NOWDT, PROTECT, CPD, NOMCLR, INTRC_IO, BROWNOUT, PUT
#use delay (internal = 4MHz)
#byte GPIO = 0x00
#include "lcd.c"
#include "DS1307.c"
void setup();
int i = 0;
void main()
{
byte day;
byte mth;
byte year;
byte hr;
byte min;
byte sec;
LCD_init();
return_:
ds1307_init();
ds1307_get_date(day,mth,year); // Read date
ds1307_get_time(hr,min,sec);
LCD_goto(4,0);
printf(LCD_putchar," %02d:\%02d:\%02d",hr,min,sec); // Display time
LCD_goto(5,1);
printf(LCD_putchar,"\%02d/\%02d/20\%02d",day,mth,year); // Display date
char txt3 = "M";
char txt4 = "H";
while(TRUE)
{
if(input(PIN_A1) == 0)
i++;
if (i == 1)
{
LCD_command(clear_display);
LCD_goto(7,0);
LCD_putchar(txt3);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",min);
delay_ms(99);
if(input(PIN_A0) == 0)
{min++;
min = min;
}
}
if(input(PIN_A1) == 0)
i++;
if (i == 2)
{
LCD_command(clear_display);
LCD_goto(7,0);
LCD_putchar(txt4);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",hr);
delay_ms(100);
if(input(PIN_A0) == 0)
{hr++;
hr = hr;
}
}
if(input(PIN_A1) == 0)
i++;
if (i == 3)
goto return_;
};
}
void setup()
{
set_tris_a(0b01110000); // GP0 GP1 GP2 input, All outputs
disable_interrupts(GLOBAL);
setup_comparator(NC_NC_NC_NC);
setup_ADC(ADC_off);
setup_ADC_ports(no_analogs);
setup_timer_0(T0_internal);
setup_timer_1(T1_disabled);
set_timer0(0);
set_timer1(0);
LCD_init();
delay_ms(100);
}
|
lcd.c
Code: | #include "lcd.h"
void LCD_init()
{
data_value = 0x30;
PCF8574_write(data_value);
data_value = 0x20;
PCF8574_write(data_value);
data_value |= 0x08;
PCF8574_write(data_value);
delay_ms(dly);
data_value &= 0xF7;
PCF8574_write(data_value);
delay_ms(dly);
LCD_command(_4_pin_interface | _2_row_display | _5x7_dots);
LCD_command(display_on | cursor_off | blink_off);
LCD_command(clear_display);
LCD_command(cursor_direction_inc | display_no_shift);
}
void LCD_command(unsigned char value)
{
data_value &= 0xFB;
PCF8574_write(data_value);
LCD_4bit_send(value);
}
void LCD_send_data(unsigned char value)
{
data_value |= 0x04;
PCF8574_write(data_value);
LCD_4bit_send(value);
}
void LCD_4bit_send(unsigned char lcd_data)
{
unsigned char temp = 0x00;
temp = (lcd_data & 0xF0);
data_value &= 0x0F;
data_value |= temp;
PCF8574_write(data_value);
data_value |= 0x08;
PCF8574_write(data_value);
delay_ms(dly);
data_value &= 0xF7;
PCF8574_write(data_value);
delay_ms(dly);
temp = (lcd_data & 0x0F);
temp <<= 0x04;
data_value &= 0x0F;
data_value |= temp;
PCF8574_write(data_value);
data_value |= 0x08;
PCF8574_write(data_value);
delay_ms(dly);
data_value &= 0xF7;
PCF8574_write(data_value);
delay_ms(dly);
}
void LCD_putchar(char char_data)
{
LCD_send_data(char_data);
}
void LCD_clear_home()
{
LCD_command(clear_display);
LCD_command(goto_home);
}
void LCD_goto(unsigned char x_pos,unsigned char y_pos)
{
if(y_pos == 0)
{
LCD_command(0x80 | x_pos);
}
else
{
LCD_command(0x80 | 0x40 | x_pos);
}
}
|
lcd.h
Code: | #include "PCF8574.c"
#define clear_display 0x01
#define goto_home 0x02
#define cursor_direction_inc (0x04 | 0x02)
#define cursor_direction_dec (0x04 | 0x00)
#define display_shift (0x04 | 0x01)
#define display_no_shift (0x04 | 0x00)
#define display_on (0x08 | 0x04)
#define display_off (0x08 | 0x02)
#define cursor_on (0x08 | 0x02)
#define cursor_off (0x08 | 0x00)
#define blink_on (0x08 | 0x01)
#define blink_off (0x08 | 0x00)
#define _8_pin_interface (0x20 | 0x10)
#define _4_pin_interface (0x20 | 0x00)
#define _2_row_display (0x20 | 0x08)
#define _1_row_display (0x20 | 0x00)
#define _5x10_dots (0x20 | 0x40)
#define _5x7_dots (0x20 | 0x00)
#define dly 0x01
unsigned char data_value = 0x00;
void LCD_init();
void LCD_command(unsigned char value);
void LCD_send_data(unsigned char value);
void LCD_4bit_send(unsigned char lcd_data);
void LCD_putstr(char *lcd_string);
void LCD_putchar(char char_data);
void LCD_clear_home();
void LCD_goto(unsigned char x_pos, unsigned char y_pos); |
ds1307.c
Code: | #include <DS1307.h>
#define RTC_SDA pin_A5
#define RTC_SCL pin_A4
#use i2c(master, sda=RTC_SDA, scl=RTC_SCL)
byte bin2bcd(byte binary_value);
byte bcd2bin(byte bcd_value);
void ds1307_init(void)
{
output_float(RTC_SCL);
output_float(RTC_SDA);//niverina indroa io teo
}
void ds1307_get_date(byte &day, byte &mth, byte &year)
{
i2c_start();
i2c_write(0xD0);
//delay_us(1);
i2c_write(0x04); // Start at REG 3 - Day of week
i2c_start();
i2c_write(0xD1);
day = bcd2bin(i2c_read(1) & 0x3f); // REG 4
mth = bcd2bin(i2c_read(1) & 0x1f); // REG 5
year = bcd2bin(i2c_read(0)); // REG 6
i2c_stop();
}
void ds1307_get_time(byte &hr, byte &min, byte &sec)
{
i2c_start();
i2c_write(0xD0);
i2c_write(0x00); // Start at REG 0 - Seconds
i2c_start();
i2c_write(0xD1);
sec = bcd2bin(i2c_read(1) & 0x7f);
min = bcd2bin(i2c_read(1) & 0x7f);
hr = bcd2bin(i2c_read(0) & 0x3f);
i2c_stop();
}
byte bin2bcd(byte binary_value)
{
byte temp;
byte retval;
temp = binary_value;
retval = 0;
//while(1) IO NO TEO
while(TRUE)
{
// Get the tens digit by doing multiple subtraction
// of 10 from the binary value.
if(temp >= 10)
{
temp -= 10;
retval += 0x10;
}
else // Get the ones digit by adding the remainder.
{
retval += temp;
break;
}
};
return(retval);
}
// Input range - 00 to 99.
byte bcd2bin(byte bcd_value)
{
byte temp;
temp = bcd_value;
// Shifting upper digit right by 1 is same as multiplying by 8.
temp >>= 1;
// Isolate the bits for the upper digit.
temp &= 0x78;
// Now return: (Tens * 8) + (Tens * 2) + Ones
return(temp + (temp >> 2) + (bcd_value & 0x0f));
}
|
ds1307.h
Code: | #ifndef __DS1307_H
#define __DS1307_H
// Define DS1307 i2c device address
#define Device_Address_DS1307_EEPROM 0xD0
// Function Declarations
void ds1307_init(void);
void ds1307_get_date(byte &day, byte &mth, byte &year);
void ds1307_get_time(byte &hr, byte &min, byte &sec);
byte bin2bcd(byte binary_value);
byte bcd2bin(byte bcd_value); |
PCF8574.c
Code: | #include "PCF8574.h"
unsigned char PCF8574_read()
{
unsigned char port_byte = 0;
i2c_start();
i2c_write(PCF8574_read_cmd);
port_byte = i2c_read(0);
i2c_stop();
return port_byte;
}
void PCF8574_write(unsigned char data_byte)
{
i2c_start();
i2c_write(PCF8574_write_cmd);
i2c_write(data_byte);
i2c_stop();
} |
PCF8574.h
Code: | #define PCF8574_address 0x40 //A2, A1, A0, vers la masse
#define PCF8574_write_cmd PCF8574_address
#define PCF8574_read_cmd (PCF8574_address + 1)
#define SDA_pin pin_A5
#define SCL_pin pin_A4
#use I2C(Master, SDA = SDA_pin, SCL = SCL_pin)
unsigned char PCF8574_read();
void PCF8574_write(unsigned char data_byte); |
thank you PCM programmer, please guide me! |
|
|
mahatia
Joined: 14 Nov 2016 Posts: 23
|
|
Posted: Thu Nov 24, 2016 1:20 am |
|
|
Hello PCM programmer! At last, I can finally do it! I used the pin GP2 interrupt to configure the digital clock!
this is my code!
I2C_LCD.c
Code: | #include <12F675.h>
#device *= 16
#fuses NOWDT, PROTECT, CPD, NOMCLR, INTRC_IO, BROWNOUT, PUT
#use delay (internal = 4MHz)
//#byte GPIO = 0x00
#bit gpio5 =0x05.5
#bit gpio4 =0x05.4
#bit gpio3 =0x05.3
#bit gpio2 =0x05.2
#bit gpio1 =0x05.1
#bit gpio0 =0x05.0
#include "lcd.c"
#include "DS1307.c"
//#define INT_RA3 0x080B08
//#define INT_GP0 0x0010B08
//#define Int_Ext1 GP0
//void setup();
int i = 0;
int cnt;
//#INT_RA3
//void int_on_change_GP03 (void)
//{
//}
#INT_EXT
void EXT_ISR(void)
{
disable_interrupts(GLOBAL);
i++;
cnt=0;
enable_interrupts(GLOBAL);
}
#byte ADCON0 = 0x1F
#byte ANSEL = 0x9F
#byte CMCON = 0x19
void main()
{
ADCON0 = 0; // ADC off
ANSEL = 0; // GPIO pins 0,1,2 and 4 set to all digital
CMCON = 7; // Comparators off
set_tris_a(0b001100);
setup_counters(rtcc_internal,rtcc_div_2);
enable_interrupts(int_ext);
ext_int_edge(h_to_l);
enable_interrupts(global);
//enable_interrupts(INT_RA3);
byte day;
byte mth;
byte year;
byte hr;
byte min;
byte sec;
//setup();
LCD_init();
char txt3 = "M";
char txt4 = "O";
char txt5 = "D";
char txt6 = "v";
char txt7 = "T";
while(TRUE)
{
if((i == 0)||(i == 6))
{
ds1307_init();
ds1307_get_date(day,mth,year); // Read date
ds1307_get_time(hr,min,sec);
LCD_goto(4,0);
printf(LCD_putchar," %02d:\%02d:\%02d",hr,min,sec); // Display time
LCD_goto(5,1);
printf(LCD_putchar,"\%02d/\%02d/20\%02d",day,mth,year); // Display date
}
else
{
if(cnt==0)
{
LCD_command(clear_display);
cnt=1;
}
if (i==1)
{
LCD_goto(7,0);
LCD_putchar(txt3);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",min);
}
if (i==2)
{
LCD_goto(7,0);
LCD_putchar(txt4);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",hr);
}
if (i ==3)
{
LCD_goto(7,0);
LCD_putchar(txt5);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",day);
}
if (i ==4)
{
LCD_goto(7,0);
LCD_putchar(txt6);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",mth);
}
if (i ==5)
{
LCD_goto(7,0);
LCD_putchar(txt7);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",year);
}
}
};
}
|
Now, I am trying to use GP3 interrupt to increment variables (hr, min, and so on) but I always get error! How to activate interrupt with GP3? Thank you so much! Mahatia |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19596
|
|
Posted: Thu Nov 24, 2016 2:41 am |
|
|
First thing. Repeat fifty times.
Code must _never_ 'enable_interrupts(GLOBAL)' inside an interrupt. Doing so, is a sure way of triggering a chip crash.
The disable is pointless, but does no harm.
The PIC is different from many other chips. On the PIC (PIC12, 14 & 16 - slightly different on the PIC18), the _hardware_ disables the global interrupt bit as soon as the call to the interrupt handler occurs. It also re-enables this the instruction _after_ the chip returns from the interrupt. Enabling the interrupt inside the handler means (since the interrupt flag is still set), the code will loop and interrupt itself. Uurgh.....
There is not a separate interrupt on GP3. You have to use the 'interrupt on change' ability. This will interrupt on all changes on the pin (both rising and falling).
Code: |
//global declaration
static int1 last3;
//To enable this in main
last=input(PIN_A3); //latch must be read before starting
clear_interrupts(INT_RA);
enable_interrupts(INT_RA3); //the '3' here says to enable only on A3
//then to handle it:
//This will be called for _all_ enabled RA interrupts
#INT_RA
void change(void)
{
//Now for just one bit high to low
if (input(PIN_A3))
{
//pin is high
if (last3==0)
last3=1;
}
else
{
//pin is low
if (last3==1)
{
last3=0;
//code here for 'high to low'
}
}
}
|
As a general comment, get rid of all your register declarations. Just use CCS code:
Code: |
//ADCON0 = 0; // ADC off
setup_adc(ADC_OFF);
//ANSEL = 0; // GPIO pins 0,1,2 and 4 set to all digital
setup_adc_ports(NO_ANALOGS);
//CMCON = 7; // Comparators off
setup_comparators(NC_NC);
|
This would work if you move to another chip, while the direct register accesses would have you diving for the data sheet.
If you 'must' do direct accesses, then let the compiler look them up for you:
#byte ADCON0 = getenv("SFR:ADCON0")
#byte ANSEL = getenv("SFR:ANSEL")
#byte CMCON = getenv("SFR:CMCON") |
|
|
mahatia
Joined: 14 Nov 2016 Posts: 23
|
|
Posted: Thu Nov 24, 2016 2:58 am |
|
|
Thanks a lot! I will try it. |
|
|
mahatia
Joined: 14 Nov 2016 Posts: 23
|
|
Posted: Thu Nov 24, 2016 3:47 am |
|
|
Could you explain it more please? I have tried it and get an error! maybe I don't realy understand what you mean! I use PIC12F675 and I have use an interruption with GP2, and now, I need some interruption with GP3 or GP0, thanks a lot! |
|
|
mahatia
Joined: 14 Nov 2016 Posts: 23
|
|
Posted: Thu Nov 24, 2016 1:35 pm |
|
|
so, I can't use any interruption with GP3? can I have external interrupt with GP0? |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9274 Location: Greensville,Ontario
|
|
Posted: Thu Nov 24, 2016 2:23 pm |
|
|
I know English is not everyone's 1st language but for PIC datasheets you NEED to know it.
Microchip very clearly show on table 1-1 on page 6 (of the version I have) that any/all 6 of the GPpins (GP0 ... GP5) do have 'interrupt-on-change' functionality. Section 3.2.2 details what is required and how to access this feature. As such, when properly configured any of those pins can be used for say 'push button pressed' for increment/decrement a counter.
As for using CCS C to do this, simply open the manual (press F11 with your project open) and search for interrupts, there are several paragraphs and sections about this.
You can also look in the examples folder, pretty sure CCS supplies an example. If not you can always try 'Google' as you are NOT the 1st one to have ever used interrupts in the 12F675!
Jay |
|
|
mahatia
Joined: 14 Nov 2016 Posts: 23
|
|
Posted: Fri Nov 25, 2016 12:15 am |
|
|
ok! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19596
|
|
Posted: Fri Nov 25, 2016 2:53 am |
|
|
The reason it'd not compile (in a suitable program), is one error:
last=input(PIN_A3); //latch must be read before starting
I left the '3' out of the variable name. Should be 'last3', not 'last'.
This is because while typing the code I decided you might want to use the same code on multiple pins. When I originally started typing I was doing it for one pin, then decided the same code might be wanted for multiple pins, so added the '3', and missed this one....
However the code as posted cannot compile anyway. Look at the big comment I have added when you try to load the LCD driver...
Temtronic has correctly pointed out what has to happen. It is a fundamental case of understanding the chip. There is _one_ standard interrupt (INT_EXT), on GP2. Just one. There is one other interrupt called an 'interrupt on change'. There is not actually an 'INT_RA3'. Just INT_RA. The point about the '3' is that uised when enabling the interrupt, it programs which pin(s) it is to happen on. This can be used on one or more of the pins on the chip. However unlike INT_EXT, it triggers on every 'change' on the selected pins. So the code in the handler has to work out which pins have changed, and which 'direction' the signal has changed in. The code I posted is to do this for GP3. It records what level is on the pin before starting, and then when the interrupt handler is called, sees whether the signal has changed 'high to low' or 'low to high'. You could actually get rid of INT_EXT, and use just a single handler. As:
Code: |
#include <12F675.h>
#device *= 16
#fuses NOWDT, PROTECT, CPD, NOMCLR, INTRC_IO, BROWNOUT, PUT
#use delay (internal = 4MHz)
//Now there are problems here. You are including an LCD driver
//but there are not enough pins on the chip for this. Duh.....
//Even in 'nibble' mode, an LCD needs 6 output pins to drive it. The
//whole chip only has six pins (five output), and you are using two pins
//for interrupts and two for the bus to the clock chip....
//it can't compile from this point on.... :(
#include "lcd.c"
#include "DS1307.c"
//global variables
int8 i = 0;
int8 cnt;
static int1 last2, last3; //single bits to record the 'last'' state of the pins
//This will be called for _all_ enabled RA interrupts
#INT_RA
void change(void)
{
//Now first RA2
if (input(PIN_A2))
{
//pin is high
if (last2==0)
last2=1;
}
else
{
//pin is low
if (last2==1)
{
last2=0;
//code here for 'high to low' on RA2
i++;
cnt=0;
}
}
//Now RA3
if (input(PIN_A3))
{
//pin is high
if (last3==0)
last3=1;
}
else
{
//pin is low
if (last3==1)
{
last3=0;
//code here for 'high to low' on RA3
}
}
}
void main(void)
{
byte day;
byte mth;
byte year;
byte hr;
byte min;
byte sec; //variables should only be declared at the start of a
//code section. CCS will accept other declarations, but it can
//give problems and is not standard (historical) 'C'.
char txt3 = 'M';
char txt4 = 'O';
char txt5 = 'D';
char txt6 = 'v';
char txt7 = 'T;
//read a C textbook, and understand the difference between a
//single inverted comma, for a 'character' declaration, and double
//inverted commas.....
setup_adc(ADC_OFF); //ADC off
setup_adc_ports(NO_ANALOGS);
setup_comparators(NC_NC); //comparators off
set_tris_a(0b001100);
setup_counters(rtcc_internal,rtcc_div_2);
last3=input(PIN_A3); //latch must be read before starting
last2=input(PIN_A2); //and the same for A2
clear_interrupts(INT_RA);
enable_interrupts(INT_RA3 | INT_RA2); //enable on RA3 and RA2
enable_interrupts(global);
while(TRUE)
{
if((i == 0)||(i == 6))
{
ds1307_init();
ds1307_get_date(day,mth,year); // Read date
ds1307_get_time(hr,min,sec);
LCD_goto(4,0);
printf(LCD_putchar," %02d:\%02d:\%02d",hr,min,sec); // Display time
LCD_goto(5,1);
printf(LCD_putchar,"\%02d/\%02d/20\%02d",day,mth,year); // Display date
}
else
{
if(cnt==0)
{
LCD_command(clear_display);
cnt=1;
}
switch (i)
{
case 1:
LCD_goto(7,0);
LCD_putchar(txt3);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",min);
break;
case 2:
LCD_goto(7,0);
LCD_putchar(txt4);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",hr);
break;
case 3:
LCD_goto(7,0);
LCD_putchar(txt5);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",day);
break;
case 4:
LCD_goto(7,0);
LCD_putchar(txt6);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",mth);
break;
case 5:
LCD_goto(7,0);
LCD_putchar(txt7);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",year);
break;
} //end of switch
}
}
}
|
Now this can't compile, since you just don't have enough pins on the chip.
The LCD interface alone, needs more pins than the chip has. |
|
|
mahatia
Joined: 14 Nov 2016 Posts: 23
|
|
Posted: Fri Nov 25, 2016 4:41 am |
|
|
Ok! Thank you very much. About the LCD, I've used an expander PCF8574 and it works fine. I can display date and hour information on it. My only problem was the interruption. Now, I am going to try it. Thank you very much. |
|
|
mahatia
Joined: 14 Nov 2016 Posts: 23
|
|
Posted: Wed Nov 30, 2016 2:35 am |
|
|
Hello everybody! I don't know what happened with my code but when I simulate it, variables don't increment. Could someone say me the reason please?
lcd_I2c.c
Code: | #include <12F675.h>
#device *= 16
#fuses NOWDT, PROTECT, CPD, NOMCLR, INTRC_IO, BROWNOUT, PUT
#use delay (internal = 4MHz)
#byte GPIO = 0x00
#include "lcd.c"
#include "DS1307.c"
//global variables
int8 i = 0;
int8 cnt;
static int1 last2, last0; //single bits to record the 'last'' state of the pins
byte day;
byte mth;
byte year;
byte hr;
byte min;
byte sec;
//This will be called for _all_ enabled RA interrupts
#INT_RA
void change(void)
{
//Now first RA2
if (input(PIN_A2))
{
//pin is high
if (last2==0)
last2=1;
}
else
{
//pin is low
if (last2==1)
{
last2=0;
//code here for 'high to low' on RA2
disable_interrupts(GLOBAL);
i++;
cnt=0;
enable_interrupts(GLOBAL);
}
}
//Now RA3
if (input(PIN_A0))
{
//pin is high
if (last0==0)
last0=1;
}
else
{
//pin is low
if (last0==1)
{
last0=0;
//code here for 'high to low' on RA3
if (i == 1)
{
if(min<59)min++;
else min = 0;
}
if (i == 2)
{
if(hr<24)hr++;
else hr = 0;
}
if (i == 3)
{
if(day<31)day++;
else day = 1;
}
if (i == 4)
{
if(mth<13)mth++;
{
if (mth ==13)
{
mth = 1;
year++;
}
}
}
}
}
//clear_interrupt(INT_RA); vo napetaka
}
void main(void)
{
char txt3 = "M";
char txt4 = "O";
char txt5 = "D";
char txt6 = "V";
setup_adc(ADC_OFF); //ADC off
setup_adc_ports(NO_ANALOGS);
setup_comparator(NC_NC_NC_NC); //comparators off
set_tris_a(0b001100);
setup_counters(rtcc_internal,rtcc_div_2);
last0=input(PIN_A0); //latch must be read before starting
last2=input(PIN_A2); //and the same for A2
clear_interrupt(INT_RA);
enable_interrupts(INT_RA0 | INT_RA2); //enable on RA3 and RA2
enable_interrupts(global);
LCD_init();
ds1307_init();
ds1307_get_date(day,mth,year); // Read date
ds1307_get_time(hr,min,sec);
while(TRUE)
{
if((i == 0)||(i == 5))
{
LCD_goto(4,0);
printf(LCD_putchar," %02d:\%02d:\%02d",hr,min,sec); // Display time
LCD_goto(5,1);
printf(LCD_putchar,"\%02d/\%02d/20\%02d",day,mth,year); // Display date
}
else
{
if(cnt==0)
{
LCD_command(clear_display);
cnt=1;
}
switch (i)
{
case 1:
LCD_goto(7,0);
LCD_putchar(txt3);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",min);
break;
case 2:
LCD_goto(7,0);
LCD_putchar(txt4);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",hr);
break;
case 3:
LCD_goto(7,0);
LCD_putchar(txt5);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",day);
break;
case 4:
LCD_goto(7,0);
LCD_putchar(txt6);
LCD_goto(7,1);
printf(LCD_putchar, "%02d",mth);
break;
case 5:
i = 0;
break;
//! LCD_goto(7,0);
//! LCD_putchar(txt7);
//! LCD_goto(7,1);
//! printf(LCD_putchar, "%02d",year);
//! break;
} //end of switch
}
};
}
|
Thank you so much. |
|
|
|
|
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
|