1
0
mirror of https://review.coreboot.org/flashrom.git synced 2025-04-27 15:12:36 +02:00

hwaccess: add endianness converting deserialization functions

Add functions like
  `uint32_t read_le32(const void *base, size_t offset);`
Read a 32 bit unsigned from a base with an offset.
Having prototypes and a macro generated implementation makes it easier
to read, understand and spot errors in one of them.

Change-Id: Idde177acf8bc5f94cd046b6539dc31532c98e452
Signed-off-by: Thomas Heijligen <thomas.heijligen@secunet.com>
Reviewed-on: https://review.coreboot.org/c/flashrom/+/31016
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Angel Pons <th3fanbus@gmail.com>
Reviewed-by: Nico Huber <nico.h@gmx.de>
This commit is contained in:
Thomas Heijligen 2022-02-19 22:31:32 +01:00 committed by Nico Huber
parent c456944170
commit 82604bd738
4 changed files with 58 additions and 1 deletions

View File

@ -378,7 +378,7 @@ CHIP_OBJS = jedec.o stm50.o w39.o w29ee011.o \
# Library code.
LIB_OBJS = libflashrom.o layout.o flashrom.o udelay.o programmer.o programmer_table.o \
helpers.o ich_descriptors.o fmap.o platform/endian_$(ENDIAN).o
helpers.o ich_descriptors.o fmap.o platform/endian_$(ENDIAN).o platform/memaccess.o
###############################################################################

View File

@ -135,6 +135,8 @@ if cc.check_header('sys/utsname.h')
add_project_arguments('-DHAVE_UTSNAME=1', language : 'c')
endif
srcs += 'platform/memaccess.c'
if host_machine.endian() == 'little'
srcs += 'platform/endian_little.c'
add_project_arguments('-D__FLASHROM_LITTLE_ENDIAN__=1', language : 'c')

View File

@ -22,6 +22,7 @@
#ifndef __PLATFORM_H__
#define __PLATFORM_H__ 1
#include <stddef.h>
#include <stdint.h>
/* swap bytes */
@ -100,4 +101,16 @@ uint16_t be_to_cpu16(uint16_t value);
uint32_t be_to_cpu32(uint32_t value);
uint64_t be_to_cpu64(uint64_t value);
/* read value from base at offset in little endian */
uint8_t read_le8 (const void *base, size_t offset);
uint16_t read_le16(const void *base, size_t offset);
uint32_t read_le32(const void *base, size_t offset);
uint64_t read_le64(const void *base, size_t offset);
/* read value from base at offset in big endian */
uint8_t read_be8 (const void *base, size_t offset);
uint16_t read_be16(const void *base, size_t offset);
uint32_t read_be32(const void *base, size_t offset);
uint64_t read_be64(const void *base, size_t offset);
#endif /* !__PLATFORM_H__ */

42
platform/memaccess.c Normal file
View File

@ -0,0 +1,42 @@
/*
* This file is part of the flashrom project.
*
* Copyright (C) 2016 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 "../platform.h"
/*
* macro to return endian aware read function
*
* `___read(le, 8)`
* expands to
* `uint8_t read_le8 (const void *const base, const size_t offset)
* { return le_to_cpu8 (*(uint8_t *)((uintptr_t)base + offset)); }`
*/
#define ___read(endian, bits) \
uint##bits##_t read_##endian##bits (const void *const base, const size_t offset) \
{ return endian##_to_cpu##bits (*(uint##bits##_t *)((uintptr_t)base + offset)); }
/* read value from base at offset in little endian */
___read(le, 8)
___read(le, 16)
___read(le, 32)
___read(le, 64)
/* read value from base at offset in big endian */
___read(be, 8)
___read(be, 16)
___read(be, 32)
___read(be, 64)