78 lines
		
	
	
	
		
			2.1 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			78 lines
		
	
	
	
		
			2.1 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
|   | /*
 | ||
|  |  * Copyright 2013 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. | ||
|  |  */ | ||
|  | 
 | ||
|  | /* This file is machine-generated; DO NOT EDIT! */ | ||
|  | #include "gxio/iorpc_uart.h"
 | ||
|  | 
 | ||
|  | struct cfg_interrupt_param { | ||
|  | 	union iorpc_interrupt interrupt; | ||
|  | }; | ||
|  | 
 | ||
|  | int gxio_uart_cfg_interrupt(gxio_uart_context_t *context, int inter_x, | ||
|  | 			    int inter_y, int inter_ipi, int inter_event) | ||
|  | { | ||
|  | 	struct cfg_interrupt_param temp; | ||
|  | 	struct cfg_interrupt_param *params = &temp; | ||
|  | 
 | ||
|  | 	params->interrupt.kernel.x = inter_x; | ||
|  | 	params->interrupt.kernel.y = inter_y; | ||
|  | 	params->interrupt.kernel.ipi = inter_ipi; | ||
|  | 	params->interrupt.kernel.event = inter_event; | ||
|  | 
 | ||
|  | 	return hv_dev_pwrite(context->fd, 0, (HV_VirtAddr) params, | ||
|  | 			     sizeof(*params), GXIO_UART_OP_CFG_INTERRUPT); | ||
|  | } | ||
|  | 
 | ||
|  | EXPORT_SYMBOL(gxio_uart_cfg_interrupt); | ||
|  | 
 | ||
|  | struct get_mmio_base_param { | ||
|  | 	HV_PTE base; | ||
|  | }; | ||
|  | 
 | ||
|  | int gxio_uart_get_mmio_base(gxio_uart_context_t *context, HV_PTE *base) | ||
|  | { | ||
|  | 	int __result; | ||
|  | 	struct get_mmio_base_param temp; | ||
|  | 	struct get_mmio_base_param *params = &temp; | ||
|  | 
 | ||
|  | 	__result = | ||
|  | 	    hv_dev_pread(context->fd, 0, (HV_VirtAddr) params, sizeof(*params), | ||
|  | 			 GXIO_UART_OP_GET_MMIO_BASE); | ||
|  | 	*base = params->base; | ||
|  | 
 | ||
|  | 	return __result; | ||
|  | } | ||
|  | 
 | ||
|  | EXPORT_SYMBOL(gxio_uart_get_mmio_base); | ||
|  | 
 | ||
|  | struct check_mmio_offset_param { | ||
|  | 	unsigned long offset; | ||
|  | 	unsigned long size; | ||
|  | }; | ||
|  | 
 | ||
|  | int gxio_uart_check_mmio_offset(gxio_uart_context_t *context, | ||
|  | 				unsigned long offset, unsigned long size) | ||
|  | { | ||
|  | 	struct check_mmio_offset_param temp; | ||
|  | 	struct check_mmio_offset_param *params = &temp; | ||
|  | 
 | ||
|  | 	params->offset = offset; | ||
|  | 	params->size = size; | ||
|  | 
 | ||
|  | 	return hv_dev_pwrite(context->fd, 0, (HV_VirtAddr) params, | ||
|  | 			     sizeof(*params), GXIO_UART_OP_CHECK_MMIO_OFFSET); | ||
|  | } | ||
|  | 
 | ||
|  | EXPORT_SYMBOL(gxio_uart_check_mmio_offset); |