table of contents
CXL_MMIO_READ32(3) | CXL Programmer's Manual | CXL_MMIO_READ32(3) |
NAME¶
cxl_mmio_read32 - read a 32-bit word from the mapped AFU Problem State Area
SYNOPSIS¶
#include <libcxl.h>
int cxl_mmio_read32(struct cxl_afu_h *afu, uint64_t offset, uint32_t *data);
DESCRIPTION¶
cxl_mmio_read32() reads the 32-bit word at offset from the address of the mapped Problem State Area of afu, and copies its value to the word pointed to by data. The copy will include byte swapping if the AFU endianness declared by cxl_mmio_map() differs from the host endianness.
offset is a byte address that is aligned on a word (4 byte) boundary. It must be lower than the MMIO size returned by cxl_get_mmio_size(). The address of the mapped MMIO space is returned by cxl_mmio_ptr().
If the MMIO access fails due to an IO error, a SIGBUS may be sent to the application, which would ordinarily result in the process being terminated. libcxl provides an optional SIGBUS handler, which can be installed with cxl_mmio_install_sigbus_handler().
Installing this signal handler prior to using the MMIO accessor functions will cause them to return -1 and set errno to EIO in the event of an IO error. Additionally, if this handler has NOT been installed, the cxl_mmio_read* functions will raise a SIGBUS in the event that they detect an IO error due to a read of all F's for consistency.
RETURN VALUE¶
On success, 0 is returned. On error, -1 is returned and errno is set appropriately.
ERRORS¶
SEE ALSO¶
cxl(3), cxl_get_mmio_size(3), cxl_mmio_install_sigbus_handler(3), cxl_mmio_map(3), cxl_mmio_ptr(3), cxl_mmio_read64(3), cxl_mmio_unmap(3), cxl_mmio_write32(3), cxl_mmio_write64(3)
2017-05-24 | LIBCXL 1.5 |