diff options
author | Thomas Heijligen <thomas.heijligen@secunet.com> | 2022-02-19 21:17:44 +0100 |
---|---|---|
committer | Nico Huber <nico.h@gmx.de> | 2022-04-12 09:55:45 +0000 |
commit | 6272c71fbbfb26ebde9954708f74f875c083f822 (patch) | |
tree | b63df2390c6826bb19022772267a48557266f784 /hwaccess_endian_big.c | |
parent | b94a5a21c34877082477af7a7f29f952f5364944 (diff) | |
download | flashrom-6272c71fbbfb26ebde9954708f74f875c083f822.tar.gz flashrom-6272c71fbbfb26ebde9954708f74f875c083f822.tar.bz2 flashrom-6272c71fbbfb26ebde9954708f74f875c083f822.zip |
hwaccess: replace macros by C code
Split the code for endian conversion into separate files for big and
little endian. The buildsystem selects the correct file for the used
endianness. Replace the swab macros with `static inline` c functions.
Define macros for returning the same or swapped value. Call those macros
in the endian specific files.
Change-Id: I86d38d816b37c283279c485fac8027f8fb94364a
Signed-off-by: Thomas Heijligen <thomas.heijligen@secunet.com>
Reviewed-on: https://review.coreboot.org/c/flashrom/+/62898
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Nico Huber <nico.h@gmx.de>
Diffstat (limited to 'hwaccess_endian_big.c')
-rw-r--r-- | hwaccess_endian_big.c | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/hwaccess_endian_big.c b/hwaccess_endian_big.c new file mode 100644 index 00000000..1f7b5a37 --- /dev/null +++ b/hwaccess_endian_big.c @@ -0,0 +1,42 @@ +/* + * This file is part of the flashrom project. + * + * Copyright (C) 2022 secunet Security Networks AG + * (written by Thomas Heijligen <thomas.heijligen@secunet.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 "hwaccess.h" + +/* convert cpu native endian to little endian */ +___return_swapped(cpu_to_le, 8) +___return_swapped(cpu_to_le, 16) +___return_swapped(cpu_to_le, 32) +___return_swapped(cpu_to_le, 64) + +/* convert cpu native endian to big endian */ +___return_same(cpu_to_be, 8) +___return_same(cpu_to_be, 16) +___return_same(cpu_to_be, 32) +___return_same(cpu_to_be, 64) + +/* convert little endian to cpu native endian */ +___return_swapped(le_to_cpu, 8) +___return_swapped(le_to_cpu, 16) +___return_swapped(le_to_cpu, 32) +___return_swapped(le_to_cpu, 64) + +/* convert big endian to cpu native endian */ +___return_same(be_to_cpu, 8) +___return_same(be_to_cpu, 16) +___return_same(be_to_cpu, 32) +___return_same(be_to_cpu, 64) |