in32s()

Read 32-bit values from a port

Synopsis:

#include <hw/inout.h>

void * in32s( void * buff,
              unsigned len,
              uintptr_t port );

Arguments:

buff
A pointer to a buffer where the function can store the values read.
len
The number of values that you want to read.
port
The port you want to read the values from.

Library:

libc

Use the -l c option to qcc to link against this library. This library is usually included automatically.

Description:

The in32s() function reads len 32-bit values from the specified port and stores them in the buffer pointed to by buff.

The calling process must use mmap_device_io() to access the device's I/O registers.

On x86 targets, the calling thread must have I/O privileges, or else it will fault with a SIGSEGV; see the ThreadCtl() _NTO_TCTL_IO command for details.

Returns:

A pointer to the end of the read data.

Classification:

QNX Neutrino

Safety:
Cancellation point No
Interrupt handler Yes
Signal handler Yes
Thread Yes

See also:

in8(), in8s(), in16(), in16s(), in32(), mmap_device_io(), out8(), out8s(), out16(), out16s(), out32(), out32s()