NEW: Learning electronics? Ask your questions on the new Electronics Questions & Answers site hosted by CircuitLab.
Support Forum » PORTB NOT RESPONDING CORRECTLY
November 27, 2009 by gnkarn |
HI, I am experimenting with a led array, in my configuration 6 leds are managed by portC and the two msb are managed by port B pins 3 and 4. I run the program using the simulation environment in AVR studio, and it works perfectly, when I run the program from the micro, the port C leds works fine, but the port B leds stays on all the time. More strange is that , I added an initialization code segment to test all leds, and it works perfect, but after this, leds 6 and 7 stays on all time. Any possible incompatibility with PORTB and the serial communication routines include in the library?, any library function "included" that makes abuse of portB ? thanks |
---|---|
November 27, 2009 by pbfy0 |
You could try setting PORTB to 0:
at the beginning of your code, which would turn all off. |
November 27, 2009 by gnkarn |
During The initial phase I blink all LEDs and works perfect , what puzzles me is that after this portb changes it's behaviour also consider that under simulation the code works fine thanks |
November 27, 2009 by gnkarn |
PROBLEM SOLVED, just for the record in case it may be of help This is my problem analysis: as im using a 74ls374 to "latch" the port outputs , because my next step is to multiplex several 8 bits outputs, and I am using PORTB pins as data pins 3,4, and also to control (pins 0,1,2) ; in my code I was at the same writing the data to port B, and triggering the control lines to latch the data. My assumption is that there is a timing issue involved here, this must be two separate code lines in order to allow for proper edge triggering, so once I changed my code in order to perform this two tasks in separate lines instead of doing all on the same code line, it start working right. This also explains why I wasn't able to see the problem in the simulator, because in the simulator you can see the PORT status, but not the actual "latch status". Gustavo |
November 28, 2009 by NK_EK |
Hi, I have a similar problem on pins PB2 & PB3. For some reason when I switch PB2 high (PORTB |= (1<<PB2);) PB3 ALSO goes high, even though I specifically set it low (PORTB &= ~(1<<PB3);). PB2 is set as OUTPUT (DDRB |= (1<<PB2);) and I've even tried to switch PB3 to input, but no luck. All the other pins seem OK. I will try and test if I can read input from these two pins & report back. Thanks in advance. Ernest |
November 28, 2009 by NK_EK |
Now I'm pretty I screwed something up somewhere. The pins do not get input AT ALL! They work fine as 1 output pin, but no longer as input. Any help will really be appreciated. |
November 28, 2009 by NK_EK |
PRETTY SURE that should be... |
November 28, 2009 by gnkarn |
For some reason I have to install "pull down" resistors on the PORTB pins , for it to work properly... It should be a good logical explanation for this ... |
November 28, 2009 by NK_EK |
Is there a way to completely reset the MCU (168) - all the pins, registers? I don't quite understand the datasheet. It speaks of a RESET by setting the RESET pin (pin 1) low for more than a clock cycle. Do I remove the +5V from pin 1 & restart the MCU? I'm trying to undo any recoverable mistakes that I may have made. |
November 30, 2009 by hevans (NerdKits Staff) |
Hi NK_EK, The surest way to reset the chip is to disconnect the power, and plug it in again. You can also use the RESET pin (pin 1). Our instructions have you put a wire from pin 1 straight to +5, this will keep this pin high and keep you from resetting your chip. If you want, you can set up a pull up resistor from the pin to +5 instead of the wire. Then you can take another wire and quickly ground pin 1 when you wish to reset the chip (For a more elegant setup, you can hook up a switch). Every time you reset the chip everything in RAM is cleared (or at least no longer valid), registers are reset, and your program starts again from the main() function. Anything in Flash or EEPROM will be unaffected. Let us know if you have any other questions. Humberto |
November 30, 2009 by NK_EK |
Humberto, Thanks for the reply. I tried that, but the two ports (PB2 & PB3) seems to be shorted internal to MCU. As I described before, there seems to be a "bleed" between the two - when I connect two LED's and blink them alternately, the one on PB3 stays dimly lit (it does flash, but never goes completely dead). I can also not read input from these two pins. I removed the MCU from the breadboard and put it into a spare breadboard - same result. I took a spare MCU and loaded the exact program on that one, and it's working fine. So it seems to me that in my experimenting I've managed to damage the chip although it's not completely ruined. I'll continue to use it for experimenting and keep the other 168 for my LED Marquee. Again, thanks to everyone for the help. Ernest |
December 01, 2009 by hevans (NerdKits Staff) |
Hi NK_EK, How are you "turning off" the pins? Remember that these are digital outputs, that means that a logic low does not necessarily have to be 0V. To turn the LED completely off. To make sure the LED goes completely off try turning the pin into an input pin temporarily (and turn off the pullup resistor). That will make sure no current flows through the pin, and will hopefully turn your pin completely off. It is possible you fried that bank of pins. But it doesn't hurt to check to make sure. Humberto |
December 02, 2009 by NK_EK |
Humberto, Again, thanks for the reply. You can look at the main() function that I use here: pastebin. Sorry for the lack of comments - I just slapped this together to test. I took a video and uploaded it here: YouSendIt. Thanks for your help so far. Ernest |
December 02, 2009 by NK_EK |
BTW, the same thing happens the other way round - if I just blink PB2 (commented in the above code) with PB3 supposedly 'off'. |
December 03, 2009 by pbfy0 |
I think you have PB2 and PB3 set as input. replacing line three with this:
should fix your problem (I think) note: if it says <, that means a less than |
December 03, 2009 by hevans (NerdKits Staff) |
Hi NK_EK, It looks like you did manage to short the pins internally. There is pretty much nothing else that could explain what you are seeing. Humberto |
December 05, 2009 by NK_EK |
Humberto, Thanks for the help (again). Yep, I sure did something silly somewhere - just wish I knew where so that I don't repeat it :-). Luckily the other pins work fine, so I can still use the chip for testing/experimenting. Ernest |
December 27, 2009 by BobaMosfet |
Ernest- It would be useful to know what your schematic is-- are you using an AVRisp MkII or your programming, or something else? In other words, is anything else plugged into your PORTB pins? Remember also, that you must use a resistor in series with any LED you use, not only to protect the LED, but also to protect the MCU pin- excessive current (not voltage) is what will kill your device. |
December 28, 2009 by NK_EK |
BobaMosfet, Thanks, but there is nothing else connected to any of the PORTB pins. I thought long and hard about what I could have done wrong, and the only 2 things I could think of was the time I tried to run a small hobby geared motor off the MCU (but I cannot recall which pins I used) or just using the LED's without resistors (maybe even switching the anode & cathode). But as I say, I can't remember exactly what I did, but this I know: I will definitely be more careful in future and make sure that everything is connected as it should be before applying power. Thanks for the help! |
Please log in to post a reply.
Did you know that two resistors can be used to make a voltage divider? Learn more...
|