Home | History | Annotate | Download | only in s390x
      1 #include <assert.h>
      2 #include <stdlib.h>
      3 #include <stdio.h>
      4 #include "opcodes.h"
      5 
      6 #define srnmt(b,d) \
      7    ({ \
      8       __asm__ volatile ( "lghi 8," #b "\n\t" \
      9                          SRNMT(8,d) \
     10                          ::: "8"); \
     11    })
     12 
     13 
     14 /* Like srnmt above, except it uses r0 as a base register */
     15 #define srnmt0(d) \
     16    ({ \
     17       __asm__ volatile ( SRNMT(0,d) \
     18                          ::: "0"); \
     19    })
     20 
     21 unsigned
     22 get_dfp_rounding_mode(void)
     23 {
     24    unsigned fpc;
     25 
     26    __asm__ volatile ("stfpc  %0\n\t" : "=m"(fpc));
     27 
     28    return (fpc & 0x70) >> 4;
     29 }
     30 
     31 int main(void)
     32 {
     33    printf("initial rounding mode = %u\n", get_dfp_rounding_mode());
     34 
     35    /* Set basic rounding modes in various ways */
     36    srnmt(1,002);  // 1 + 2 = 3
     37    printf("rounding mode = %u\n", get_dfp_rounding_mode());
     38 
     39    srnmt(2,000);
     40    printf("rounding mode = %u\n", get_dfp_rounding_mode());
     41 
     42    srnmt(0,001);
     43    printf("rounding mode = %u\n", get_dfp_rounding_mode());
     44 
     45    srnmt(0,000);
     46    printf("rounding mode = %u\n", get_dfp_rounding_mode());
     47 
     48    srnmt(7,000);
     49    printf("rounding mode = %u\n", get_dfp_rounding_mode());
     50 
     51    srnmt(0,006);
     52    printf("rounding mode = %u\n", get_dfp_rounding_mode());
     53 
     54    srnmt0(005);
     55    printf("rounding mode = %u\n", get_dfp_rounding_mode());
     56 
     57    srnmt0(004);
     58    printf("rounding mode = %u\n", get_dfp_rounding_mode());
     59 
     60    return 0;
     61 }
     62