Welcome
Username or Email:

Password:


Missing Code




[ ]
[ ]
Online
  • Guests: 55
  • Members: 0
  • Newest Member: omjtest
  • Most ever online: 396
    Guests: 396, Members: 0 on 12 Jan : 12:51
Members Birthdays:
All today's birthdays', congrats!
Self Defenestrate (35)
Alex Yuan (29)


Next birthdays
04/06 Jrz126 (41)
04/07 joshua_ (36)
04/07 Angstrom (37)
Contact
If you need assistance, please send an email to forum at 4hv dot org. To ensure your email is not marked as spam, please include the phrase "4hv help" in the subject line. You can also find assistance via IRC, at irc.shadowworld.net, room #hvcomm.
Support 4hv.org!
Donate:
4hv.org is hosted on a dedicated server. Unfortunately, this server costs and we rely on the help of site members to keep 4hv.org running. Please consider donating. We will place your name on the thanks list and you'll be helping to keep 4hv.org alive and free for everyone. Members whose names appear in red bold have donated recently. Green bold denotes those who have recently donated to keep the server carbon neutral.


Special Thanks To:
  • Aaron Holmes
  • Aaron Wheeler
  • Adam Horden
  • Alan Scrimgeour
  • Andre
  • Andrew Haynes
  • Anonymous000
  • asabase
  • Austin Weil
  • barney
  • Barry
  • Bert Hickman
  • Bill Kukowski
  • Blitzorn
  • Brandon Paradelas
  • Bruce Bowling
  • BubeeMike
  • Byong Park
  • Cesiumsponge
  • Chris F.
  • Chris Hooper
  • Corey Worthington
  • Derek Woodroffe
  • Dalus
  • Dan Strother
  • Daniel Davis
  • Daniel Uhrenholt
  • datasheetarchive
  • Dave Billington
  • Dave Marshall
  • David F.
  • Dennis Rogers
  • drelectrix
  • Dr. John Gudenas
  • Dr. Spark
  • E.TexasTesla
  • eastvoltresearch
  • Eirik Taylor
  • Erik Dyakov
  • Erlend^SE
  • Finn Hammer
  • Firebug24k
  • GalliumMan
  • Gary Peterson
  • George Slade
  • GhostNull
  • Gordon Mcknight
  • Graham Armitage
  • Grant
  • GreySoul
  • Henry H
  • IamSmooth
  • In memory of Leo Powning
  • Jacob Cash
  • James Howells
  • James Pawson
  • Jeff Greenfield
  • Jeff Thomas
  • Jesse Frost
  • Jim Mitchell
  • jlr134
  • Joe Mastroianni
  • John Forcina
  • John Oberg
  • John Willcutt
  • Jon Newcomb
  • klugesmith
  • Leslie Wright
  • Lutz Hoffman
  • Mads Barnkob
  • Martin King
  • Mats Karlsson
  • Matt Gibson
  • Matthew Guidry
  • mbd
  • Michael D'Angelo
  • Mikkel
  • mileswaldron
  • mister_rf
  • Neil Foster
  • Nick de Smith
  • Nick Soroka
  • nicklenorp
  • Nik
  • Norman Stanley
  • Patrick Coleman
  • Paul Brodie
  • Paul Jordan
  • Paul Montgomery
  • Ped
  • Peter Krogen
  • Peter Terren
  • PhilGood
  • Richard Feldman
  • Robert Bush
  • Royce Bailey
  • Scott Fusare
  • Scott Newman
  • smiffy
  • Stella
  • Steven Busic
  • Steve Conner
  • Steve Jones
  • Steve Ward
  • Sulaiman
  • Thomas Coyle
  • Thomas A. Wallace
  • Thomas W
  • Timo
  • Torch
  • Ulf Jonsson
  • vasil
  • Vaxian
  • vladi mazzilli
  • wastehl
  • Weston
  • William Kim
  • William N.
  • William Stehl
  • Wesley Venis
The aforementioned have contributed financially to the continuing triumph of 4hv.org. They are deserving of my most heartfelt thanks.
Forums
4hv.org :: Forums :: Projects
« Previous topic | Next topic »   

Digital Alarm Clock

1 2 
Move Thread LAN_403
wpk5008
Wed Jan 05 2011, 06:56AM Print
wpk5008 Registered Member #3546 Joined: Tue Dec 28 2010, 08:24AM
Location: Pittsburgh, PA
Posts: 18
First project post, please don't be gentile...

This is a simple project I started after the mechanical failures of my persistence of vision propeller clock. I am sure I will get that working someday and have a post for that as well...

For this project I decided to use the PIC16F886 micro controller to run two two-digit seven-segment displays. Because this chip has only 28 pins, and about a third of them were needed for controlling the time and supplying the chip with power, I had to rely on the persistence of vision effect for this project. That being said what I did was use one set of seven pins connected to the corresponding inputs on the four displays, but I connected nMOS transistors on the grounds of each of the four pins. As the micro controller switches what is being displayed it switches which nMOS is in saturation, allowing me to control which display is on. When this is done fast enough it appears constant.

Besides dealing with that little mess I had to write code that kept track of time, allowed the user to change the time, allowed the user to set the alarm clock, and controlled if the alarm clock was turned on.

Alarmclock

Parts:
1-PIC16F886
5-2N7000 MOSFETs
1-8ohm 2W speaker
2-MAN6750 seven segment displays
28-100ohm resistors
5-SPDT switches
1-audio jack
1-7805 regulator
2-ceramic filter capacitors (for the 7805)

If you want a circuit diagram I can probably put one together tomorrow sometime.

My future plans for this project involve adding a thermometer feature, that I have already started as seen here. I'm just running into problems getting the PIC to read the reference values as I am pretty sure the room temperature is not 98 Celsius. It has to be a simple coding error.

Temperature

I think I would like to turn this into my first PCB endeavor. I am thinking of trying the acid etching first, if you have any tips on that throw me a pm. If I am to put anymore time into this I will also have to clean the code up as it is rather sloppy right now. Another idea I have is wiring the right most two digit display upside down so that I can use the decimal points as the colon of a clock. I know that you can get displays with the colon, but I'm cheap. I also seem to be having a problem with driving the speaker with an MP3 player but I attribute that to not having any fresh batteries for my MP3 player right now. It works great off my computer.

Oh one last thing I forgot to mention, it currently is running off the PIC's internal oscillator, which is amazing because it only loses about one minute per seventy-six minutes. I am looking into the best solution. I can either add code to add an extra minute every so often, I can adjust the frequency of the oscillator, I could learn how to add an external crystal, or I could create a wall power supply for it like the clocks you buy that would a square wave clock generator based off the oscillations in the AC voltage. The last would be the best solution as the power companies actually will adjust the frequency during none peak hours so that the frequency averages out to exactly 60 Hz over the course of each day.

This project is mostly for me proof of concept though. I hopefully by the end of this year will have created the world most dangerous alarm clock. Nixie clock with a plasma speaker anyone? Although I am not sure that the plasma speaker will be loud enough.

The source code is as follows... Let me warn you though that I only code in assembly, I find programming in assembly to be more of a challenge for my personal projects. I only ask that you please do not re-post my code elsewhere on the web without accreditation.

Mind you this code is rather sloppy right now, instead of using one set of code to control the display and time changing of both the actual time and the alarm time I copied the code and changed the variables. Also, the displaying function could use a rewrite, it is rather disgusting imo.

;Walter P Kerin
;Seven Segment Display Clock

#include <p16F886.inc>
	__CONFIG _CONFIG1, _LVP_OFF & _FCMEN_OFF & _IESO_OFF & _BOR_OFF & _CPD_OFF & _CP_OFF & _MCLRE_OFF & _PWRTE_ON & _WDT_OFF & _INTRC_OSC_NOCLKOUT 
	__CONFIG _CONFIG2, _WRT_OFF & _BOR21V

	cblock 0x20
ten
hundred
Seconds

MinuteOnes
MinuteTens
HourOnes
HourTens
digitkeep

AMinuteOnes
AMinuteTens
AHourOnes
AHourTens
Adigitkeep

ATest
	endc

	cblock 0x70
w_temp
STATUS_temp
	endc

	org 	h'00'

	GOTO 	Start

	org 	h'04'
	
	GOTO	ISR

;-----------------------------------------------------------------------------------
;LOOKUP TABLES
;-----------------------------------------------------------------------------------

LookUpTable:
	ADDWF	PCL,f
	RETLW	b'01110111'	;0
	RETLW	b'01000100' ;1
	RETLW	b'00111110' ;2
	RETLW	b'01101110'	;3
	RETLW	b'01001101'	;4
	RETLW	b'01101011'	;5
	RETLW	b'01111011'	;6
	RETLW	b'01000110'	;7
	RETLW	b'01111111'	;8
	RETLW	b'01001111'	;9
	RETLW	b'01110111' ;0

DigitTable:
	ADDWF	PCL,f
	GOTO	digit1
	GOTO	digit2
	GOTO	digit3
	GOTO	digit4

ADigitTable:
	ADDWF	PCL,f
	GOTO	Adigit1
	GOTO	Adigit2
	GOTO	Adigit3
	GOTO	Adigit4


;-----------------------------------------------------------------------------------
;START
;-----------------------------------------------------------------------------------
Start:
	;Bank 3
	BSF		STATUS,RP1
	BSF		STATUS,RP0
	CLRF	ANSELH
	CLRF	ANSEL

	
	;Bank 1
	BCF		STATUS,RP1
	BSF		STATUS,RP0
	BCF		TRISB,0			
	BSF		TRISA,0			;hours
	BSF		TRISA,1			;minutes tens
	BSF		TRISA,2			;minutes ones
	BSF		TRISA,3			;clock or alarm
	BSF		TRISA,4			;alarm on/off
	BCF		TRISA,5			;alarm
	CLRF	        TRISC			;seven segments
	BCF		TRISB,1			;transistors
	BCF		TRISB,2
	BCF		TRISB,3
	BCF		TRISB,4
	BCF		OPTION_REG,T0CS	;Use internal clock
	BCF		OPTION_REG,PSA	;Use prescaler with TMR0
	BCF		OPTION_REG,PS2	;Set prescaler to 8
	BSF		OPTION_REG,PS1
	BCF		OPTION_REG,PS0	
	
	BSF		OSCCON,IRCF2
	BSF		OSCCON,IRCF1
	BSF		OSCCON,IRCF0
	BSF		OSCCON,SCS	

	;Bank 0
	BCF		STATUS,RP1
	BCF		STATUS,RP0

	MOVLW	h'06'
	MOVWF	TMR0

	MOVLW	d'10'
	MOVWF	ten

	MOVLW	d'100'
	MOVWF	hundred

	MOVLW	d'60'
	MOVWF	Seconds

	MOVLW	d'10'
	MOVWF	MinuteOnes

	MOVLW	d'6'
	MOVWF	MinuteTens

	MOVLW	d'1'
	MOVWF	HourOnes

	MOVLW	d'1'
	MOVWF	HourTens

	MOVLW	d'10'
	MOVWF	AMinuteOnes

	MOVLW	d'6'
	MOVWF	AMinuteTens

	MOVLW	d'1'
	MOVWF	AHourOnes

	MOVLW	d'1'
	MOVWF	AHourTens

	CLRF	        digitkeep
	CLRF	        Adigitkeep
	BCF		PORTB,1
	BCF		PORTB,2
	BCF		PORTB,3
	BCF		PORTB,4

	BSF		INTCON,GIE
	BSF		INTCON,T0IE
	
	GOTO	MainLoop

;-----------------------------------------------------------------------------------
;MainLoop
;-----------------------------------------------------------------------------------

MainLoop:
	BTFSC	PORTA,4
		CALL	Check_Alarm
	BTFSS	PORTA,4
		BCF		PORTA,5
	BTFSC	PORTA,3
		GOTO	Change_Alarm
	GOTO	Display_Time

;-----------------------------------------------------------------------------------
;Check_Alarm
;-----------------------------------------------------------------------------------
Check_Alarm:
	MOVF	HourTens,w
	SUBWF	AHourTens,w
	BTFSS	STATUS,Z
		RETURN

	MOVF	HourOnes,w
	SUBWF	AHourOnes,w
	BTFSS	STATUS,Z
		RETURN
	
	MOVF	MinuteTens,w
	SUBWF	AMinuteTens,w
	BTFSS	STATUS,Z
		RETURN

	MOVF	MinuteOnes,w
	SUBWF	AMinuteOnes,w
	BTFSS	STATUS,Z
		RETURN

	BSF		PORTA,5

;-----------------------------------------------------------------------------------
;Display_Time
;-----------------------------------------------------------------------------------

Display_Time:
	CALL	DisplayTime

	BTFSS	PORTA,2
		GOTO $+7
	BTFSC	PORTA,2
		GOTO $-1
	DECFSZ	MinuteOnes
		GOTO	$+3
	MOVLW	d'10'
	MOVWF	MinuteOnes

	CALL	DisplayTime

	BTFSS	PORTA,1
		GOTO $+7
	BTFSC	PORTA,1
		GOTO $-1
	DECFSZ	MinuteTens
		GOTO	$+3
	MOVLW	d'6'
	MOVWF	MinuteTens

	CALL	DisplayTime

	BTFSS	PORTA,0
		GOTO $+11
	BTFSC	PORTA,0
		GOTO $-1
	BTFSS	HourTens,0
		GOTO	$+7
	DECFSZ	HourOnes
		GOTO	$+4
	MOVLW	d'9'
	MOVWF	HourOnes
	CLRF 	HourTens
	GOTO	MainLoop
	DECFSZ	HourOnes
		GOTO	$+5
	MOVLW	d'3'
	MOVWF	HourOnes
	MOVLW	d'1'
	MOVWF	HourTens

	CALL	DisplayTime

	GOTO	MainLoop

;DisplayTime
;-----------------------------------------------------------------------------------
DisplayTime:
	MOVF	digitkeep,w	
	GOTO	DigitTable

DisplayNow:

	BTFSS	PORTB,0
		GOTO $-1
	BCF		PORTB,0	
	INCF	digitkeep
	MOVF	digitkeep,w
	BCF		STATUS,C
	ADDLW	b'11111100'
	BTFSC	STATUS,C
		CLRF	digitkeep
	RETURN

;Display Tables
;-----------------------------------------------------------------------------------
;Selects the digit using the DigitTable
;Goes to appropriate digit subroutine and executes the commands and access the
;lookup tables at the end of the program to send the proper hex configuration back to
;the display time subroutine

digit1:
	BCF		PORTB,2
	BCF		PORTB,3
	BCF		PORTB,4
	MOVF	MinuteOnes,w
	SUBLW	d'10'
	CALL	LookUpTable
	MOVWF	PORTC
	BSF		PORTB,1
	GOTO	DisplayNow

digit2:
	BCF		PORTB,1
	BCF		PORTB,3
	BCF		PORTB,4
	MOVF	MinuteTens,w
	SUBLW	d'6'
	CALL	LookUpTable
	MOVWF	PORTC
	BSF		PORTB,2
	GOTO	DisplayNow

digit3:
	BCF		PORTB,1
	BCF		PORTB,2
	BCF		PORTB,4
	MOVF	HourOnes,w
	BTFSC	HourTens,0		; Skip if HourTens = 0
		GOTO	$+6			; Go six lines down in code from here

	SUBLW	d'10'
	CALL	LookUpTable
	MOVWF	PORTC
	BSF		PORTB,3
	GOTO	DisplayNow

	SUBLW	d'3'
	CALL	LookUpTable
	MOVWF	PORTC
	BSF		PORTB,3
	GOTO	DisplayNow

digit4:
	BCF		PORTB,1
	BCF		PORTB,2
	BCF		PORTB,3
	MOVF	HourTens,w
	BTFSS	HourTens,0		; Skip if HourTens is 1
		GOTO	$+4
	CALL	LookUpTable
	MOVWF	PORTC
	BSF		PORTB,4
	GOTO	DisplayNow


;-----------------------------------------------------------------------------------
;ISR
;-----------------------------------------------------------------------------------

ISR:
	MOVWF	w_temp
	SWAPF	STATUS,W
	MOVWF	STATUS_temp

	BTFSC	INTCON,T0IF
	CALL	Time

	SWAPF	STATUS_temp,W
	MOVWF	STATUS
	SWAPF	w_temp,F
	SWAPF	w_temp,W

	RETFIE

;TIMER
;-----------------------------------------------------------------------------------

Time:
	BCF		INTCON,T0IF
	MOVLW	h'06'
	MOVWF	TMR0
;1 uS
	BSF		PORTB,0
	DECFSZ	ten
		RETURN

;10 uS
	BSF		PORTE,0
	MOVLW	d'10'
	MOVWF	ten
	DECFSZ	hundred
		RETURN

;1 S
	MOVLW	d'100'
	MOVWF	hundred
	DECFSZ	Seconds
		RETURN

;60 S ~ 1 M
	MOVLW	d'60'
	MOVWF	Seconds
	DECFSZ	MinuteOnes
		RETURN

;600 S ~ 10 M
	MOVLW	d'10'
	MOVWF	MinuteOnes
	DECFSZ	MinuteTens
		RETURN

;3600 S ~ 60 M ~ 1 H
	MOVLW	d'6'
	MOVWF	MinuteTens
	DECFSZ	HourOnes
		RETURN

	BTFSS	HourTens,0		; Skip if HourTens = 0
		GOTO	$+5			; Go six lines down in code from here

	MOVLW	d'9'
	MOVWF	HourOnes
	CLRF 	HourTens
		RETURN

	MOVLW	d'3'
	MOVWF	HourOnes
	MOVLW	d'1'
	MOVWF	HourTens
		RETURN


;-----------------------------------------------------------------------------------
;Change_Alarm
;-----------------------------------------------------------------------------------
Change_Alarm:
	CALL	ADisplayTime

	BTFSS	PORTA,2
		GOTO $+7
	BTFSC	PORTA,2
		GOTO $-1
	DECFSZ	AMinuteOnes
		GOTO	$+3
	MOVLW	d'10'
	MOVWF	AMinuteOnes

	CALL	ADisplayTime

	BTFSS	PORTA,1
		GOTO $+7
	BTFSC	PORTA,1
		GOTO $-1
	DECFSZ	AMinuteTens
		GOTO	$+3
	MOVLW	d'6'
	MOVWF	AMinuteTens

	CALL	ADisplayTime

	BTFSS	PORTA,0
		GOTO $+11
	BTFSC	PORTA,0
		GOTO $-1
	BTFSS	AHourTens,0
		GOTO	$+7
	DECFSZ	AHourOnes
		GOTO	$+4
	MOVLW	d'9'
	MOVWF	AHourOnes
	CLRF 	AHourTens
	GOTO	MainLoop
	DECFSZ	AHourOnes
		GOTO	$+5
	MOVLW	d'3'
	MOVWF	AHourOnes
	MOVLW	d'1'
	MOVWF	AHourTens

	CALL	ADisplayTime

	GOTO	MainLoop

;DisplayTime
;-----------------------------------------------------------------------------------
ADisplayTime:
	MOVF	Adigitkeep,w	
	GOTO	ADigitTable

ADisplayNow:

	BTFSS	PORTB,0
		GOTO $-1
	BCF		PORTB,0	
	INCF	Adigitkeep
	MOVF	Adigitkeep,w
	BCF		STATUS,C
	ADDLW	b'11111100'
	BTFSC	STATUS,C
		CLRF	Adigitkeep
	RETURN

;Display Tables
;-----------------------------------------------------------------------------------
;Selects the digit using the DigitTable
;Goes to appropriate digit subroutine and executes the commands and access the
;lookup tables at the end of the program to send the proper hex configuration back to
;the display time subroutine

Adigit1:
	BCF		PORTB,2
	BCF		PORTB,3
	BCF		PORTB,4
	MOVF	AMinuteOnes,w
	SUBLW	d'10'
	CALL	LookUpTable
	MOVWF	PORTC
	BSF		PORTB,1
	GOTO	ADisplayNow

Adigit2:
	BCF		PORTB,1
	BCF		PORTB,3
	BCF		PORTB,4
	MOVF	AMinuteTens,w
	SUBLW	d'6'
	CALL	LookUpTable
	MOVWF	PORTC
	BSF		PORTB,2
	GOTO	ADisplayNow

Adigit3:
	BCF		PORTB,1
	BCF		PORTB,2
	BCF		PORTB,4
	MOVF	AHourOnes,w
	BTFSC	AHourTens,0		; Skip if HourTens = 0
		GOTO	$+6			; Go six lines down in code from here

	SUBLW	d'10'
	CALL	LookUpTable
	MOVWF	PORTC
	BSF		PORTB,3
	GOTO	ADisplayNow

	SUBLW	d'3'
	CALL	LookUpTable
	MOVWF	PORTC
	BSF		PORTB,3
	GOTO	ADisplayNow

Adigit4:
	BCF		PORTB,1
	BCF		PORTB,2
	BCF		PORTB,3
	MOVF	AHourTens,w
	BTFSS	AHourTens,0		; Skip if HourTens is 1
		GOTO	$+4
	CALL	LookUpTable
	MOVWF	PORTC
	BSF		PORTB,4
	GOTO	ADisplayNow


	

	END
Back to top
Bjørn
Wed Jan 05 2011, 09:20AM
Bjørn Registered Member #27 Joined: Fri Feb 03 2006, 02:20AM
Location: Hyperborea
Posts: 2058
A nice little project, I would be interested to look at the source code. If you scroll down to the bottom of the page you will find the license that everything we post is bound by. If you are not happy to post your code under that license you can send it to me in a PM.
Back to top
Ken M.
Wed Jan 05 2011, 05:51PM
Ken M. Registered Member #618 Joined: Sat Mar 31 2007, 04:15AM
Location: Us-Great Lakes
Posts: 628
I could be wrong but it looks like he already has posted the source code.
Back to top
wpk5008
Wed Jan 05 2011, 05:53PM
wpk5008 Registered Member #3546 Joined: Tue Dec 28 2010, 08:24AM
Location: Pittsburgh, PA
Posts: 18
Bjorn, I have updated the thread with my code. It seems that when it posted, the forum removed all of my tabs? Is there a way to fix that as the tabbing really made the code more readable? Also looking through the code some random spaces were added into the code that would definitely break the code if you were to try to compile the code right off the forum? I could understand the forum removing the tabs, but I am perplexed by the spacing...

I guess for now if anybody wants to try to replicate this and wants my code I can email it to you. I won't make anybody find every space or add the proper tabbing. Ironically before my computer crashed a couple months ago I had written a program that would take code that was 'tabbed' very well and it would add the tabs where I thought they were needed. It was unfortunately lost and my C++ skills are lacking at this time to duplicate it...
Back to top
Andyman
Wed Jan 05 2011, 08:23PM
Andyman Registered Member #1083 Joined: Mon Oct 29 2007, 06:16PM
Location: Upland, California
Posts: 256
You could always use pastebin, I use that all the time.
Back to top
Bjørn
Fri Jan 07 2011, 07:14AM
Bjørn Registered Member #27 Joined: Fri Feb 03 2006, 02:20AM
Location: Hyperborea
Posts: 2058
I added the code tag to your code and it improved the appearance but in general the forum is hopeless at preserving formatting.

You need to check your ISR function, it is not doing what you think and it may cause your code to fail when you least expect it.
Back to top
wpk5008
Fri Jan 07 2011, 11:33PM
wpk5008 Registered Member #3546 Joined: Tue Dec 28 2010, 08:24AM
Location: Pittsburgh, PA
Posts: 18
Bjorn- I would have to agree with you. But what is sad is that is the portion of code that my class got from a Microchip datasheet and my professor taught as being correct. I had always assumed since microchip published it that it must work properly, but just looking at it I have to agree with you.

ISR:
MOVWF w_temp
SWAPF STATUS_temp,w
MOVWF STATUS_temp

BTFSC INTCON,T0IF
CALL Time

SWAPF STATUS_temp,w
MOVF STATUS
SWAPF w_temp,F
SWAPF w_temp,w

RETFIE


The first two MOVF's were just moving whatever register they were attached to back into themselves I think. The rest looks fine to me now. Does that look appropriate to you?
Back to top
Bjørn
Sat Jan 08 2011, 03:40AM
Bjørn Registered Member #27 Joined: Fri Feb 03 2006, 02:20AM
Location: Hyperborea
Posts: 2058
The original MOVF w_temp was not only moving the register back to itself but it was also corrupting the zero flag.

ISR:
MOVWF w_temp
SWAPF STATUS,W (changed w to upper case to make sure a case sensitive assembler does not trip you up)
MOVWF STATUS_temp
- At this point we should have safely stored the internal state of the CPU.

BTFSC INTCON,T0IF
CALL Time

SWAPF STATUS_temp,W
MOVWF STATUS
SWAPF w_temp,F
SWAPF w_temp,W
- At this point the status should have been restored again

RETFIE

The point of using SWAPF instead of MOVF is that it does not alter the status flags, that makes the code a bit more confusing.

There is one more potential problem, if the temporary storage locations are moved to a bank where they can't be reached you will overwrite the wrong registers. So you should add a comment at "cblock 0x70" to remind yourself that those variables must never be moved to a location that is not mirrored in all banks without updating the ISR code.
Back to top
wpk5008
Sat Jan 08 2011, 09:34AM
wpk5008 Registered Member #3546 Joined: Tue Dec 28 2010, 08:24AM
Location: Pittsburgh, PA
Posts: 18
Two more good catches, I'm glad to have such a good programmer looking over my shoulder. When I find the sheet that provided this ISR I'll post it.

Yeah I realized what the intention of the swap was when I was looking over this before. Honestly I feel so dumb for not catching that second set of errors.

The nice thing about the pic16f8xx series is that it has global memory starting at 0x70, which is why I always put my ISR backups in that spot. Probably a good comment to add though, I'm not always the best with comments because I have my own set of rules I follow when I program, but somebody looking at my code wouldn't know them...

I will also keep your comment about the lowercase w's in mind. My compiler is not case sensitive but for whatever reason I just got into the habit of typing all commands in caps, and all registers in lowercase, it looking at my code is seems for destinations I always capitalized my F's and my w's are lower case. What is the standard amongst other compilers? I have only ever used MPLAB IDE; caps for commands and destinations and lower case for registers?

I'm really glad you looked over my code Bjorn. I have been having some issues with unexpected happens in a lot of my code lately. But because I got my ISR from a datasheet I probably never would have bother to check it, but I feel like this might have been the culprit. Thank you.

I will also edit my first post...
Back to top
Bjørn
Tue Jan 11 2011, 01:26PM
Bjørn Registered Member #27 Joined: Fri Feb 03 2006, 02:20AM
Location: Hyperborea
Posts: 2058
What is the standard amongst other compilers? I have only ever used MPLAB IDE; caps for commands and destinations and lower case for registers?
All their examples seems to be in upper case but that seems very old fashioned. I have had problems with some version of MPASM that generated the wrong code when using a lower case w.
Back to top
1 2 

Moderator(s): Chris Russell, Noelle, Alex, Tesladownunder, Dave Marshall, Dave Billington, Bjørn, Steve Conner, Wolfram, Kizmo, Mads Barnkob

Go to:

Powered by e107 Forum System
 
Legal Information
This site is powered by e107, which is released under the GNU GPL License. All work on this site, except where otherwise noted, is licensed under a Creative Commons Attribution-ShareAlike 2.5 License. By submitting any information to this site, you agree that anything submitted will be so licensed. Please read our Disclaimer and Policies page for information on your rights and responsibilities regarding this site.