mirror of
				https://github.com/AetherDroid/android_kernel_samsung_on5xelte.git
				synced 2025-10-31 08:08:51 +01:00 
			
		
		
		
	Fixed MTP to work with TWRP
This commit is contained in:
		
						commit
						f6dfaef42e
					
				
					 50820 changed files with 20846062 additions and 0 deletions
				
			
		
							
								
								
									
										79
									
								
								arch/openrisc/include/asm/syscall.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								arch/openrisc/include/asm/syscall.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,79 @@ | |||
| /*
 | ||||
|  * OpenRISC Linux | ||||
|  * | ||||
|  * Linux architectural port borrowing liberally from similar works of | ||||
|  * others.  All original copyrights apply as per the original source | ||||
|  * declaration. | ||||
|  * | ||||
|  * OpenRISC implementation: | ||||
|  * Copyright (C) 2003 Matjaz Breskvar <phoenix@bsemi.com> | ||||
|  * Copyright (C) 2010-2011 Jonas Bonn <jonas@southpole.se> | ||||
|  * et al. | ||||
|  * | ||||
|  * 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; either version 2 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  */ | ||||
| 
 | ||||
| #ifndef __ASM_OPENRISC_SYSCALL_H__ | ||||
| #define __ASM_OPENRISC_SYSCALL_H__ | ||||
| 
 | ||||
| #include <uapi/linux/audit.h> | ||||
| #include <linux/err.h> | ||||
| #include <linux/sched.h> | ||||
| 
 | ||||
| static inline int | ||||
| syscall_get_nr(struct task_struct *task, struct pt_regs *regs) | ||||
| { | ||||
| 	return regs->orig_gpr11; | ||||
| } | ||||
| 
 | ||||
| static inline void | ||||
| syscall_rollback(struct task_struct *task, struct pt_regs *regs) | ||||
| { | ||||
| 	regs->gpr[11] = regs->orig_gpr11; | ||||
| } | ||||
| 
 | ||||
| static inline long | ||||
| syscall_get_error(struct task_struct *task, struct pt_regs *regs) | ||||
| { | ||||
| 	return IS_ERR_VALUE(regs->gpr[11]) ? regs->gpr[11] : 0; | ||||
| } | ||||
| 
 | ||||
| static inline long | ||||
| syscall_get_return_value(struct task_struct *task, struct pt_regs *regs) | ||||
| { | ||||
| 	return regs->gpr[11]; | ||||
| } | ||||
| 
 | ||||
| static inline void | ||||
| syscall_set_return_value(struct task_struct *task, struct pt_regs *regs, | ||||
| 			 int error, long val) | ||||
| { | ||||
| 	regs->gpr[11] = (long) error ?: val; | ||||
| } | ||||
| 
 | ||||
| static inline void | ||||
| syscall_get_arguments(struct task_struct *task, struct pt_regs *regs, | ||||
| 		      unsigned int i, unsigned int n, unsigned long *args) | ||||
| { | ||||
| 	BUG_ON(i + n > 6); | ||||
| 
 | ||||
| 	memcpy(args, ®s->gpr[3 + i], n * sizeof(args[0])); | ||||
| } | ||||
| 
 | ||||
| static inline void | ||||
| syscall_set_arguments(struct task_struct *task, struct pt_regs *regs, | ||||
| 		      unsigned int i, unsigned int n, const unsigned long *args) | ||||
| { | ||||
| 	BUG_ON(i + n > 6); | ||||
| 
 | ||||
| 	memcpy(®s->gpr[3 + i], args, n * sizeof(args[0])); | ||||
| } | ||||
| 
 | ||||
| static inline int syscall_get_arch(void) | ||||
| { | ||||
| 	return AUDIT_ARCH_OPENRISC; | ||||
| } | ||||
| #endif | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 awab228
						awab228