2014-11-04 18:25:20 +00:00
|
|
|
.. _pyb.Pin:
|
|
|
|
|
2014-10-31 22:21:37 +00:00
|
|
|
class Pin -- control I/O pins
|
|
|
|
=============================
|
2014-10-31 01:37:19 +00:00
|
|
|
|
|
|
|
A pin is the basic object to control I/O pins. It has methods to set
|
|
|
|
the mode of the pin (input, output, etc) and methods to get and set the
|
2015-06-10 22:29:56 +01:00
|
|
|
digital logic level. For analog control of a pin, see the ADC class.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
|
|
|
Usage Model:
|
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
All Board Pins are predefined as pyb.Pin.board.Name::
|
|
|
|
|
|
|
|
x1_pin = pyb.Pin.board.X1
|
|
|
|
|
|
|
|
g = pyb.Pin(pyb.Pin.board.X1, pyb.Pin.IN)
|
|
|
|
|
|
|
|
CPU pins which correspond to the board pins are available
|
|
|
|
as ``pyb.cpu.Name``. For the CPU pins, the names are the port letter
|
|
|
|
followed by the pin number. On the PYBv1.0, ``pyb.Pin.board.X1`` and
|
|
|
|
``pyb.Pin.cpu.B6`` are the same pin.
|
|
|
|
|
|
|
|
You can also use strings::
|
|
|
|
|
|
|
|
g = pyb.Pin('X1', pyb.Pin.OUT_PP)
|
|
|
|
|
|
|
|
Users can add their own names::
|
|
|
|
|
|
|
|
MyMapperDict = { 'LeftMotorDir' : pyb.Pin.cpu.C12 }
|
|
|
|
pyb.Pin.dict(MyMapperDict)
|
|
|
|
g = pyb.Pin("LeftMotorDir", pyb.Pin.OUT_OD)
|
|
|
|
|
|
|
|
and can query mappings::
|
|
|
|
|
|
|
|
pin = pyb.Pin("LeftMotorDir")
|
|
|
|
|
|
|
|
Users can also add their own mapping function::
|
|
|
|
|
|
|
|
def MyMapper(pin_name):
|
|
|
|
if pin_name == "LeftMotorDir":
|
|
|
|
return pyb.Pin.cpu.A0
|
|
|
|
|
|
|
|
pyb.Pin.mapper(MyMapper)
|
|
|
|
|
|
|
|
So, if you were to call: ``pyb.Pin("LeftMotorDir", pyb.Pin.OUT_PP)``
|
|
|
|
then ``"LeftMotorDir"`` is passed directly to the mapper function.
|
|
|
|
|
|
|
|
To summarise, the following order determines how things get mapped into
|
|
|
|
an ordinal pin number:
|
|
|
|
|
|
|
|
1. Directly specify a pin object
|
|
|
|
2. User supplied mapping function
|
|
|
|
3. User supplied mapping (object must be usable as a dictionary key)
|
|
|
|
4. Supply a string which matches a board pin
|
|
|
|
5. Supply a string which matches a CPU port/pin
|
|
|
|
|
|
|
|
You can set ``pyb.Pin.debug(True)`` to get some debug information about
|
|
|
|
how a particular object gets mapped to a pin.
|
|
|
|
|
|
|
|
When a pin has the ``Pin.PULL_UP`` or ``Pin.PULL_DOWN`` pull-mode enabled,
|
|
|
|
that pin has an effective 40k Ohm resistor pulling it to 3V3 or GND
|
|
|
|
respectively (except pin Y5 which has 11k Ohm resistors).
|
|
|
|
|
|
|
|
.. only:: port_wipy
|
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
Board pins are identified by their string id::
|
2015-06-10 22:29:56 +01:00
|
|
|
|
2015-09-13 14:31:17 +01:00
|
|
|
g = pyb.Pin('GP9', mode=pyb.Pin.OUT, pull=None, drive=pyb.Pin.MED_POWER, alt=-1)
|
2015-06-10 22:29:56 +01:00
|
|
|
|
|
|
|
You can also configure the Pin to generate interrupts. For instance::
|
|
|
|
|
|
|
|
def pincb(pin):
|
2015-09-03 10:25:44 +01:00
|
|
|
print(pin.id())
|
2015-06-10 22:29:56 +01:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
pin_int = pyb.Pin('GP10', mode=Pin.IN, pull=pyb.Pin.PULL_DOWN)
|
|
|
|
pin_int.irq(mode=pyb.Pin.IRQ_RISING, handler=pincb)
|
2015-06-10 22:29:56 +01:00
|
|
|
# the callback can be triggered manually
|
2015-09-03 10:25:44 +01:00
|
|
|
pin_int.irq()()
|
2015-06-10 22:29:56 +01:00
|
|
|
# to disable the callback
|
2015-09-03 10:25:44 +01:00
|
|
|
pin_int.irq().disable()
|
2015-06-10 22:29:56 +01:00
|
|
|
|
|
|
|
Now every time a falling edge is seen on the gpio pin, the callback will be
|
|
|
|
executed. Caution: mechanical push buttons have "bounce" and pushing or
|
|
|
|
releasing a switch will often generate multiple edges.
|
|
|
|
See: http://www.eng.utah.edu/~cs5780/debouncing.pdf for a detailed
|
|
|
|
explanation, along with various techniques for debouncing.
|
|
|
|
|
|
|
|
All pin objects go through the pin mapper to come up with one of the
|
|
|
|
gpio pins.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
Constructors
|
|
|
|
------------
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
.. class:: pyb.Pin(id, ...)
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
Create a new Pin object associated with the id. If additional arguments are given,
|
|
|
|
they are used to initialise the pin. See :meth:`pin.init`.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. only:: port_pyboard
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
Class methods
|
|
|
|
-------------
|
|
|
|
|
|
|
|
.. method:: Pin.af_list()
|
|
|
|
|
|
|
|
Returns an array of alternate functions available for this pin.
|
|
|
|
|
|
|
|
.. method:: Pin.debug([state])
|
|
|
|
|
|
|
|
Get or set the debugging state (``True`` or ``False`` for on or off).
|
|
|
|
|
|
|
|
.. method:: Pin.dict([dict])
|
|
|
|
|
|
|
|
Get or set the pin mapper dictionary.
|
|
|
|
|
|
|
|
.. method:: Pin.mapper([fun])
|
|
|
|
|
|
|
|
Get or set the pin mapper function.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
Methods
|
|
|
|
-------
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. only:: port_pyboard
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. method:: pin.init(mode, pull=Pin.PULL_NONE, af=-1)
|
|
|
|
|
|
|
|
Initialise the pin:
|
|
|
|
|
|
|
|
- ``mode`` can be one of:
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
- ``Pin.IN`` - configure the pin for input;
|
|
|
|
- ``Pin.OUT_PP`` - configure the pin for output, with push-pull control;
|
|
|
|
- ``Pin.OUT_OD`` - configure the pin for output, with open-drain control;
|
|
|
|
- ``Pin.AF_PP`` - configure the pin for alternate function, pull-pull;
|
|
|
|
- ``Pin.AF_OD`` - configure the pin for alternate function, open-drain;
|
|
|
|
- ``Pin.ANALOG`` - configure the pin for analog.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
- ``pull`` can be one of:
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
- ``Pin.PULL_NONE`` - no pull up or down resistors;
|
|
|
|
- ``Pin.PULL_UP`` - enable the pull-up resistor;
|
|
|
|
- ``Pin.PULL_DOWN`` - enable the pull-down resistor.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
- when mode is ``Pin.AF_PP`` or ``Pin.AF_OD``, then af can be the index or name
|
|
|
|
of one of the alternate functions associated with a pin.
|
|
|
|
|
|
|
|
Returns: ``None``.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. only:: port_wipy
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
.. method:: pin.init(mode, pull, \*, drive, alt)
|
2015-06-10 22:29:56 +01:00
|
|
|
|
|
|
|
Initialise the pin:
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
- ``mode`` can be one of:
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
- ``Pin.IN`` - input pin.
|
|
|
|
- ``Pin.OUT`` - output pin in push-pull mode.
|
|
|
|
- ``Pin.OPEN_DRAIN`` - output pin in open-drain mode.
|
|
|
|
- ``Pin.ALT`` - pin mapped to an alternate function.
|
|
|
|
- ``Pin.ALT_OPEN_DRAIN`` - pin mapped to an alternate function in open-drain mode.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
- ``pull`` can be one of:
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-13 14:31:17 +01:00
|
|
|
- ``None`` - no pull up or down resistor.
|
2015-09-03 10:25:44 +01:00
|
|
|
- ``Pin.PULL_UP`` - pull up resistor enabled.
|
|
|
|
- ``Pin.PULL_DOWN`` - pull down resitor enabled.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
- ``drive`` can be one of:
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
- ``Pin.LOW_POWER`` - 2mA drive capability.
|
|
|
|
- ``Pin.MED_POWER`` - 4mA drive capability.
|
|
|
|
- ``Pin.HIGH_POWER`` - 6mA drive capability.
|
|
|
|
|
|
|
|
- ``alt`` is the number of the alternate function. Please refer to the
|
|
|
|
`pinout and alternate functions table. <https://raw.githubusercontent.com/wipy/wipy/master/docs/PinOUT.png>`_
|
|
|
|
for the specific alternate functions that each pin supports.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
Returns: ``None``.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
.. method:: pin.id()
|
|
|
|
|
|
|
|
Get the pin id.
|
|
|
|
|
2014-11-04 18:07:06 +00:00
|
|
|
.. method:: pin.value([value])
|
|
|
|
|
|
|
|
Get or set the digital logic level of the pin:
|
|
|
|
|
|
|
|
- With no argument, return 0 or 1 depending on the logic level of the pin.
|
|
|
|
- With ``value`` given, set the logic level of the pin. ``value`` can be
|
|
|
|
anything that converts to a boolean. If it converts to ``True``, the pin
|
|
|
|
is set high, otherwise it is set low.
|
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
.. method:: pin.__str__()
|
|
|
|
|
|
|
|
Return a string describing the pin object.
|
|
|
|
|
|
|
|
.. method:: pin.af()
|
|
|
|
|
|
|
|
Returns the currently configured alternate-function of the pin. The
|
|
|
|
integer returned will match one of the allowed constants for the af
|
|
|
|
argument to the init function.
|
|
|
|
|
|
|
|
.. method:: pin.gpio()
|
|
|
|
|
|
|
|
Returns the base address of the GPIO block associated with this pin.
|
|
|
|
|
|
|
|
.. method:: pin.mode()
|
|
|
|
|
|
|
|
Returns the currently configured mode of the pin. The integer returned
|
|
|
|
will match one of the allowed constants for the mode argument to the init
|
|
|
|
function.
|
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
.. method:: pin.name()
|
2015-06-28 11:53:37 +01:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
Get the pin name.
|
2015-06-28 11:53:37 +01:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. method:: pin.names()
|
|
|
|
|
|
|
|
Returns the cpu and board names for this pin.
|
|
|
|
|
|
|
|
.. method:: pin.pin()
|
|
|
|
|
|
|
|
Get the pin number.
|
|
|
|
|
|
|
|
.. method:: pin.port()
|
|
|
|
|
|
|
|
Get the pin port.
|
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
.. method:: pin.pull()
|
|
|
|
|
|
|
|
Returns the currently configured pull of the pin. The integer returned
|
|
|
|
will match one of the allowed constants for the pull argument to the init
|
|
|
|
function.
|
2015-06-10 22:29:56 +01:00
|
|
|
|
|
|
|
.. only:: port_wipy
|
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
.. method:: pin([value])
|
|
|
|
|
|
|
|
Pin objects are callable. The call method provides a (fast) shortcut to set and get the value of the pin.
|
|
|
|
See **pin.value** for more details.
|
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. method:: pin.toggle()
|
|
|
|
|
|
|
|
Toggle the value of the pin.
|
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
.. method:: pin.mode([mode])
|
|
|
|
|
|
|
|
Get or set the pin mode.
|
2015-06-10 22:29:56 +01:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
.. method:: pin.pull([pull])
|
2015-06-10 22:29:56 +01:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
Get or set the pin pull.
|
2015-06-28 11:53:37 +01:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
.. method:: pin.drive([drive])
|
|
|
|
|
|
|
|
Get or set the pin drive strength.
|
|
|
|
|
|
|
|
.. method:: pin.irq(\*, trigger, priority=1, handler=None, wake=None)
|
2015-06-10 22:29:56 +01:00
|
|
|
|
2015-06-11 14:53:31 +01:00
|
|
|
Create a callback to be triggered when the input level at the pin changes.
|
2015-06-10 22:29:56 +01:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
- ``trigger`` configures the pin level which can generate an interrupt. Possible values are:
|
2015-06-10 22:29:56 +01:00
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
- ``Pin.IRQ_FALLING`` interrupt on falling edge.
|
|
|
|
- ``Pin.IRQ_RISING`` interrupt on rising edge.
|
|
|
|
- ``Pin.IRQ_LOW_LEVEL`` interrupt on low level.
|
|
|
|
- ``Pin.IRQ_HIGH_LEVEL`` interrupt on high level.
|
|
|
|
|
|
|
|
The values can be *ORed* together, for instance mode=Pin.IRQ_FALLING | Pin.IRQ_RISING
|
2015-06-10 22:29:56 +01:00
|
|
|
|
|
|
|
- ``priority`` level of the interrupt. Can take values in the range 1-7.
|
|
|
|
Higher values represent higher priorities.
|
|
|
|
- ``handler`` is an optional function to be called when new characters arrive.
|
2015-09-03 10:25:44 +01:00
|
|
|
- ``wakes`` selects the power mode in which this interrupt can wake up the
|
2015-06-10 22:29:56 +01:00
|
|
|
board. Please note:
|
|
|
|
|
2015-08-11 10:18:02 +01:00
|
|
|
- If ``wake_from=pyb.Sleep.ACTIVE`` any pin can wake the board.
|
|
|
|
- If ``wake_from=pyb.Sleep.SUSPENDED`` pins ``GP2``, ``GP4``, ``GP10``,
|
2015-07-28 22:03:53 +01:00
|
|
|
``GP11``, GP17`` or ``GP24`` can wake the board. Note that only 1
|
2015-06-10 22:29:56 +01:00
|
|
|
of this pins can be enabled as a wake source at the same time, so, only
|
|
|
|
the last enabled pin as a ``pyb.Sleep.SUSPENDED`` wake source will have effect.
|
2015-08-11 10:18:02 +01:00
|
|
|
- If ``wake_from=pyb.Sleep.SUSPENDED`` pins ``GP2``, ``GP4``, ``GP10``,
|
2015-07-28 22:03:53 +01:00
|
|
|
``GP11``, ``GP17`` and ``GP24`` can wake the board. In this case all of the
|
2015-06-11 14:53:31 +01:00
|
|
|
6 pins can be enabled as a ``pyb.Sleep.HIBERNATE`` wake source at the same time.
|
2015-06-10 22:29:56 +01:00
|
|
|
- Values can be ORed to make a pin generate interrupts in more than one power
|
|
|
|
mode.
|
|
|
|
|
|
|
|
Returns a callback object.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
Constants
|
|
|
|
---------
|
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
.. data:: Pin.AF_OD
|
|
|
|
|
|
|
|
initialise the pin to alternate-function mode with an open-drain drive
|
|
|
|
|
|
|
|
.. data:: Pin.AF_PP
|
|
|
|
|
|
|
|
initialise the pin to alternate-function mode with a push-pull drive
|
|
|
|
|
|
|
|
.. data:: Pin.ANALOG
|
|
|
|
|
|
|
|
initialise the pin to analog mode
|
|
|
|
|
|
|
|
.. data:: Pin.IN
|
|
|
|
|
|
|
|
initialise the pin to input mode
|
|
|
|
|
|
|
|
.. data:: Pin.OUT_OD
|
|
|
|
|
|
|
|
initialise the pin to output mode with an open-drain drive
|
|
|
|
|
|
|
|
.. data:: Pin.OUT_PP
|
|
|
|
|
|
|
|
initialise the pin to output mode with a push-pull drive
|
|
|
|
|
|
|
|
.. data:: Pin.PULL_DOWN
|
|
|
|
|
|
|
|
enable the pull-down resistor on the pin
|
|
|
|
|
|
|
|
.. data:: Pin.PULL_NONE
|
|
|
|
|
|
|
|
don't enable any pull up or down resistors on the pin
|
|
|
|
|
|
|
|
.. data:: Pin.PULL_UP
|
|
|
|
|
|
|
|
enable the pull-up resistor on the pin
|
|
|
|
|
|
|
|
.. only:: port_wipy
|
|
|
|
|
|
|
|
.. data:: Pin.IN
|
2015-09-03 10:25:44 +01:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. data:: Pin.OUT
|
|
|
|
|
2015-09-03 10:25:44 +01:00
|
|
|
.. data:: Pin.OPEN_DRAIN
|
|
|
|
|
|
|
|
.. data:: Pin.ALT
|
|
|
|
|
|
|
|
.. data:: Pin.ALT_OPEN_DRAIN
|
|
|
|
|
|
|
|
Selects the pin mode.
|
|
|
|
|
|
|
|
.. data:: Pin.PULL_UP
|
|
|
|
|
|
|
|
.. data:: Pin.PULL_DOWN
|
2015-06-10 22:29:56 +01:00
|
|
|
|
2015-09-13 14:31:17 +01:00
|
|
|
Selectes the wether there's pull up/down resistor.
|
2015-09-03 10:25:44 +01:00
|
|
|
|
|
|
|
.. data:: Pin.LOW_POWER
|
|
|
|
|
|
|
|
.. data:: Pin.MED_POWER
|
|
|
|
|
|
|
|
.. data:: Pin.HIGH_POWER
|
|
|
|
|
|
|
|
Selects the drive strength.
|
|
|
|
|
|
|
|
.. data:: Pin.IRQ_FALLING
|
|
|
|
|
|
|
|
.. data:: Pin.IRQ_RISING
|
|
|
|
|
|
|
|
.. data:: Pin.IRQ_LOW_LEVEL
|
|
|
|
|
|
|
|
.. data:: Pin.IRQ_HIGH_LEVEL
|
|
|
|
|
|
|
|
Selects the IRQ trigger type.
|
2015-06-10 22:29:56 +01:00
|
|
|
|
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
class PinAF -- Pin Alternate Functions
|
|
|
|
======================================
|
|
|
|
|
|
|
|
A Pin represents a physical pin on the microcprocessor. Each pin
|
|
|
|
can have a variety of functions (GPIO, I2C SDA, etc). Each PinAF
|
|
|
|
object represents a particular function for a pin.
|
|
|
|
|
|
|
|
Usage Model::
|
|
|
|
|
|
|
|
x3 = pyb.Pin.board.X3
|
|
|
|
x3_af = x3.af_list()
|
|
|
|
|
|
|
|
x3_af will now contain an array of PinAF objects which are availble on
|
|
|
|
pin X3.
|
|
|
|
|
|
|
|
For the pyboard, x3_af would contain:
|
|
|
|
[Pin.AF1_TIM2, Pin.AF2_TIM5, Pin.AF3_TIM9, Pin.AF7_USART2]
|
|
|
|
|
|
|
|
Normally, each peripheral would configure the af automatically, but sometimes
|
|
|
|
the same function is available on multiple pins, and having more control
|
|
|
|
is desired.
|
|
|
|
|
|
|
|
To configure X3 to expose TIM2_CH3, you could use::
|
|
|
|
|
|
|
|
pin = pyb.Pin(pyb.Pin.board.X3, mode=pyb.Pin.AF_PP, af=pyb.Pin.AF1_TIM2)
|
|
|
|
|
|
|
|
or::
|
|
|
|
|
|
|
|
pin = pyb.Pin(pyb.Pin.board.X3, mode=pyb.Pin.AF_PP, af=1)
|
|
|
|
|
|
|
|
Methods
|
|
|
|
-------
|
|
|
|
|
|
|
|
.. method:: pinaf.__str__()
|
|
|
|
|
|
|
|
Return a string describing the alternate function.
|
|
|
|
|
|
|
|
.. method:: pinaf.index()
|
|
|
|
|
|
|
|
Return the alternate function index.
|
|
|
|
|
|
|
|
.. method:: pinaf.name()
|
|
|
|
|
|
|
|
Return the name of the alternate function.
|
|
|
|
|
|
|
|
.. method:: pinaf.reg()
|
|
|
|
|
|
|
|
Return the base register associated with the peripheral assigned to this
|
|
|
|
alternate function. For example, if the alternate function were TIM2_CH3
|
|
|
|
this would return stm.TIM2
|