Shop OBEX P1 Docs P2 Docs Learn Events
5V input to Prop pin question — Parallax Forums

5V input to Prop pin question

T ChapT Chap Posts: 4,223
edited 2014-08-27 16:33 in Propeller 1
I remember back in the very early days some discussion about using a 1k for 5V inputs to Prop(could have been mistaken), and built many systems that use 5V though a 1k to the Prop pin and have never had a failure. Typically these are normally open, momentary closure for under 1 sec. In some cases the contacts are normally closed, with brief opens for triggers. I have one project that I cannot go visit that is stating that one of the systems using a card reader with normally closed contacts and a 5 second open time is acting strange, it sometimes takes several attempts at the card to work, there is no pattern. I tested this with a short jumper wire and it works fine on my bench systems, so I am wondering if the steady 5v though the newer value of 1.2k over prolonged periods is causing some temporary strangeness. I don't think this is software. The input has a 220k to GND right at the pin so it cannot float.

Over more recent years I see recommendations of 3k etc. In prior experiences, you either kill the input or you don't, there is never a random state. Any thoughts on the resistance causing sporadic failures? I cannot control their 5 second delay time, and this is the only other potential culprit but I cannot see how it would affect anything.
PUB PushbuttonsState2(inputpin)    | selectinput
    Case inputpin   
         auxin1  :  CurrentSwState2[0] := ina[2] 
                    selectinput := 0
         auxin2  :  CurrentSwState2[1] := ina[5] 
                    selectinput := 1 
         auxin3  :  CurrentSwState2[2] := ina[6]
                    selectinput := 2 
         auxin4  :  CurrentSwState2[3] := ina[23]
                    selectinput := 3
    If CurrentSwState2[selectinput] <> PrevSWState2[selectinput]    'byte arrays  used here
      if ina[inputpin] == 0   
         Open
         delayCounter~ 
         GoZeroClear
         ser.str(3, String("Open"))
         w(40_000_000)    'waitcnt shortcut

    PrevSWState2[selectinput] := CurrentSwState2[selectinput] 

Comments

  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2014-08-25 16:31
    T Chap wrote: »
    I remember back in the very early days some discussion about using a 1k for 5V inputs to Prop(could have been mistaken), and built many systems that use 5V though a 1k to the Prop pin and have never had a failure. Typically these are normally open, momentary closure for under 1 sec. In some cases the contacts are normally closed, with brief opens for triggers. I have one project that I cannot go visit that is stating that one of the systems using a card reader with normally closed contacts and a 5 second open time is acting strange, it sometimes takes several attempts at the card to work, there is no pattern. I tested this with a short jumper wire and it works fine on my bench systems, so I am wondering if the steady 5v though the newer value of 1.2k over prolonged periods is causing some temporary strangeness. I don't think this is software. The input has a 220k to GND right at the pin so it cannot float.

    Over more recent years I see recommendations of 3k etc. In prior experiences, you either kill the input or you don't, there is never a random state. Any thoughts on the resistance causing sporadic failures? I cannot control their 5 second delay time, and this is the only other potential culprit but I cannot see how it would affect anything.

    I don't know why these resistors values are so low as if CMOS inputs require current. I typically use 10K values or even 100K and only ever use lower values if the signals are high speed (>1MHz) due to of course the combined capacitance of the input. A value of 1K results in almost 1.5ma flowing through the pin up into the 3.3V supply which can force that up especially during reset. I think the 3.3K value mentioned is the *minimum*, not the required value at all. I have seen Props not booting due to the elevated Vdd observable during reset.
  • kwinnkwinn Posts: 8,697
    edited 2014-08-25 16:55
    @T Chap

    One of the things I have learned in over 40 years of service is to fix any problem I find regardless of how minor or unrelated it may seem to be to the problem I was called in to fix. It's amazing how often fixing that seemingly minor unrelated problem solved the issue. Try using a 3.3K or higher resistor and replace the prop chip.
  • Chris SavageChris Savage Parallax Engineering Posts: 14,406
    edited 2014-08-25 17:06
    Try this article. Under series resistor I tried to explain the details of why the 3.9K resistor is used on the Propeller.
  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2014-08-25 17:58
    Try this article. Under series resistor I tried to explain the details of why the 3.9K resistor is used on the Propeller.

    Hi Chris, I notice in the article that when you address current limit you only give the "safe" limit for resistors but not any guidelines for a practical value. The trouble is as I have noted from my circuits (burn and learn) is that when you have multiple 5V inputs current limited then these very signals can contribute to misoperation of the Prop, especially when it's not drawing a lot of current then the 3.3 rail just gets pushed up to 4V or more (as regulators can't actually pull a line down). The problem is exacerbated during reset and it seems to play havoc with it as the Prop does not respond reliable of at all.

    Please put in a recommended operating value, as I said there is no reason why these values can't be much much higher and in most normal circumstances 100K is fine, or at least 10K. But 3.3K should be quoted as "ABSOLUTE MINIMUM" perhaps, as in do not normally do this unless you know what you are doing type thing.

    @kwinn: Yes, I will ditto that in bold, when you ignore the little problems in pursuit of the big problems you almost invariably discover the little problem is causing the big problem.
  • edited 2014-08-25 23:28
    The attached application note from the old Parallax Semiconductor site indicates that 4.7k is an appropriate value for a series, current limiting resistor.

    I've used 4.7k resistors on some MCP3201s that I'm clocking at 400 kHz. Works well.

    Sandy
  • LoopyBytelooseLoopyByteloose Posts: 12,537
    edited 2014-08-26 01:03
    I followed the rather lengthy and elaborate debate about the right resistor level and thought that it all settled at 3.1K being the minimum acceptable to not abuse the i/o.

    Somehow that has morphed into 3.9K being the standard policy value.

    Since many of the assumptions for these were made with a a full continuous ON state, I suppose the the 1K value will work well if there is a duty cycle of 50% or less. But it is rather silly to go with the smallest value and waste power when a higher value will both conserve power and work fine.

    Too high a value might not provide enough stability if the i/o is over longer wires or subject to RFI interferences. So I suspect that anything above 5K begins to ask for other problems to creep in... depending upon construction.
  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2014-08-26 05:38
    I followed the rather lengthy and elaborate debate about the right resistor level and thought that it all settled at 3.1K being the minimum acceptable to not abuse the i/o.

    Somehow that has morphed into 3.9K being the standard policy value.

    Since many of the assumptions for these were made with a a full continuous ON state, I suppose the the 1K value will work well if there is a duty cycle of 50% or less. But it is rather silly to go with the smallest value and waste power when a higher value with both conserve power and work fine.

    Too high a value might not provide enough stability if the i/o is over longer wires or subject to RFI interferences. So I suspect that anything about 5K begins to ask for other problems to creep in... depending upon construction.

    Loopy, you know your maths right? Why then do you make statements about too high a value might not provide stability? The Propeller chip is constructed using CMOS technology which we are familiar with. Unlike TTL which required more sinking current and had limited fan-out, we know that the limitation with CMOS has eventually to do with capacitance which affects speed. The input capacitance of a CMOS input is a maximum of 10pF, the input resistance is in the order of 100s of megaohms although they will always quote a "leakage" value of 1ua max. So we feed a "100s of megaohm" input with say a whopping (in our minds) 1M resistor. What's that going to do? Will it lack drive? Will it have enough "current"? Those questions are not relevant because of the technology and really only the capacitance is factored in with a time constant of 1M * 10pf * 0.68 = 6.8us so even at this level there is definitely no problem reading switches and 9600 baud data etc. In fact this time constant makes the Prop more resilient to RFI and stray voltages anyway plus we would normally have a pulldown or pullup resistor before the current limit as well which lowers the input impedance. If you do the maths then theoretically the input could withstand 500V although the resistors etc would have to be rated for that!

    So you see a higher value resistor has everything going for it and the only time I need something as low as 10K is when I am dealing with > 1MHz signals and even then I'm still on the safe side.
  • ManAtWorkManAtWork Posts: 2,178
    edited 2014-08-26 07:36
    ... with a time constant of 1M * 10pf * 0.68 = 6.8us so even at this level there is definitely no problem reading switches and 9600 baud data etc. In fact this time constant makes the Prop more resilient to RFI and stray voltages anyway...

    No. Slower rise/fall times mean the input voltage stays longer in the "forbidden zone" near the threshold and oscillations may occur if you don't add a schmitt trigger circuit. I had that problem when I increased the series resistors for my 5V-tolerant inputs for step and charge pump inputs of a stepper motor driver. I had to add software debouncing to avoid false step pulse triggering. With a 1.2k resistor only, everything worked fine.
  • Chris SavageChris Savage Parallax Engineering Posts: 14,406
    edited 2014-08-26 08:19
    Hi Chris, I notice in the article that when you address current limit you only give the "safe" limit for resistors but not any guidelines for a practical value. The trouble is as I have noted from my circuits (burn and learn) is that when you have multiple 5V inputs current limited then these very signals can contribute to misoperation of the Prop, especially when it's not drawing a lot of current then the 3.3 rail just gets pushed up to 4V or more (as regulators can't actually pull a line down). The problem is exacerbated during reset and it seems to play havoc with it as the Prop does not respond reliable of at all.

    Peter,

    The relevant section is listed below. I used the ratings Chip Gracey gave me for the diodes to calculate the absolute minimum, then specify some allowance for tolerance and use the next highest common resistor value. Is the absolute minimum not what you were looking for?
    The Propeller chip does include protection, however the clamping diodes are rated at ±500 µA. These diodes also have a forward voltage drop of 0.4V. This means the diodes will conduct at 3.7V. To ensure the current limit of the diodes is not exceeded when providing 5V to an input pin we must use a minimum resistor value of 2600Ω.

    5V input signal minus the point at which the diodes conduct (3.7V) gives a voltage difference of 1.3V. Solving using ohm’s law; 1.3V divided by 500uA gives 2600 ohms.

    (5V – 3.7V) / 0.0005A = 2600Ω

    To allow for some safety margin due to tolerances and the fact that 2.6k is not a standard resistor value it is recommend to use a 3.3k (2.8k minimum) or 4.7k resistor. Both values are common. Remember, it is not necessary to use a resistor on a Propeller output going into a 5V input. The bidirectional port tags show that the signal can travel in each direction, but the resistor is only required when the signal is bidirectional or an output from the 5V device.

    Caveats: Current is limited by the current rating of the clamping diodes. Larger resistors will reduce overall signal bandwidth. For example, you could use a 10K resistor in the example above, however less signal bandwidth would be available than using the minimum required resistor value.

    As a note there are other considerations as well. Sometimes you're interfacing to a pin that has been pulled up and then you inherently create a voltage divider which may not allow the pin to go low enough to be registered as a low.
  • wmosscropwmosscrop Posts: 409
    edited 2014-08-26 08:55
    T Chap wrote: »
    I remember back in the very early days some discussion about using a 1k for 5V inputs to Prop(could have been mistaken)

    You weren't mistaken.

    I've also been building circuits with the 1K resistor in series with the input, based upon this post:

    http://forums.parallax.com/showthread.php/85841-Propeller-Chip-5V-tolerant

    Now I guess I need to upgrade my devices... but I haven't had any chips fail for this reason.

    Walter
  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2014-08-26 09:13
    ManAtWork wrote: »
    No. Slower rise/fall times mean the input voltage stays longer in the "forbidden zone" near the threshold and oscillations may occur if you don't add a schmitt trigger circuit. I had that problem when I increased the series resistors for my 5V-tolerant inputs for step and charge pump inputs of a stepper motor driver. I had to add software debouncing to avoid false step pulse triggering. With a 1.2k resistor only, everything worked fine.

    All signals are not perfect and they will hover in that "forbidden zone" either way. But you are talking about a stepper motor driver which may exhibit that problem but I have tested the Prop in this regard. Even just now I connected a 1M resistor from one I/O to another and set it up to output various frequencies while I capture the other input into a buffer at high speeds. I have yet to detect these oscillations as it would be immediately apparent since I am reading the inputs as if they were 4MHz SPI data and what would occur would be irregular patterns. At various settings the data is perfectly preserved.

    To really exacerbate the condition I went and added a 0.1uf to the input of the Prop after the 1M resistor, surely now I will see oscillations? Nope, not a sausage.


    @Chris: Obviously if the input already has a pullup/pulldown then that would always have to be taken into account but I believe the whole discussion has been about how to connect to Prop pins, that is in their bare n naked state.

    Here's a glance at a couple of my captures which were done with a 10kHz excitation signal and capturing this at 4MSPS into a buffer.
    #10 KHZ  ok
    ( with 1M + 0.1uf on Prop input ) 
    CAP 
    0000_355C:   FF 00 00 00  FF FF FF FF   FF FF FF FF  FF FF FF FF   ................
    0000_356C:   E0 00 00 00  FF FF FF FF   FF FF FF FF  FF FF FF FF   ................
    0000_357C:   00 00 00 1F  FF FF FF FF   FF FF FF FF  FF FF FF FF   ................
    0000_358C:   00 00 00 FF  FF FF FF FF   FF FF FF FF  FF FF FF 00   ................
    0000_359C:   00 00 00 FF  FF FF FF FF   FF FF FF FF  FF FF FF 00   ................
    0000_35AC:   00 00 FF FF  FF FF FF FF   FF FF FF FF  FF FF FE 00   ................
    0000_35BC:   00 00 FF FF  FF FF FF FF   FF FF FF FF  FF FF 00 00   ................
    0000_35CC:   00 07 FF FF  FF FF FF FF   FF FF FF FF  FF FF 00 00   ................
    0000_35DC:   00 FF FF FF  FF FF FF FF   FF FF FF FF  FF E0 00 00   ................
    0000_35EC:   00 FF FF FF  FF FF FF FF   FF FF FF FF  FF 00 00 00   ................
    0000_35FC:   3F FF FF FF  FF FF FF FF   FF FF FF FF  FF 00 00 00   ?...............
    0000_360C:   FF FF FF FF  FF FF FF FF   FF FF FF FF  00 00 00 00   ................
    0000_361C:   FF FF FF FF  FF FF FF FF   FF FF FF FF  00 00 00 FF   ................
    0000_362C:   FF FF FF FF  FF FF FF FF   FF FF FF FE  00 00 00 FF   ................
    
    ( with just the 1M on the input )
    CAP 
    0000_355C:   FF 00 00 00  00 00 00 00   00 FF FF FF  FF FF FF FF   ................
    0000_356C:   FE 00 00 00  00 00 00 00   3F FF FF FF  FF FF FF FF   ........?.......
    0000_357C:   00 00 00 00  00 00 00 00   FF FF FF FF  FF FF FF FF   ................
    0000_358C:   00 00 00 00  00 00 00 00   FF FF FF FF  FF FF FF F0   ................
    0000_359C:   00 00 00 00  00 00 00 FF   FF FF FF FF  FF FF FF 00   ................
    0000_35AC:   00 00 00 00  00 00 00 FF   FF FF FF FF  FF FF FF 00   ................
    0000_35BC:   00 00 00 00  00 00 03 FF   FF FF FF FF  FF FF 80 00   ................
    0000_35CC:   00 00 00 00  00 00 FF FF   FF FF FF FF  FF FF 00 00   ................
    0000_35DC:   00 00 00 00  00 00 FF FF   FF FF FF FF  FF FE 00 00   ................
    0000_35EC:   00 00 00 00  00 3F FF FF   FF FF FF FF  FF 00 00 00   .....?..........
    0000_35FC:   00 00 00 00  00 FF FF FF   FF FF FF FF  FF 00 00 00   ................
    0000_360C:   00 00 00 00  00 FF FF FF   FF FF FF FF  F0 00 00 00   ................
    0000_361C:   00 00 00 00  FF FF FF FF   FF FF FF FF  00 00 00 00   ................
    0000_362C:   00 00 00 00  FF FF FF FF   FF FF FF FF  00 00 00 00   ................
    0000_363C:   00 00 00 03  FF FF FF FF   FF FF FF 80  00 00 00 00   ................
    0000_364C:   00 00 00 FF  FF FF FF FF   FF FF FF 00  00 00 00 00   ................
    

    Just to reinforce this and maybe make it a bit clearer I have done a dump in binary mode.
    0000000000000000000000000000000000000000000000000000000000000000
    1111111111111111111111111111111111111111111111111111111111111111
    0000000000000000000000000000000000000000000000000000000000001111
    1111111111111111111111111111111111111111111111111111111100000000
    0000000000000000000000000000000000000000000000000000000011111111
    1111111111111111111111111111111111111111111111111111111100000000
    0000000000000000000000000000000000000000000000000000000011111111
    1111111111111111111111111111111111111111111111111111110000000000
    0000000000000000000000000000000000000000000000000111111111111111
    1111111111111111111111111111111111111111111111110000000000000000
    0000000000000000000000000000000000000000000000001111111111111111
    1111111111111111111111111111111111111111111111110000000000000000
    0000000000000000000000000000000000000000000000001111111111111111
    1111111111111111111111111111111111111111111000000000000000000000
    0000000000000000000000000000000000000000111111111111111111111111
    1111111111111111111111111111111111111111000000000000000000000000
    0000000000000000000000000000000000000000111111111111111111111111
    1111111111111111111111111111111111111111000000000000000000000000
    0000000000000000000000000000000000001111111111111111111111111111
    1111111111111111111111111111111100000000000000000000000000000000
    0000000000000000000000000000000011111111111111111111111111111111
    1111111111111111111111111111111100000000000000000000000000000000
    

  • T ChapT Chap Posts: 4,223
    edited 2014-08-26 10:38
    Yes this is Beau's fault! I remember reading these early posts about 1k, and have hundreds of systems out there with 1k inputs from 5V, never once had a failure. This current problem may not even be related as it it sporadic and could be other things. I was mainly interested to see if there were such a state that could exists where the input could latch after being held to 5V with a 1.2k for a long period. I has been a long time since a Prop has blown up or a pin died, and these were always related to a direct hit on a pin with 5V or greater. It is an easy thing to change the machine to place a 4.99k on future builds. On the current problem, I have them adding a 4.7K inline with the 5V and changing to a different pin and see if that solves it.
  • LawsonLawson Posts: 870
    edited 2014-08-26 10:55
    (as regulators can't actually pull a line down).

    I'd say that most regulators can't pull a line down. I've seen a few low power CMOS regulators that advertise being able to sink current. (the pull-down FET is needed for stability at uA loads, might as well boast about it) Also any switching regulator with synchronous rectification can probably sink current as well.

    Back directly on topic, I've got an older design that uses 1K inline to 5v outputs and it's been working fine for years. The serial buss operates at a MHz or two, so I felt the speed was needed. I did have an update of that design show a ~4v Vcc line for the prop. I added a 300 ohm load to Vcc as a quick fix. If I ever revise the PCB, I'll use a 1k/2k voltage divider instead of the 1k series resistors.

    Marty
  • kwinnkwinn Posts: 8,697
    edited 2014-08-26 16:35
    This seems to be a recurring discussion. Based on typical specs of +-5% for regulators the worst case voltage difference between a 3.3V and 5V system would be 5.25V – 3.135V = 2.115V. Subtract the diode drop from that and a current limiting resistor for the propeller should drop a minimum of 1.415V at 500uA, which would be 2830 ohms.

    Going with a more conservative +-10% for regulators would result in requiring a voltage drop of 5.5 – (2.97 + 0.7) = 1.83V at 500uA or 3660 ohms.
  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2014-08-26 16:45
    Lawson wrote: »
    I'd say that most regulators can't pull a line down. I've seen a few low power CMOS regulators that advertise being able to sink current. (the pull-down FET is needed for stability at uA loads, might as well boast about it) Also any switching regulator with synchronous rectification can probably sink current as well.

    Back directly on topic, I've got an older design that uses 1K inline to 5v outputs and it's been working fine for years. The serial buss operates at a MHz or two, so I felt the speed was needed. I did have an update of that design show a ~4v Vcc line for the prop. I added a 300 ohm load to Vcc as a quick fix. If I ever revise the PCB, I'll use a 1k/2k voltage divider instead of the 1k series resistors.

    Marty

    Smarty Marty, I know about those regs too :) The trouble is that pratically all Prop designs I have seen rarely progress past simple linear regulators, so the "most" particularly refers to the ones that are employed in Prop designs. That ~4V you observed has caused problems for me with trying to reprogram devices and besides the load resistor I have also tried clamps using a 47R + 2 red LEDs in series.

    Personally I can't see where really low values of 1K are every necessary though, especially in view of tests I have run, but that's the good thing about already having a resistor there, it's easy to change the value anytime.
  • LoopyBytelooseLoopyByteloose Posts: 12,537
    edited 2014-08-27 11:02
    I think I will just continue to use 3.1K when I need it. But what I really need is a good oscilloscope to keep up with everyone's debate.

    Chip Gracy may have recommended 2.6K. But after that, I believe the 3.1K was justified by Beau Schwab in a rather elaborate clean up of some wrong assumptions.

    Should we trust Beau after is leading us astray with the 1K value? A lot of things happened in the early days that were not quite right. Also the values for the VGA resistors were not quite right. In fact, my Propeller Protoboard required addition of 100 to 120 ohm SMD to get the color to be really nice.

    But that is yet another resistor topic that went on and on. I tend to just follow along in these.
  • tonyp12tonyp12 Posts: 1,951
    edited 2014-08-27 14:03
    If you want speed, Buffer IC with a 3.3Vcc but it still takes 5-7V on its inputs is the best way to go:
    http://tinyurl.com/nf5xj2a
  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2014-08-27 16:33
    I think I will just continue to use 3.1K when I need it. But what I really need is a good oscilloscope to keep up with everyone's debate.

    Chip Gracy may have recommended 2.6K. But after that, I believe the 3.1K was justified by Beau Schwab in a rather elaborate clean up of some wrong assumptions.

    Should we trust Beau after is leading us astray with the 1K value? A lot of things happened in the early days that were not quite right. Also the values for the VGA resistors were not quite right. In fact, my Propeller Protoboard required addition of 100 to 120 ohm SMD to get the color to be really nice.

    But that is yet another resistor topic that went on and on. I tend to just follow along in these.

    So what's maths and science and observation and testing got to do with it then? Just keep doing it your way.

    However for those who are interested I just discovered that I had picked up a 4.7M resistor instead of the 1M and had tested with that!. Hooking this up to the scope shows a reduced amplitude from which I worked out that the inputs are reading more like 10M resistance. Anyway I went back and checked this with a 100K resistor at 10MHz on the scope. So even with the 100K resistor it is very usable even at 10MHz. At 1MHz you can't even tell the difference. Why would I ever want to have voltage translators or 1K resistors "just to be sure"?
    prop-100k.png
    prop-100k.jpg



    I have done quite a bit of testing which I didn't really have time for but I am happy with the 100K as a standard value but if I still want speed then all it takes is a 15pf capacitor in parallel with the 100K as this works at >10MHz and is symmetrical. I've also ran this through LTspice and attached the files. Try this with 50V inputs!
    Screenshot from 2014-08-28 14:19:22.jpg
    800 x 600 - 38K
    1024 x 657 - 126K
Sign In or Register to comment.