mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-09 17:38:00 +00:00
uxutils.c: move some definitions into a header file.
If the autoconf/ifdef system ends up taking the trivial branch through all the Arm-architecture ifdefs, then we define the always-fail version of getauxval as a 'static inline' function, and then (because none of our desired HWCAP_FOO values is defined at all) never call it. This leads to a compiler warning because we defined a static function and never called it - i.e. at the default -Werror, a build failure. Of course it's perfectly sensible to define a static inline function that never gets called! Header files do it all the time, and nobody is expected to ensure that if they include a header file then they take care to refer to every static inline function it defines. But if the definition is in the _source_ file rather than a header file, then clang (in particular on macOS) will give a warning. So the easy solution is to move the inline definitions of getauxval into a header file, which suppresses the warning without requiring me to faff about with further ifdefs to make the definitions conditional on at least one use.
This commit is contained in:
parent
e9e6c03c6e
commit
d13adebe1a
@ -1,36 +1,10 @@
|
||||
#include "putty.h"
|
||||
#include "ssh.h"
|
||||
|
||||
#include "uxutils.h"
|
||||
|
||||
#if defined __arm__ || defined __aarch64__
|
||||
|
||||
#ifdef HAVE_SYS_TYPES_H
|
||||
#include <sys/types.h>
|
||||
#endif
|
||||
|
||||
#ifdef HAVE_SYS_AUXV_H
|
||||
#include <sys/auxv.h>
|
||||
#endif
|
||||
|
||||
#ifdef HAVE_ASM_HWCAP_H
|
||||
#include <asm/hwcap.h>
|
||||
#endif
|
||||
|
||||
#if defined HAVE_GETAUXVAL
|
||||
/* No code needed: getauxval has just the API we want already */
|
||||
#elif defined HAVE_ELF_AUX_INFO
|
||||
/* Implement the simple getauxval API in terms of FreeBSD elf_aux_info */
|
||||
static inline u_long getauxval(int which)
|
||||
{
|
||||
u_long toret;
|
||||
if (elf_aux_info(which, &toret, sizeof(toret)) != 0)
|
||||
return 0; /* elf_aux_info didn't work */
|
||||
return toret;
|
||||
}
|
||||
#else
|
||||
/* Implement a stub getauxval which returns no capabilities */
|
||||
static inline u_long getauxval(int which) { return 0; }
|
||||
#endif
|
||||
|
||||
bool platform_aes_hw_available(void)
|
||||
{
|
||||
#if defined HWCAP_AES
|
||||
|
45
unix/uxutils.h
Normal file
45
unix/uxutils.h
Normal file
@ -0,0 +1,45 @@
|
||||
/*
|
||||
* uxutils.h: header included only by uxutils.c.
|
||||
*
|
||||
* The only reason this is a header file instead of a source file is
|
||||
* so that I can define 'static inline' functions which may or may not
|
||||
* be used, without provoking a compiler warning when I turn out not
|
||||
* to use them in the subsequent source file.
|
||||
*/
|
||||
|
||||
#ifndef PUTTY_UXUTILS_H
|
||||
#define PUTTY_UXUTILS_H
|
||||
|
||||
#if defined __arm__ || defined __aarch64__
|
||||
|
||||
#ifdef HAVE_SYS_TYPES_H
|
||||
#include <sys/types.h>
|
||||
#endif
|
||||
|
||||
#ifdef HAVE_SYS_AUXV_H
|
||||
#include <sys/auxv.h>
|
||||
#endif
|
||||
|
||||
#ifdef HAVE_ASM_HWCAP_H
|
||||
#include <asm/hwcap.h>
|
||||
#endif
|
||||
|
||||
#if defined HAVE_GETAUXVAL
|
||||
/* No code needed: getauxval has just the API we want already */
|
||||
#elif defined HAVE_ELF_AUX_INFO
|
||||
/* Implement the simple getauxval API in terms of FreeBSD elf_aux_info */
|
||||
static inline u_long getauxval(int which)
|
||||
{
|
||||
u_long toret;
|
||||
if (elf_aux_info(which, &toret, sizeof(toret)) != 0)
|
||||
return 0; /* elf_aux_info didn't work */
|
||||
return toret;
|
||||
}
|
||||
#else
|
||||
/* Implement a stub getauxval which returns no capabilities */
|
||||
static inline u_long getauxval(int which) { return 0; }
|
||||
#endif
|
||||
|
||||
#endif /* defined __arm__ || defined __aarch64__ */
|
||||
|
||||
#endif /* PUTTY_UXUTILS_H */
|
Loading…
Reference in New Issue
Block a user