-
Notifications
You must be signed in to change notification settings - Fork 131
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Question - High Drive GPIO pins #456
Comments
When I queried Nordic about this (around November 2016) the answer was 'no' (their engineers even ran the code in a debugger and checked the values in the pin drive registers, and confirmed 5mA high drive was disabled). You will have to check with @jamesadevine as to whether any changes have been made to the DAL since then that affect this configuration. There is an article on the support site here that shows how to write to chip registers from user code, along with a link to the device register map, so you could change the settings yourself and see if it allows you to achieve your current goal, whatever that may be. Note also some analysis that @edbye did a while back, shows that GPIO pins will provide more than the stated/configured current limit. This was confirmed by a Nordic engineer at the time, who said that GPIO pins will continue to provide more current, but that the voltage will de-rate (roughly linearly) and therefore the pin voltage specs cannot be guaranteed or maintained at higher currents (and thus a logic '1' level will not be guaranteed any more). Also the performance of analogs and the radio block would suffer as a result. @edbye discovered by systematic testing, that the GPIO pin will continue to de-rate it's voltage until a point where the pin becomes temporarily non functional, eventually the GPIO block shuts down completely, both are recovered by power cycling the device. Hope this helps. |
@whaleygeek Thanks David! I investigated all the various layers last night out of curiosity and couldn't see any place where high drive mode is set. I also looked at the nrf51822 product specification and noted that the maximum current draw for a pin is not specified, so I'm glad your findings confirm this. @mastertechisme do you require access to high drive? |
Sorry if this is a red herring. This is confusing if high drive mode is disabled: |
Hi Martin, It's a good point you make. However although it might be a tad misleading, it is still correct - it does not say whether the pins are pre-configured in that mode or not. But we should open a github ticket on the tech site to clarify, I think... |
Not sure I clearly understand what the question(s) is. |
Yes, let me clarify. On an Arduino, you get an overall current budget for all GPIO combined, 100ma lets say, plus a maximum of 20ma per GPIO. At least here I can tell what is possible with some math. On the microbit, I see several mentions that GPIO can source 5ma, but only 3 pins, if enabled through software. So I am looking for specifics on current from GPIO pins. If you have a link to your write up that would be great. I also see from that article on Microbit site they are pulling 5 ma from pin 0. I was also wondering are pins 0,1,2 set to 5ma by default? This is rationale behind the question, hope this helps. |
The intended purpose for ‘high drive’ is to maintain correct logic levels when interfacing with other logic IC’s, not for driving things like LED’s. Changing from standard GPIO drive to high will not change the published limitations on current capabilities. It will not give an overall increase or per pin capability. In standard drive you can comfortably drive up to 5mA, as evidenced by the Microbit LED matrix, 220R resistor to Red LED. If high current GPIO output is required, the correct way is to use a hardware interface. When it comes to LED’s, why do you need 20mA? Most, if not all LED’s will give a very reasonable level of illumination with a current of 2mA or less. Hope that clarifiies and helps |
If the capability to drive up to 5mA is not related to high drive, does that mean the mention of high drive and a 3 pin limit is not relevant in the article about connecting LEDs? |
Not really (i.e. it is still relevant). 5mA high drive, if enabled, will guarantee up to 5mA for each of the 3 configured pins while maintaining guaranteed voltage specifications such that VOH and VOL logic levels are within spec for logic circuits also. In the default case of std drive, the VOH in particular will linearly collapse as you draw more current, so you cant guarantee that attached logic circuits will also work in those conditions. |
having done some more research on this, I stand corrected. In high drive mode, you can get substantially more than 15mA output current from a GPIO https://devzone.nordicsemi.com/f/nordic-q-a/19897/nrf51822-gpio-direct-source-with-high-drive-setting As @whaleygeek says, it is the chip specifications that can not be met above 5mA (high drive), for standard drive it is less. The question is does this matter? This can only be answered by considering the circuitry requirements of what is being driven i.e. the appropriate datasheet must be consulted for respective VIH and VIL over the range of the power rail voltage. The degredation of VOH only applies to the GPIO under consideration, each of the GPIO's has its own monitoring circuit. |
Does the DAL set any of the GPIO pins to high drive, 5ma, instead of .5 ma? I see examples of micro:bit driving an LED directly of pin 0 with a max of 5 ma. So somewhere I assume this is being set because makecode does not have a function to set high drive.
The text was updated successfully, but these errors were encountered: