Generating a square wave with a PIC12F

AI Thread Summary
The discussion focuses on generating a square wave using a PIC12F683 by toggling an I/O pin with a timer interrupt. The original poster is experiencing issues, as the output pin remains at a constant 5 volts instead of producing the expected square wave. Suggestions include rearranging the interrupt enable commands to occur after timer setup and checking the configuration of the pins to ensure they are set for digital I/O. A key solution identified is disabling the comparator functions and analog settings, which resolves the issue of the output pin not toggling. The conversation highlights the importance of proper pin configuration in microcontroller programming.
Marmoteer
Messages
8
Reaction score
0
Hi, using a PIC12F683 I'm attempting to toggle an IO pin every time the internal timer overflows (via the timer interrupt) but I can't seem to get it working. I'm viewing the voltage of the pin on a scope, expecting a square wave and getting a constant 5 volts. Also I've read the official documentation multiple times and believe my code is correct (I could be way off). I'm also aware that this may not be the best way to generate a square wave. Regardless I'd at least like to realize what I'm doing wrong before I take a different approach.
Anyhow, here's the source, it was assembled with GPASM.

Code:
        PROCESSOR 12F683
        __CONFIG _INTOSCIO & _WDT_OFF & _PWRTE_ON & _BOREN_OFF
        include "P12F683.inc"
       
bank0   MACRO
        bcf STATUS, RP0         ;Clear STATUS[RP0] to switch to bank 0
        endm
bank1   MACRO
        bsf STATUS, RP0         ;Set STATUS[RP0] to switch to bank 1
        endm
         
#define T1CONF  b'00000101'    
#define OUTPINS b'00001000'     ; MCLR pin set to input and rest set to output
#define GP2TOG  b'00000100'     ; XOR mask for toggling GP2 pin
#define DELAY   h'FF'
 
reset_vec code 0x00
        goto main
       
int_svc code 0x04
        goto int_vec
 
        code
main:
        bank1
        movlw OUTPINS
        movwf TRISIO            ; Set I/O on pins
       
        bsf PIE1, TMR1IE        ; Enable the Timer1 overflow interrupt
       
        bank0
        bsf INTCON, PEIE        ; Enable all unmasked peripheral interrupts
        bsf INTCON, GIE         ; Enable all unmasked interrupts
       
        movlw T1CONF            ; Move timer configuration into W reg
        movwf T1CON             ; Configure Timer 1
 
        bcf PIR1, TMR1IF        ; Clear Timer interrupt flag just in case.
       
        clrf GPIO
       
idle:
        goto idle
       
int_vec:
        btfss PIR1, TMR1IF      ; Is this interrupt from the Timer?
        goto retf_vec           ; If not timer int, return
        movlw GP2TOG            ; Load GP2 xor mask
        xorwf GPIO, 1           ; Toggle GP2 bit and store result in GPIO
        bcf PIR1, TMR1IF        ; Clear interrupt
retf_vec:
        retfie                  ; return from interrupt
        end

GPASM - http://ww1.microchip.com/downloads/en/devicedoc/41211d_.pdf

Instruction set reference - http://www.dcc.unicamp.br/~celio/mc404/pic/pic_instructionset_summary.html

Official Datasheet - http://ww1.microchip.com/downloads/en/devicedoc/41211d_.pdf

Important pages:
Pin Diagram - 2
Pin IO - 31
Timer Interrupt - 46
Interrupt Registers - 13, 14, 15

Thanks in advance.
 
Engineering news on Phys.org
Your code looks reasonable, although that is no guarantee of correctness since I only do a little PICASM here and there. Just in case, I would move the INT enables to _after_ the timer setup -- just before your infinite loop.

You can check your startup and logic by putting the XOR in the idle loop to see if you actually get anything on the output pin. Do you have RESET pulled up? Maybe it's never getting started...
 
Man I'm dumb. The problem was just that the pins weren't set for regular IO. Should have read more closely, to fix it this is all that has to be added
Code:
bank0
movlw b'00000111' ; Disables comparator functions
movwf CMCON0 

bank1
clrf ANSEL ; Disables analog stuff

This can be found in the GPIO seciton.
 
Very basic question. Consider a 3-terminal device with terminals say A,B,C. Kirchhoff Current Law (KCL) and Kirchhoff Voltage Law (KVL) establish two relationships between the 3 currents entering the terminals and the 3 terminal's voltage pairs respectively. So we have 2 equations in 6 unknowns. To proceed further we need two more (independent) equations in order to solve the circuit the 3-terminal device is connected to (basically one treats such a device as an unbalanced two-port...
suppose you have two capacitors with a 0.1 Farad value and 12 VDC rating. label these as A and B. label the terminals of each as 1 and 2. you also have a voltmeter with a 40 volt linear range for DC. you also have a 9 volt DC power supply fed by mains. you charge each capacitor to 9 volts with terminal 1 being - (negative) and terminal 2 being + (positive). you connect the voltmeter to terminal A2 and to terminal B1. does it read any voltage? can - of one capacitor discharge + of the...
Thread 'Weird near-field phenomenon I get in my EM simulation'
I recently made a basic simulation of wire antennas and I am not sure if the near field in my simulation is modeled correctly. One of the things that worry me is the fact that sometimes I see in my simulation "movements" in the near field that seems to be faster than the speed of wave propagation I defined (the speed of light in the simulation). Specifically I see "nodes" of low amplitude in the E field that are quickly "emitted" from the antenna and then slow down as they approach the far...

Similar threads

Replies
2
Views
2K
Replies
3
Views
2K
Replies
2
Views
6K
Replies
3
Views
3K
Replies
2
Views
7K
Back
Top