36 lines
		
	
	
		
			1018 B
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			1018 B
		
	
	
	
		
			C
		
	
	
	
/*
 | 
						|
 * (C) Copyright 2012 Stephen Warren
 | 
						|
 *
 | 
						|
 * See file CREDITS for list of people who contributed to this
 | 
						|
 * project.
 | 
						|
 *
 | 
						|
 * This program is free software; you can redistribute it and/or
 | 
						|
 * modify it under the terms of the GNU General Public License
 | 
						|
 * version 2 as published by the Free Software Foundation.
 | 
						|
 *
 | 
						|
 * 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 <common.h>
 | 
						|
#include <asm/io.h>
 | 
						|
#include <asm/arch/wdog.h>
 | 
						|
 | 
						|
#define RESET_TIMEOUT 10
 | 
						|
 | 
						|
void reset_cpu(ulong addr)
 | 
						|
{
 | 
						|
	struct bcm2835_wdog_regs *regs =
 | 
						|
		(struct bcm2835_wdog_regs *)BCM2835_WDOG_PHYSADDR;
 | 
						|
	uint32_t rstc;
 | 
						|
 | 
						|
	rstc = readl(®s->rstc);
 | 
						|
	rstc &= ~BCM2835_WDOG_RSTC_WRCFG_MASK;
 | 
						|
	rstc |= BCM2835_WDOG_RSTC_WRCFG_FULL_RESET;
 | 
						|
 | 
						|
	writel(BCM2835_WDOG_PASSWORD | RESET_TIMEOUT, ®s->wdog);
 | 
						|
	writel(BCM2835_WDOG_PASSWORD | rstc, ®s->rstc);
 | 
						|
}
 |