mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-26 14:01:50 +01:00 
			
		
		
		
	Signed-off-by: Wolfgang Denk <wd@denx.de> [trini: Fixup common/cmd_io.c] Signed-off-by: Tom Rini <trini@ti.com>
		
			
				
	
	
		
			60 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2002
 | |
|  * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
 | |
|  *
 | |
|  * SPDX-License-Identifier:	GPL-2.0+
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| 
 | |
| /*
 | |
|  * Watchdog test
 | |
|  *
 | |
|  * The test verifies the watchdog timer operation.
 | |
|  * On the first iteration, the test routine disables interrupts and
 | |
|  * makes a 10-second delay. If the system does not reboot during this delay,
 | |
|  * the watchdog timer is not operational and the test fails. If the system
 | |
|  * reboots, on the second iteration the test routine reports a success.
 | |
|  */
 | |
| 
 | |
| #include <post.h>
 | |
| #include <watchdog.h>
 | |
| 
 | |
| #if CONFIG_POST & CONFIG_SYS_POST_WATCHDOG
 | |
| 
 | |
| static ulong gettbl (void)
 | |
| {
 | |
| 	ulong r;
 | |
| 
 | |
|   asm ("mftbl %0":"=r" (r));
 | |
| 
 | |
| 	return r;
 | |
| }
 | |
| 
 | |
| int watchdog_post_test (int flags)
 | |
| {
 | |
| 	if (flags & POST_REBOOT) {
 | |
| 		/* Test passed */
 | |
| 
 | |
| 		return 0;
 | |
| 	} else {
 | |
| 		/* 10-second delay */
 | |
| 		int ints = disable_interrupts ();
 | |
| 		ulong base = gettbl ();
 | |
| 		ulong clk = get_tbclk ();
 | |
| 
 | |
| 		while ((gettbl () - base) / 10 < clk);
 | |
| 
 | |
| 		if (ints)
 | |
| 			enable_interrupts ();
 | |
| 
 | |
| 		/*
 | |
| 		 * If we have reached this point, the watchdog timer
 | |
| 		 * does not work
 | |
| 		 */
 | |
| 		return -1;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| #endif /* CONFIG_POST & CONFIG_SYS_POST_WATCHDOG */
 |