 bda0f5bad8
			
		
	
	
	bda0f5bad8
	
	
	
		
			
			This change improves and cleans up the tile console. - We enable HVC_IRQ support on tilegx, with the addition of a new Tilera hypervisor API for tilegx to allow a console IPI. If IPI support is not available we fall back to the previous polling mode. - We simplify the earlyprintk code to use CON_BOOT and eliminate some of the other supporting earlyprintk code. - A new tile_console_write() primitive is used to send output to the console and is factored out of the hvc_tile driver. This lets us support a "sim_console" boot argument to allow using simulator hooks to send output to the "console" as a slightly faster alternative to emulating the hardware more directly. Signed-off-by: Chris Metcalf <cmetcalf@tilera.com> Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
		
			
				
	
	
		
			52 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright 2010 Tilera Corporation. All Rights Reserved.
 | |
|  *
 | |
|  *   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.
 | |
|  *
 | |
|  *   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, GOOD TITLE or
 | |
|  *   NON INFRINGEMENT.  See the GNU General Public License for
 | |
|  *   more details.
 | |
|  */
 | |
| #ifndef _ASM_TILE_SETUP_H
 | |
| #define _ASM_TILE_SETUP_H
 | |
| 
 | |
| 
 | |
| #include <linux/pfn.h>
 | |
| #include <linux/init.h>
 | |
| #include <uapi/asm/setup.h>
 | |
| 
 | |
| /*
 | |
|  * Reserved space for vmalloc and iomap - defined in asm/page.h
 | |
|  */
 | |
| #define MAXMEM_PFN	PFN_DOWN(MAXMEM)
 | |
| 
 | |
| int tile_console_write(const char *buf, int count);
 | |
| void early_panic(const char *fmt, ...);
 | |
| 
 | |
| /* Init-time routine to do tile-specific per-cpu setup. */
 | |
| void setup_cpu(int boot);
 | |
| 
 | |
| /* User-level DMA management functions */
 | |
| void grant_dma_mpls(void);
 | |
| void restrict_dma_mpls(void);
 | |
| 
 | |
| #ifdef CONFIG_HARDWALL
 | |
| /* User-level network management functions */
 | |
| void reset_network_state(void);
 | |
| struct task_struct;
 | |
| void hardwall_switch_tasks(struct task_struct *prev, struct task_struct *next);
 | |
| void hardwall_deactivate_all(struct task_struct *task);
 | |
| int hardwall_ipi_valid(int cpu);
 | |
| 
 | |
| /* Hook hardwall code into changes in affinity. */
 | |
| #define arch_set_cpus_allowed(p, new_mask) do { \
 | |
| 	if (!cpumask_equal(&p->cpus_allowed, new_mask)) \
 | |
| 		hardwall_deactivate_all(p); \
 | |
| } while (0)
 | |
| #endif
 | |
| 
 | |
| #endif /* _ASM_TILE_SETUP_H */
 |