: You have a huge noise there, try to see why. Almost 2Vpp of noise is a : real mess. : It's possible that sometime the PWM dutycycle be longer that PWM period? : Only then the CCP output remains high. Maybe a compiler problem ? I should have been clearer about the part of the CCP module that I was using. I'm using the "compare" rather than the "pwm" part. I don't think that it is a compiler problem as the effect is random and nothing else appears to be affected. I can't see it just jumping off somewhere else in the program and not having an effect on either the Timer 1 or the CCPR1 register. I need to look more carefully at the noise on the 5 V section of the daugther board. It is buried in the transmitter box and a PIA to get at. Because the ADCs are noise free, my assumption was that it was fairly noise free. How much noise on the power lines is acceptable? If the noisy supply voltage stays between 2.0 and 5.5 volts, is that OK? Or does the noise component need to be kept below some value p-p? Regards, Gordon Williams : On 5/12/08, Gordon Williams wrote: : > Hi All, : > : > I'm having problems tracking down the reason of some glitches occurring on : > the CCP1 output and it is driving me a bit crazy. : > : > I'm putting some smarts into a basic RC transmitter. I've replaced the : > current chip producing the pulse train to the RF section with a daughter : > board and added a cell phone LCD, some switches and Serial port for input : > and output. The serial port and LCD (spi) work fine and they don't have any : > glitches. The 5 ADC readings for the joysticks (4) and battery voltage also : > work well with only 1 bit of noise on a 10 bit reading (referenced to the : > power and gnd lines). : > : > The PIC that I am using is the 16F886. Its supply is a 78L05 on the main : > board and I have a 10uf Tant and three 0.1uF on the power lines on the : > daughter board. The daughter board is single sided with a ground plane pour : > under the PIC and every else where I could. Because I don't have ADC : > problems or serial or spi errors that noise must be reasonably constrained, : > I think. : > : > I'm using CCP1 (pin C2) to produce the PPM that goes to the RF section. It : > is the standard PPM protocol (each channel pulse is 1 to 2 ms wide including : > the following 0.3 ms pulse, repeated every 20ms). : > : > Timer1 runs freely. With a CCP1 interrupt (my only interrupt) I update : > CCPR1 with the duration until the next transition high or low and the : > CCP1CON bits to set the next transition in the correct direction. My main : > program clears a flag and that is all. : > : > Most of the time it works perfectly and looks like: : > http://www.cyberus.ca/~g_will/TxGlitch/NoGlitch1.jpg : > : > or detail : > : > http://www.cyberus.ca/~g_will/TxGlitch/NoGlitch.jpg : > : > The receiver pulses for the first 4 channes are shown in the logic section : > below. : > : > Every 20 to 100 frames on average (sometimes they are consectutive frames) I : > get a glitch: : > : > http://www.cyberus.ca/~g_will/TxGlitch/Glitch1.jpg : > : > or : > : > http://www.cyberus.ca/~g_will/TxGlitch/Glitch2.jpg : > : > The green lines indicate where the signal should have been. : > : > There is a fair bit of noise - about 1.8 volts p-p because the scope ground : > was attached to the battery neg lead. I don't think that my probes are very : > well shielded either. The noise is from the 72 Mhz RF. : > : > In each case the low output flips high. My question is WHY? : > : > Timer 1 keeps on rolling as there is no problem with frame spacing or the : > width or placement of the next good pulse. : > : > CCPR1 is not upset or incorrectly set for the same reasons - because the : > next good pulse is in the proper location relative to the last good pulse. : > : > The serial and LCD have been comment out. I'm reading 2 ADC on port A and : > 3ADC on port B. All other pins on ports A,B,C are inputs and some are : > floating (could this be a problem?) : > : > Is there anything else on the chip that may be miss-configured that may be : > giving me a problem? : > : > The chip docs say: : > Note: Clearing the CCP1CON register will force : > the CCPx compare output latch to the : > default low level. This is not the PORT I/O : > data latch. : > : > But I don't think that this applies to me. The only time that I do anything : > with the CCP1CON is during the long bit in the frame between the pulse : > series and the glitch doesn't always happen there. : > : > It is not read-mod-write ... I'm not writing anything to the port. : > : > I read the errata - nothing there indicated a problem. : > : > Any ideas what I should be looking at/ trying next?? : > : > - I guess I should look at the 5 v power going to the chip to see that it is : > truly quiet and doesn't have a spike. Brown out is disabled. : > : > - Should set the un-used outputs to either high or low. - Good right? : > : > Funny that it is only affecting one pin that I can see. : > : > Looking for suggestions... : > : > Regards, : > : > Gordon Williams : > : > -- : > http://www.piclist.com PIC/SX FAQ & list archive : > View/change your membership options at : > http://mailman.mit.edu/mailman/listinfo/piclist : > : -- : http://www.piclist.com PIC/SX FAQ & list archive : View/change your membership options at : http://mailman.mit.edu/mailman/listinfo/piclist : -- http://www.piclist.com PIC/SX FAQ & list archive View/change your membership options at http://mailman.mit.edu/mailman/listinfo/piclist