about summary refs log tree commit diff
path: root/sysdeps/riscv/preconfigure.ac
blob: a5c30e0dbfc452e8f607bb18d761c55d7db1a356 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
GLIBC_PROVIDES[]dnl See aclocal.m4 in the top level source directory.
# Local preconfigure fragment for sysdeps/riscv

case "$machine" in
riscv*)
    xlen=`$CC $CFLAGS $CPPFLAGS -E -dM -xc /dev/null | sed -n 's/^#define __riscv_xlen \(.*\)/\1/p'`
    flen=`$CC $CFLAGS $CPPFLAGS -E -dM -xc /dev/null | sed -n 's/^#define __riscv_flen \(.*\)/\1/p'`
    float_abi=`$CC $CFLAGS $CPPFLAGS -E -dM -xc /dev/null | sed -n 's/^#define __riscv_float_abi_\([^ ]*\) .*/\1/p'`
    atomic=`$CC $CFLAGS $CPPFLAGS -E -dM -xc /dev/null | grep '#define __riscv_atomic' | cut -d' ' -f2`

    case "$xlen" in
    64 | 32)
	;;
    *)
	AC_MSG_ERROR([Unable to determine XLEN], [1])
	;;
    esac

    case "$flen" in
    64)
	float_machine=rvd
	with_fp_cond=1
	;;
    32)
	AC_MSG_ERROR([glibc does not yet support systems with the F but not D extensions], 1)
	;;
    "")
	with_fp_cond=0
	;;
    *)
	AC_MSG_ERROR([Unable to determine FLEN], [1])
	;;
    esac

    case "$float_abi" in
    soft)
	abi_flen=0
	;;
    single)
	AC_MSG_ERROR([glibc does not yet support the single floating-point ABI], [1])
	;;
    double)
	abi_flen=64
	;;
    *)
	AC_MSG_ERROR([Unable to determine floating-point ABI], [1])
	;;
    esac

    case "$atomic" in
    __riscv_atomic)
	;;
    *)
	AC_MSG_ERROR([glibc requires the A extension], [1])
	;;
    esac

    base_machine=riscv
    machine=riscv/rv$xlen/$float_machine

    AC_DEFINE_UNQUOTED([RISCV_ABI_XLEN], [$xlen])
    AC_DEFINE_UNQUOTED([RISCV_ABI_FLEN], [$abi_flen])
    ;;
esac