oracular (3) lowlevel.3.gz

Provided by: libbcm2835-dev_1.75+ds-1_amd64 bug

NAME

       lowlevel - Low level register access

SYNOPSIS

   Functions
       uint32_t * bcm2835_regbase (uint8_t regbase)
       uint32_t bcm2835_peri_read (volatile uint32_t *paddr)
       uint32_t bcm2835_peri_read_nb (volatile uint32_t *paddr)
       void bcm2835_peri_write (volatile uint32_t *paddr, uint32_t value)
       void bcm2835_peri_write_nb (volatile uint32_t *paddr, uint32_t value)
       void bcm2835_peri_set_bits (volatile uint32_t *paddr, uint32_t value, uint32_t mask)

Detailed Description

       These functions provide low level register access, and should not generally need to be used

Function Documentation

   uint32_t bcm2835_peri_read (volatile uint32_t * paddr) [extern]
       Reads 32 bit value from a peripheral address WITH a memory barrier before and after each read. This is
       safe, but slow. The MB before protects this read from any in-flight reads that didn't use a MB. The MB
       after protects subsequent reads from another peripheral.

       Parameters
           paddr Physical address to read from. See BCM2835_GPIO_BASE etc.

       Returns
           the value read from the 32 bit register

       See also
           Physical Addresses

   uint32_t bcm2835_peri_read_nb (volatile uint32_t * paddr) [extern]
       Reads 32 bit value from a peripheral address WITHOUT the read barriers You should only use this when: o
       your code has previously called bcm2835_peri_read() for a register within the same peripheral, and no
       read or write to another peripheral has occurred since. o your code has called bcm2835_memory_barrier()
       since the last access to ANOTHER peripheral.

       Parameters
           paddr Physical address to read from. See BCM2835_GPIO_BASE etc.

       Returns
           the value read from the 32 bit register

       See also
           Physical Addresses

   void bcm2835_peri_set_bits (volatile uint32_t * paddr, uint32_t value, uint32_t mask) [extern]
       Alters a number of bits in a 32 peripheral regsiter. It reads the current valu and then alters the bits
       defines as 1 in mask, according to the bit value in value. All other bits that are 0 in the mask are
       unaffected. Use this to alter a subset of the bits in a register. Memory barriers are used. Note that
       this is not atomic; an interrupt routine can cause unexpected results.

       Parameters
           paddr Physical address to read from. See BCM2835_GPIO_BASE etc.
           value The 32 bit value to write, masked in by mask.
           mask Bitmask that defines the bits that will be altered in the register.

       See also
           Physical Addresses

   void bcm2835_peri_write (volatile uint32_t * paddr, uint32_t value) [extern]
       Writes 32 bit value from a peripheral address WITH a memory barrier before and after each write This is
       safe, but slow. The MB before ensures that any in-flight write to another peripheral completes before
       this write is issued. The MB after ensures that subsequent reads and writes to another peripheral will
       see the effect of this write.

       This is a tricky optimization; if you aren't sure, use the barrier version.

       Parameters
           paddr Physical address to read from. See BCM2835_GPIO_BASE etc.
           value The 32 bit value to write

       See also
           Physical Addresses

   void bcm2835_peri_write_nb (volatile uint32_t * paddr, uint32_t value) [extern]
       Writes 32 bit value from a peripheral address without the write barrier You should only use this when: o
       your code has previously called bcm2835_peri_write() for a register within the same peripheral, and no
       other peripheral access has occurred since. o your code has called bcm2835_memory_barrier() since the
       last access to ANOTHER peripheral.

       This is a tricky optimization; if you aren't sure, use the barrier version.

       Parameters
           paddr Physical address to read from. See BCM2835_GPIO_BASE etc.
           value The 32 bit value to write

       See also
           Physical Addresses

   uint32_t * bcm2835_regbase (uint8_t regbase) [extern]
       Gets the base of a register

       Parameters
           regbase You can use one of the common values BCM2835_REGBASE_* in bcm2835RegisterBase

       Returns
           the register base

       See also
           Physical Addresses

Author

       Generated automatically by Doxygen for bcm2835 from the source code.