99f83bbad4
As discussed on the mailing list and voted upon, the coreboot project is going to move the majority of copyrights out of the headers and into an AUTHORS file. This will happen a bit at a time, as we'll be unifying license headers at the same time. Additional cleanup - Unify "Inc" to "Inc." and "LLC." to "LLC" Signed-off-by: Martin Roth <martin@coreboot.org> Change-Id: Ie03a3ce1f6085494bd5f38da76e2467970cf301a Reviewed-on: https://review.coreboot.org/c/coreboot/+/35430 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Patrick Georgi <pgeorgi@google.com>
53 lines
1.5 KiB
C
53 lines
1.5 KiB
C
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* 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; version 2 of the License.
|
|
*
|
|
* 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 <assert.h>
|
|
#include <device/mmio.h>
|
|
|
|
/* Helper functions for various MMIO access patterns. */
|
|
|
|
void buffer_from_fifo32(void *buffer, size_t size, void *fifo,
|
|
int fifo_stride, int fifo_width)
|
|
{
|
|
u8 *p = buffer;
|
|
int i, j;
|
|
|
|
assert(fifo_width > 0 && fifo_width <= sizeof(u32) &&
|
|
fifo_stride % sizeof(u32) == 0);
|
|
|
|
for (i = 0; i < size; i += fifo_width, fifo += fifo_stride) {
|
|
u32 val = read32(fifo);
|
|
for (j = 0; j < MIN(size - i, fifo_width); j++)
|
|
*p++ = (u8)(val >> (j * 8));
|
|
}
|
|
}
|
|
|
|
void buffer_to_fifo32_prefix(void *buffer, u32 prefix, int prefsz, size_t size,
|
|
void *fifo, int fifo_stride, int fifo_width)
|
|
{
|
|
u8 *p = buffer;
|
|
int i, j = prefsz;
|
|
|
|
assert(fifo_width > 0 && fifo_width <= sizeof(u32) &&
|
|
fifo_stride % sizeof(u32) == 0 && prefsz <= fifo_width);
|
|
|
|
uint32_t val = prefix;
|
|
for (i = 0; i < size; i += fifo_width, fifo += fifo_stride) {
|
|
for (; j < MIN(size - i, fifo_width); j++)
|
|
val |= *p++ << (j * 8);
|
|
write32(fifo, val);
|
|
val = 0;
|
|
j = 0;
|
|
}
|
|
|
|
}
|