getisax - extract valid instruction set extensions
#include <sys/auxv.h> uint_t getisax(uint32_t * array, uint_t n);
The getisax() function sets the vector array of n 32–bit integers to contain the bits from the AV_xxx_yyy namespace of the given instruction set architecture.
Values for AV_xxx_yyy for SPARC and SPARCV9, and their associated descriptions, can be found in sys/auxv_SPARC.h.
Values for AV_xxx_yyy for i386 and AMD64, and their associated descriptions, can be found in sys/auxv_386.h.
The getisax() function returns the maximum number of array elements that contain non-zero values. This may be more than 'n'. The value n may be zero and array may be NULL, in which case the number of array elements will be returned and array will not be accessed.
In the following example, if the message is written, the SSE2 instruction set is present and fully supported by the operating system.
uint_t n = getisax(NULL, 0); uint_t *ui = calloc(n, sizeof(uint_t)); (void) getisax(ui, n); if (ui[AV_HW1_IDX] & AV_386_SSE2) { printf("SSE2 instruction set extension is present.\n"); }
See attributes(7) for descriptions of the following attributes:
|
isainfo(1), ld(1), pargs(1), attributes(7)
Oracle Solaris 11.4 Linkers and Libraries Guide
Instruction extensions to the native platform ABI are also represented by hardware capabilities. For a complete description of hardware capabilities, refer to the Oracle Solaris 11.4 Linkers and Libraries Guide.