Commit c13b2f2d authored by Peter Hinch's avatar Peter Hinch Committed by Damien George

docs: Several minor changes: network, pyb, ADCAll and inline asm.

parent 22d85ec5
...@@ -8,7 +8,8 @@ ...@@ -8,7 +8,8 @@
This module provides network drivers and routing configuration. Network This module provides network drivers and routing configuration. Network
drivers for specific hardware are available within this module and are drivers for specific hardware are available within this module and are
used to configure a hardware network interface. Configured interfaces used to configure a hardware network interface. Configured interfaces
are then available for use via the :mod:`socket` module. are then available for use via the :mod:`socket` module. To use this module
the network build of firmware must be installed.
For example:: For example::
......
...@@ -74,3 +74,9 @@ Methods ...@@ -74,3 +74,9 @@ Methods
This function does not allocate any memory. This function does not allocate any memory.
The ADCAll Object
-----------------
Instantiating this changes all ADC pins to analog inputs. It is possible to read the
MCU temperature, VREF and VBAT without using ADCAll. The raw data can be accessed on
ADC channels 16, 17 and 18 respectively. However appropriate scaling will need to be applied.
...@@ -25,6 +25,10 @@ Time related functions ...@@ -25,6 +25,10 @@ Time related functions
after 2^30 milliseconds (about 12.4 days) this will start to return after 2^30 milliseconds (about 12.4 days) this will start to return
negative numbers. negative numbers.
Note that if :meth:`pyb.stop()` is issued the hardware counter supporting this
function will pause for the duration of the "sleeping" state. This
will affect the outcome of :meth:`pyb.elapsed_millis()`.
.. function:: micros() .. function:: micros()
Returns the number of microseconds since the board was last reset. Returns the number of microseconds since the board was last reset.
...@@ -33,6 +37,10 @@ Time related functions ...@@ -33,6 +37,10 @@ Time related functions
after 2^30 microseconds (about 17.8 minutes) this will start to return after 2^30 microseconds (about 17.8 minutes) this will start to return
negative numbers. negative numbers.
Note that if :meth:`pyb.stop()` is issued the hardware counter supporting this
function will pause for the duration of the "sleeping" state. This
will affect the outcome of :meth:`pyb.elapsed_micros()`.
.. function:: elapsed_millis(start) .. function:: elapsed_millis(start)
Returns the number of milliseconds which have elapsed since ``start``. Returns the number of milliseconds which have elapsed since ``start``.
......
...@@ -78,11 +78,11 @@ three arguments, which must (if used) be named ``r0``, ``r1`` and ``r2``. When ...@@ -78,11 +78,11 @@ three arguments, which must (if used) be named ``r0``, ``r1`` and ``r2``. When
the code executes the registers will be initialised to those values. the code executes the registers will be initialised to those values.
The data types which can be passed in this way are integers and memory The data types which can be passed in this way are integers and memory
addresses. Further, integers are restricted in that the top two bits addresses. With current firmware all possible 32 bit values may be passed.
must be identical, limiting the range to -2**30 to 2**30 -1. Return Returned integers are restricted in that the top two bits must be identical,
values are similarly limited. These limitations can be overcome by means limiting the range to -2**30 to 2**30 -1. The limitations on number of arguments
of the ``array`` module to allow any number of values of any type to and return values can be overcome by means of the ``array`` module which enables
be accessed. any number of values of any type to be accessed.
Multiple arguments Multiple arguments
~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~
......
...@@ -5,6 +5,9 @@ Miscellaneous instructions ...@@ -5,6 +5,9 @@ Miscellaneous instructions
* wfi() Suspend execution in a low power state until an interrupt occurs. * wfi() Suspend execution in a low power state until an interrupt occurs.
* cpsid(flags) set the Priority Mask Register - disable interrupts. * cpsid(flags) set the Priority Mask Register - disable interrupts.
* cpsie(flags) clear the Priority Mask Register - enable interrupts. * cpsie(flags) clear the Priority Mask Register - enable interrupts.
* mrs(Rd, special_reg) ``Rd = special_reg`` copy a special register to a general register. The special register
may be IPSR (Interrupt Status Register) or BASEPRI (Base Priority Register). The IPSR provides a means of determining
the exception number of an interrupt being processed. It contains zero if no interrupt is being processed.
Currently the ``cpsie()`` and ``cpsid()`` functions are partially implemented. Currently the ``cpsie()`` and ``cpsid()`` functions are partially implemented.
They require but ignore the flags argument and serve as a means of enabling and disabling interrupts. They require but ignore the flags argument and serve as a means of enabling and disabling interrupts.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment