mirror of
https://github.com/antonblanchard/microwatt.git
synced 2026-02-18 13:27:06 +00:00
This comes in two parts: - A generator script which uses LiteX to generate litedram cores along with their init files for various boards (currently Arty and Nexys-video). This comes with configs for arty and nexys_video. - A fusesoc "generator" which uses pre-generated litedram cores The generation process is manual on purpose. This include pre-generated cores for the two above boards. This is done so that one doesn't have to install LiteX to build microwatt. In addition, the generator script or wrapper vhdl tend to break when LiteX changes significantly which happens. This is still rather standalone and hasn't been plumbed into the SoC or the FPGA toplevel files yet. At this point LiteDRAM self-initializes using a built-in VexRiscv "Minimum" core obtained from LiteX and included in this commit. There is some plumbing to generate and cores that are initialized by Microwatt directly but this isn't working yet and so isn't enabled yet. Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
41 lines
1011 B
C
41 lines
1011 B
C
/******************************************************************************
|
|
* Copyright (c) 2004, 2008 IBM Corporation
|
|
* All rights reserved.
|
|
* This program and the accompanying materials
|
|
* are made available under the terms of the BSD License
|
|
* which accompanies this distribution, and is available at
|
|
* http://www.opensource.org/licenses/bsd-license.php
|
|
*
|
|
* Contributors:
|
|
* IBM Corporation - initial implementation
|
|
*****************************************************************************/
|
|
|
|
#define CACHE_LINE_SIZE 128
|
|
|
|
#include <stddef.h>
|
|
|
|
void *memset(void *dest, int c, size_t size);
|
|
void *memset(void *dest, int c, size_t size)
|
|
{
|
|
unsigned char *d = (unsigned char *)dest;
|
|
unsigned long big_c = 0;
|
|
|
|
if (c) {
|
|
big_c = c;
|
|
big_c |= (big_c << 8) | big_c;
|
|
big_c |= (big_c << 16) | big_c;
|
|
big_c |= (big_c << 32) | big_c;
|
|
}
|
|
while (size >= 8 && c == 0) {
|
|
*((unsigned long *)d) = big_c;
|
|
d+=8;
|
|
size-=8;
|
|
}
|
|
|
|
while (size-- > 0) {
|
|
*d++ = (unsigned char)c;
|
|
}
|
|
|
|
return dest;
|
|
}
|