79 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
// SPDX-License-Identifier: GPL-2.0
 | 
						|
/*
 | 
						|
 * Copyright (c) 2014 Google, Inc
 | 
						|
 *
 | 
						|
 * From Coreboot src/lib/ramtest.c
 | 
						|
 */
 | 
						|
 | 
						|
#include <common.h>
 | 
						|
#include <asm/io.h>
 | 
						|
#include <asm/post.h>
 | 
						|
 | 
						|
static void write_phys(unsigned long addr, u32 value)
 | 
						|
{
 | 
						|
#if CONFIG_SSE2
 | 
						|
	asm volatile(
 | 
						|
		"movnti %1, (%0)"
 | 
						|
		: /* outputs */
 | 
						|
		: "r" (addr), "r" (value) /* inputs */
 | 
						|
		: /* clobbers */
 | 
						|
		);
 | 
						|
#else
 | 
						|
	writel(value, addr);
 | 
						|
#endif
 | 
						|
}
 | 
						|
 | 
						|
static u32 read_phys(unsigned long addr)
 | 
						|
{
 | 
						|
	return readl(addr);
 | 
						|
}
 | 
						|
 | 
						|
static void phys_memory_barrier(void)
 | 
						|
{
 | 
						|
#if CONFIG_SSE2
 | 
						|
	/* Needed for movnti */
 | 
						|
	asm volatile(
 | 
						|
		"sfence"
 | 
						|
		:
 | 
						|
		:
 | 
						|
		: "memory"
 | 
						|
	);
 | 
						|
#else
 | 
						|
	asm volatile(""
 | 
						|
		:
 | 
						|
		:
 | 
						|
		: "memory");
 | 
						|
#endif
 | 
						|
}
 | 
						|
 | 
						|
void quick_ram_check(void)
 | 
						|
{
 | 
						|
	int fail = 0;
 | 
						|
	u32 backup;
 | 
						|
 | 
						|
	backup = read_phys(CONFIG_RAMBASE);
 | 
						|
	write_phys(CONFIG_RAMBASE, 0x55555555);
 | 
						|
	phys_memory_barrier();
 | 
						|
	if (read_phys(CONFIG_RAMBASE) != 0x55555555)
 | 
						|
		fail = 1;
 | 
						|
	write_phys(CONFIG_RAMBASE, 0xaaaaaaaa);
 | 
						|
	phys_memory_barrier();
 | 
						|
	if (read_phys(CONFIG_RAMBASE) != 0xaaaaaaaa)
 | 
						|
		fail = 1;
 | 
						|
	write_phys(CONFIG_RAMBASE, 0x00000000);
 | 
						|
	phys_memory_barrier();
 | 
						|
	if (read_phys(CONFIG_RAMBASE) != 0x00000000)
 | 
						|
		fail = 1;
 | 
						|
	write_phys(CONFIG_RAMBASE, 0xffffffff);
 | 
						|
	phys_memory_barrier();
 | 
						|
	if (read_phys(CONFIG_RAMBASE) != 0xffffffff)
 | 
						|
		fail = 1;
 | 
						|
 | 
						|
	write_phys(CONFIG_RAMBASE, backup);
 | 
						|
	if (fail) {
 | 
						|
		post_code(POST_RAM_FAILURE);
 | 
						|
		panic("RAM INIT FAILURE!\n");
 | 
						|
	}
 | 
						|
	phys_memory_barrier();
 | 
						|
}
 |