summaryrefslogtreecommitdiff
path: root/libc/sysdeps/linux/xtensa/bits/xtensa-config.h
blob: bfcd571d26e24705d1e20720d26c45ef5f45a498 (plain)
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
65
66
67
68
69
70
71
72
/* Xtensa configuration settings.
   Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007
   Free Software Foundation, Inc.
   Contributed by Bob Wilson (bwilson@tensilica.com) at Tensilica.

   The GNU C Library is free software; you can redistribute it and/or
   modify it under the terms of the GNU Lesser General Public
   License as published by the Free Software Foundation; either
   version 2.1 of the License, or (at your option) any later version.

   The GNU C Library is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   Lesser General Public License for more details.

   You should have received a copy of the GNU Lesser General Public
   License along with the GNU C Library; if not, see
   <http://www.gnu.org/licenses/>.  */

#ifndef XTENSA_CONFIG_H
#define XTENSA_CONFIG_H

/* The macros defined here match those with the same names in the Xtensa
   compile-time HAL (Hardware Abstraction Layer).  Please refer to the
   Xtensa System Software Reference Manual for documentation of these
   macros.  */

/* The following macros reflect the default expectations for Xtensa
   processor configurations that can run glibc.  If you want to try
   building glibc for an Xtensa configuration that is missing these
   options, you will at least need to change the values of these
   macros.  */

#undef XCHAL_HAVE_NSA
#ifdef __XCHAL_HAVE_NSA
#define XCHAL_HAVE_NSA			__XCHAL_HAVE_NSA
#else
#define XCHAL_HAVE_NSA			1
#endif

#undef XCHAL_HAVE_LOOPS
#ifdef __XCHAL_HAVE_LOOPS
#define XCHAL_HAVE_LOOPS		__XCHAL_HAVE_LOOPS
#else
#define XCHAL_HAVE_LOOPS		1
#endif

/* Assume the maximum number of AR registers.  This currently only affects
   the __window_spill function, and it is always safe to flush extra.  */

#undef XCHAL_NUM_AREGS
#ifdef __XCHAL_NUM_AREGS
#define XCHAL_NUM_AREGS			__XCHAL_NUM_AREGS
#else
#define XCHAL_NUM_AREGS			64
#endif

#undef XCHAL_HAVE_S32C1I
#ifdef __XCHAL_HAVE_S32C1I
#define XCHAL_HAVE_S32C1I		__XCHAL_HAVE_S32C1I
#else
#define XCHAL_HAVE_S32C1I		1
#endif

#undef XCHAL_HAVE_EXCLUSIVE
#ifdef __XCHAL_HAVE_EXCLUSIVE
#define XCHAL_HAVE_EXCLUSIVE		__XCHAL_HAVE_EXCLUSIVE
#else
#define XCHAL_HAVE_EXCLUSIVE		0
#endif

#endif /* !XTENSA_CONFIG_H */