[PATCH v3 2/6] Define some utility functions for using the fwts_architecture enum
Alex Hung
alex.hung at canonical.com
Wed Jan 20 03:20:48 UTC 2016
On 2016-01-19 08:26 AM, Al Stone wrote:
> Add in some helper functions to make it easier to use the enum for
> fwts_architecture.
>
> Signed-off-by: Al Stone <al.stone at linaro.org>
> ---
> src/lib/include/fwts_arch.h | 4 +++
> src/lib/src/Makefile.am | 1 +
> src/lib/src/fwts_arch.c | 88 +++++++++++++++++++++++++++++++++++++++++++++
> 3 files changed, 93 insertions(+)
> create mode 100644 src/lib/src/fwts_arch.c
>
> diff --git a/src/lib/include/fwts_arch.h b/src/lib/include/fwts_arch.h
> index 3fc03fc..a950ea7 100644
> --- a/src/lib/include/fwts_arch.h
> +++ b/src/lib/include/fwts_arch.h
> @@ -34,4 +34,8 @@ typedef enum {
> FWTS_ARCH_OTHER
> } fwts_architecture;
>
> +extern fwts_architecture fwts_arch_get_host(void);
> +extern fwts_architecture fwts_arch_get_arch(const char *name);
> +extern const char *fwts_arch_names(void);
> +
> #endif
> diff --git a/src/lib/src/Makefile.am b/src/lib/src/Makefile.am
> index c16f129..5d63804 100644
> --- a/src/lib/src/Makefile.am
> +++ b/src/lib/src/Makefile.am
> @@ -28,6 +28,7 @@ libfwts_la_SOURCES = \
> fwts_acpi.c \
> fwts_acpid.c \
> fwts_alloc.c \
> + fwts_arch.c \
> fwts_args.c \
> fwts_backtrace.c \
> fwts_battery.c \
> diff --git a/src/lib/src/fwts_arch.c b/src/lib/src/fwts_arch.c
> new file mode 100644
> index 0000000..558458c
> --- /dev/null
> +++ b/src/lib/src/fwts_arch.c
> @@ -0,0 +1,84 @@
> +/*
> + * Copyright (C) 2016, Al Stone <ahs3 at redhat.com>
> + *
> + * This program is free software; you can redistribute it and/or
> + * modify it under the terms of the GNU General Public License
> + * as published by the Free Software Foundation; either version 2
> + * of the License, or (at your option) any later version.
> + *
> + * This program 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 General Public License for more details.
> + *
> + */
> +
> +#include <stdlib.h>
> +#include <sys/utsname.h>
> +
> +#include "fwts.h"
> +
> +struct fwts_arch_info {
> + fwts_architecture arch;
> + char *name;
> +};
> +
> +static const struct fwts_arch_info arch_info[] = {
> + { FWTS_ARCH_X86, "x86" },
> + { FWTS_ARCH_X86, "x86_32" },
> + { FWTS_ARCH_X86, "x86_64" },
> + { FWTS_ARCH_IA64, "ia64" },
> + { FWTS_ARCH_ARM64, "arm64" },
> + { FWTS_ARCH_ARM64, "aarch64" },
> + { FWTS_ARCH_OTHER, "other" }
> +};
> +
> +static char *arch_names;
> +
> +static fwts_architecture __fwts_arch_get_arch(const char *name)
> +{
> + const struct fwts_arch_info *ptr;
> +
> + for (ptr = arch_info; ptr->arch != FWTS_ARCH_OTHER; ptr++)
> + if (!strcmp(ptr->name, name))
> + return ptr->arch;
> +
> + return FWTS_ARCH_OTHER;
> +}
> +
> +fwts_architecture fwts_arch_get_host(void)
> +{
> + struct utsname buf;
> +
> + if (uname(&buf))
> + return FWTS_ARCH_OTHER;
> +
> + return __fwts_arch_get_arch(buf.machine);
> +}
> +
> +fwts_architecture fwts_arch_get_arch(const char *name)
> +{
> + return __fwts_arch_get_arch(name);
> +}
> +
> +const char *fwts_arch_names(void)
> +{
> + const struct fwts_arch_info *ptr;
> + size_t len;
> +
> + if (arch_names)
> + return arch_names;
> +
> + for (ptr = arch_info, len = 0; ptr->arch != FWTS_ARCH_OTHER; ptr++)
> + len += strlen(ptr->name) + 1;
> +
> + arch_names = calloc(len, 1);
> + if (arch_names) {
> + for (ptr = arch_info; ptr->arch != FWTS_ARCH_OTHER; ptr++) {
> + strcat(arch_names, ptr->name);
> + strcat(arch_names, " ");
> + }
> + }
> +
> + return arch_names;
> +}
>
Acked-by: Alex Hung <alex.hung at canonical.com>
More information about the fwts-devel
mailing list