diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-07-24 12:55:45 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-07-24 12:55:45 -0400 |
commit | 21c7075fa5a756f1c95f6b463ff42cd320cc0301 (patch) | |
tree | 69524dd01fbebe662abe3b7296664592d3ce562b | |
parent | ff0c4ad2c3a75ccfe6adca916e50804eb45bb2d9 (diff) | |
parent | 73b7d40ff1bcd44b4245c2714b88cf872fe44685 (diff) |
Merge branch 'for-linus' of git://git390.marist.edu/pub/scm/linux-2.6
* 'for-linus' of git://git390.marist.edu/pub/scm/linux-2.6: (21 commits)
[S390] use siginfo for sigtrap signals
[S390] dasd: add enhanced DASD statistics interface
[S390] kvm: make sigp emerg smp capable
[S390] disable cpu measurement alerts on a dying cpu
[S390] initial cr0 bits
[S390] iucv cr0 enablement bit
[S390] race safe external interrupt registration
[S390] remove tape block docu
[S390] ap: toleration support for ap device type 10
[S390] cleanup program check handler prototypes
[S390] remove kvm mmu reload on s390
[S390] Use gmap translation for accessing guest memory
[S390] use gmap address spaces for kvm guest images
[S390] kvm guest address space mapping
[S390] fix s390 assembler code alignments
[S390] move sie code to entry.S
[S390] kvm: handle tprot intercepts
[S390] qdio: clear shared DSCI before scheduling the queue handler
[S390] reference bit testing for unmapped pages
[S390] irqs: Do not trace arch_local_{*,irq_*} functions
...
60 files changed, 2091 insertions, 1280 deletions
diff --git a/Documentation/s390/TAPE b/Documentation/s390/TAPE deleted file mode 100644 index c639aa5603ff..000000000000 --- a/Documentation/s390/TAPE +++ /dev/null | |||
@@ -1,122 +0,0 @@ | |||
1 | Channel attached Tape device driver | ||
2 | |||
3 | -----------------------------WARNING----------------------------------------- | ||
4 | This driver is considered to be EXPERIMENTAL. Do NOT use it in | ||
5 | production environments. Feel free to test it and report problems back to us. | ||
6 | ----------------------------------------------------------------------------- | ||
7 | |||
8 | The LINUX for zSeries tape device driver manages channel attached tape drives | ||
9 | which are compatible to IBM 3480 or IBM 3490 magnetic tape subsystems. This | ||
10 | includes various models of these devices (for example the 3490E). | ||
11 | |||
12 | |||
13 | Tape driver features | ||
14 | |||
15 | The device driver supports a maximum of 128 tape devices. | ||
16 | No official LINUX device major number is assigned to the zSeries tape device | ||
17 | driver. It allocates major numbers dynamically and reports them on system | ||
18 | startup. | ||
19 | Typically it will get major number 254 for both the character device front-end | ||
20 | and the block device front-end. | ||
21 | |||
22 | The tape device driver needs no kernel parameters. All supported devices | ||
23 | present are detected on driver initialization at system startup or module load. | ||
24 | The devices detected are ordered by their subchannel numbers. The device with | ||
25 | the lowest subchannel number becomes device 0, the next one will be device 1 | ||
26 | and so on. | ||
27 | |||
28 | |||
29 | Tape character device front-end | ||
30 | |||
31 | The usual way to read or write to the tape device is through the character | ||
32 | device front-end. The zSeries tape device driver provides two character devices | ||
33 | for each physical device -- the first of these will rewind automatically when | ||
34 | it is closed, the second will not rewind automatically. | ||
35 | |||
36 | The character device nodes are named /dev/rtibm0 (rewinding) and /dev/ntibm0 | ||
37 | (non-rewinding) for the first device, /dev/rtibm1 and /dev/ntibm1 for the | ||
38 | second, and so on. | ||
39 | |||
40 | The character device front-end can be used as any other LINUX tape device. You | ||
41 | can write to it and read from it using LINUX facilities such as GNU tar. The | ||
42 | tool mt can be used to perform control operations, such as rewinding the tape | ||
43 | or skipping a file. | ||
44 | |||
45 | Most LINUX tape software should work with either tape character device. | ||
46 | |||
47 | |||
48 | Tape block device front-end | ||
49 | |||
50 | The tape device may also be accessed as a block device in read-only mode. | ||
51 | This could be used for software installation in the same way as it is used with | ||
52 | other operation systems on the zSeries platform (and most LINUX | ||
53 | distributions are shipped on compact disk using ISO9660 filesystems). | ||
54 | |||
55 | One block device node is provided for each physical device. These are named | ||
56 | /dev/btibm0 for the first device, /dev/btibm1 for the second and so on. | ||
57 | You should only use the ISO9660 filesystem on LINUX for zSeries tapes because | ||
58 | the physical tape devices cannot perform fast seeks and the ISO9660 system is | ||
59 | optimized for this situation. | ||
60 | |||
61 | |||
62 | Tape block device example | ||
63 | |||
64 | In this example a tape with an ISO9660 filesystem is created using the first | ||
65 | tape device. ISO9660 filesystem support must be built into your system kernel | ||
66 | for this. | ||
67 | The mt command is used to issue tape commands and the mkisofs command to | ||
68 | create an ISO9660 filesystem: | ||
69 | |||
70 | - create a LINUX directory (somedir) with the contents of the filesystem | ||
71 | mkdir somedir | ||
72 | cp contents somedir | ||
73 | |||
74 | - insert a tape | ||
75 | |||
76 | - ensure the tape is at the beginning | ||
77 | mt -f /dev/ntibm0 rewind | ||
78 | |||
79 | - set the blocksize of the character driver. The blocksize 2048 bytes | ||
80 | is commonly used on ISO9660 CD-Roms | ||
81 | mt -f /dev/ntibm0 setblk 2048 | ||
82 | |||
83 | - write the filesystem to the character device driver | ||
84 | mkisofs -o /dev/ntibm0 somedir | ||
85 | |||
86 | - rewind the tape again | ||
87 | mt -f /dev/ntibm0 rewind | ||
88 | |||
89 | - Now you can mount your new filesystem as a block device: | ||
90 | mount -t iso9660 -o ro,block=2048 /dev/btibm0 /mnt | ||
91 | |||
92 | TODO List | ||
93 | |||
94 | - Driver has to be stabilized still | ||
95 | |||
96 | BUGS | ||
97 | |||
98 | This driver is considered BETA, which means some weaknesses may still | ||
99 | be in it. | ||
100 | If an error occurs which cannot be handled by the code you will get a | ||
101 | sense-data dump.In that case please do the following: | ||
102 | |||
103 | 1. set the tape driver debug level to maximum: | ||
104 | echo 6 >/proc/s390dbf/tape/level | ||
105 | |||
106 | 2. re-perform the actions which produced the bug. (Hopefully the bug will | ||
107 | reappear.) | ||
108 | |||
109 | 3. get a snapshot from the debug-feature: | ||
110 | cat /proc/s390dbf/tape/hex_ascii >somefile | ||
111 | |||
112 | 4. Now put the snapshot together with a detailed description of the situation | ||
113 | that led to the bug: | ||
114 | - Which tool did you use? | ||
115 | - Which hardware do you have? | ||
116 | - Was your tape unit online? | ||
117 | - Is it a shared tape unit? | ||
118 | |||
119 | 5. Send an email with your bug report to: | ||
120 | mailto:Linux390@de.ibm.com | ||
121 | |||
122 | |||
diff --git a/arch/s390/boot/compressed/head31.S b/arch/s390/boot/compressed/head31.S index 2a5523a32bcc..e8c9e18b8039 100644 --- a/arch/s390/boot/compressed/head31.S +++ b/arch/s390/boot/compressed/head31.S | |||
@@ -7,14 +7,14 @@ | |||
7 | */ | 7 | */ |
8 | 8 | ||
9 | #include <linux/init.h> | 9 | #include <linux/init.h> |
10 | #include <linux/linkage.h> | ||
10 | #include <asm/asm-offsets.h> | 11 | #include <asm/asm-offsets.h> |
11 | #include <asm/thread_info.h> | 12 | #include <asm/thread_info.h> |
12 | #include <asm/page.h> | 13 | #include <asm/page.h> |
13 | #include "sizes.h" | 14 | #include "sizes.h" |
14 | 15 | ||
15 | __HEAD | 16 | __HEAD |
16 | .globl startup_continue | 17 | ENTRY(startup_continue) |
17 | startup_continue: | ||
18 | basr %r13,0 # get base | 18 | basr %r13,0 # get base |
19 | .LPG1: | 19 | .LPG1: |
20 | # setup stack | 20 | # setup stack |
diff --git a/arch/s390/boot/compressed/head64.S b/arch/s390/boot/compressed/head64.S index 2982cb140550..f86a4eef28a9 100644 --- a/arch/s390/boot/compressed/head64.S +++ b/arch/s390/boot/compressed/head64.S | |||
@@ -7,14 +7,14 @@ | |||
7 | */ | 7 | */ |
8 | 8 | ||
9 | #include <linux/init.h> | 9 | #include <linux/init.h> |
10 | #include <linux/linkage.h> | ||
10 | #include <asm/asm-offsets.h> | 11 | #include <asm/asm-offsets.h> |
11 | #include <asm/thread_info.h> | 12 | #include <asm/thread_info.h> |
12 | #include <asm/page.h> | 13 | #include <asm/page.h> |
13 | #include "sizes.h" | 14 | #include "sizes.h" |
14 | 15 | ||
15 | __HEAD | 16 | __HEAD |
16 | .globl startup_continue | 17 | ENTRY(startup_continue) |
17 | startup_continue: | ||
18 | basr %r13,0 # get base | 18 | basr %r13,0 # get base |
19 | .LPG1: | 19 | .LPG1: |
20 | # setup stack | 20 | # setup stack |
diff --git a/arch/s390/include/asm/irqflags.h b/arch/s390/include/asm/irqflags.h index 865d6d891ace..38fdf451febb 100644 --- a/arch/s390/include/asm/irqflags.h +++ b/arch/s390/include/asm/irqflags.h | |||
@@ -29,42 +29,42 @@ | |||
29 | }) | 29 | }) |
30 | 30 | ||
31 | /* set system mask. */ | 31 | /* set system mask. */ |
32 | static inline void __arch_local_irq_ssm(unsigned long flags) | 32 | static inline notrace void __arch_local_irq_ssm(unsigned long flags) |
33 | { | 33 | { |
34 | asm volatile("ssm %0" : : "Q" (flags) : "memory"); | 34 | asm volatile("ssm %0" : : "Q" (flags) : "memory"); |
35 | } | 35 | } |
36 | 36 | ||
37 | static inline unsigned long arch_local_save_flags(void) | 37 | static inline notrace unsigned long arch_local_save_flags(void) |
38 | { | 38 | { |
39 | return __arch_local_irq_stosm(0x00); | 39 | return __arch_local_irq_stosm(0x00); |
40 | } | 40 | } |
41 | 41 | ||
42 | static inline unsigned long arch_local_irq_save(void) | 42 | static inline notrace unsigned long arch_local_irq_save(void) |
43 | { | 43 | { |
44 | return __arch_local_irq_stnsm(0xfc); | 44 | return __arch_local_irq_stnsm(0xfc); |
45 | } | 45 | } |
46 | 46 | ||
47 | static inline void arch_local_irq_disable(void) | 47 | static inline notrace void arch_local_irq_disable(void) |
48 | { | 48 | { |
49 | arch_local_irq_save(); | 49 | arch_local_irq_save(); |
50 | } | 50 | } |
51 | 51 | ||
52 | static inline void arch_local_irq_enable(void) | 52 | static inline notrace void arch_local_irq_enable(void) |
53 | { | 53 | { |
54 | __arch_local_irq_stosm(0x03); | 54 | __arch_local_irq_stosm(0x03); |
55 | } | 55 | } |
56 | 56 | ||
57 | static inline void arch_local_irq_restore(unsigned long flags) | 57 | static inline notrace void arch_local_irq_restore(unsigned long flags) |
58 | { | 58 | { |
59 | __arch_local_irq_ssm(flags); | 59 | __arch_local_irq_ssm(flags); |
60 | } | 60 | } |
61 | 61 | ||
62 | static inline bool arch_irqs_disabled_flags(unsigned long flags) | 62 | static inline notrace bool arch_irqs_disabled_flags(unsigned long flags) |
63 | { | 63 | { |
64 | return !(flags & (3UL << (BITS_PER_LONG - 8))); | 64 | return !(flags & (3UL << (BITS_PER_LONG - 8))); |
65 | } | 65 | } |
66 | 66 | ||
67 | static inline bool arch_irqs_disabled(void) | 67 | static inline notrace bool arch_irqs_disabled(void) |
68 | { | 68 | { |
69 | return arch_irqs_disabled_flags(arch_local_save_flags()); | 69 | return arch_irqs_disabled_flags(arch_local_save_flags()); |
70 | } | 70 | } |
diff --git a/arch/s390/include/asm/kvm_host.h b/arch/s390/include/asm/kvm_host.h index cef7dbf69dfc..00ff00dfb24c 100644 --- a/arch/s390/include/asm/kvm_host.h +++ b/arch/s390/include/asm/kvm_host.h | |||
@@ -93,9 +93,7 @@ struct kvm_s390_sie_block { | |||
93 | __u32 scaol; /* 0x0064 */ | 93 | __u32 scaol; /* 0x0064 */ |
94 | __u8 reserved68[4]; /* 0x0068 */ | 94 | __u8 reserved68[4]; /* 0x0068 */ |
95 | __u32 todpr; /* 0x006c */ | 95 | __u32 todpr; /* 0x006c */ |
96 | __u8 reserved70[16]; /* 0x0070 */ | 96 | __u8 reserved70[32]; /* 0x0070 */ |
97 | __u64 gmsor; /* 0x0080 */ | ||
98 | __u64 gmslm; /* 0x0088 */ | ||
99 | psw_t gpsw; /* 0x0090 */ | 97 | psw_t gpsw; /* 0x0090 */ |
100 | __u64 gg14; /* 0x00a0 */ | 98 | __u64 gg14; /* 0x00a0 */ |
101 | __u64 gg15; /* 0x00a8 */ | 99 | __u64 gg15; /* 0x00a8 */ |
@@ -138,6 +136,7 @@ struct kvm_vcpu_stat { | |||
138 | u32 instruction_chsc; | 136 | u32 instruction_chsc; |
139 | u32 instruction_stsi; | 137 | u32 instruction_stsi; |
140 | u32 instruction_stfl; | 138 | u32 instruction_stfl; |
139 | u32 instruction_tprot; | ||
141 | u32 instruction_sigp_sense; | 140 | u32 instruction_sigp_sense; |
142 | u32 instruction_sigp_emergency; | 141 | u32 instruction_sigp_emergency; |
143 | u32 instruction_sigp_stop; | 142 | u32 instruction_sigp_stop; |
@@ -175,6 +174,10 @@ struct kvm_s390_prefix_info { | |||
175 | __u32 address; | 174 | __u32 address; |
176 | }; | 175 | }; |
177 | 176 | ||
177 | struct kvm_s390_emerg_info { | ||
178 | __u16 code; | ||
179 | }; | ||
180 | |||
178 | struct kvm_s390_interrupt_info { | 181 | struct kvm_s390_interrupt_info { |
179 | struct list_head list; | 182 | struct list_head list; |
180 | u64 type; | 183 | u64 type; |
@@ -182,6 +185,7 @@ struct kvm_s390_interrupt_info { | |||
182 | struct kvm_s390_io_info io; | 185 | struct kvm_s390_io_info io; |
183 | struct kvm_s390_ext_info ext; | 186 | struct kvm_s390_ext_info ext; |
184 | struct kvm_s390_pgm_info pgm; | 187 | struct kvm_s390_pgm_info pgm; |
188 | struct kvm_s390_emerg_info emerg; | ||
185 | struct kvm_s390_prefix_info prefix; | 189 | struct kvm_s390_prefix_info prefix; |
186 | }; | 190 | }; |
187 | }; | 191 | }; |
@@ -226,6 +230,7 @@ struct kvm_vcpu_arch { | |||
226 | struct cpuid cpu_id; | 230 | struct cpuid cpu_id; |
227 | u64 stidp_data; | 231 | u64 stidp_data; |
228 | }; | 232 | }; |
233 | struct gmap *gmap; | ||
229 | }; | 234 | }; |
230 | 235 | ||
231 | struct kvm_vm_stat { | 236 | struct kvm_vm_stat { |
@@ -236,6 +241,7 @@ struct kvm_arch{ | |||
236 | struct sca_block *sca; | 241 | struct sca_block *sca; |
237 | debug_info_t *dbf; | 242 | debug_info_t *dbf; |
238 | struct kvm_s390_float_interrupt float_int; | 243 | struct kvm_s390_float_interrupt float_int; |
244 | struct gmap *gmap; | ||
239 | }; | 245 | }; |
240 | 246 | ||
241 | extern int sie64a(struct kvm_s390_sie_block *, unsigned long *); | 247 | extern int sie64a(struct kvm_s390_sie_block *, unsigned long *); |
diff --git a/arch/s390/include/asm/linkage.h b/arch/s390/include/asm/linkage.h index 291c2d01c44f..fc8a8284778e 100644 --- a/arch/s390/include/asm/linkage.h +++ b/arch/s390/include/asm/linkage.h | |||
@@ -1,6 +1,9 @@ | |||
1 | #ifndef __ASM_LINKAGE_H | 1 | #ifndef __ASM_LINKAGE_H |
2 | #define __ASM_LINKAGE_H | 2 | #define __ASM_LINKAGE_H |
3 | 3 | ||
4 | /* Nothing to see here... */ | 4 | #include <linux/stringify.h> |
5 | |||
6 | #define __ALIGN .align 4, 0x07 | ||
7 | #define __ALIGN_STR __stringify(__ALIGN) | ||
5 | 8 | ||
6 | #endif | 9 | #endif |
diff --git a/arch/s390/include/asm/lowcore.h b/arch/s390/include/asm/lowcore.h index 228cf0b295db..f26280d9e88d 100644 --- a/arch/s390/include/asm/lowcore.h +++ b/arch/s390/include/asm/lowcore.h | |||
@@ -268,7 +268,7 @@ struct _lowcore { | |||
268 | __u64 vdso_per_cpu_data; /* 0x0358 */ | 268 | __u64 vdso_per_cpu_data; /* 0x0358 */ |
269 | __u64 machine_flags; /* 0x0360 */ | 269 | __u64 machine_flags; /* 0x0360 */ |
270 | __u64 ftrace_func; /* 0x0368 */ | 270 | __u64 ftrace_func; /* 0x0368 */ |
271 | __u64 sie_hook; /* 0x0370 */ | 271 | __u64 gmap; /* 0x0370 */ |
272 | __u64 cmf_hpp; /* 0x0378 */ | 272 | __u64 cmf_hpp; /* 0x0378 */ |
273 | 273 | ||
274 | /* Interrupt response block. */ | 274 | /* Interrupt response block. */ |
diff --git a/arch/s390/include/asm/mmu.h b/arch/s390/include/asm/mmu.h index 82d0847896a0..4506791adcd5 100644 --- a/arch/s390/include/asm/mmu.h +++ b/arch/s390/include/asm/mmu.h | |||
@@ -6,6 +6,7 @@ typedef struct { | |||
6 | unsigned int flush_mm; | 6 | unsigned int flush_mm; |
7 | spinlock_t list_lock; | 7 | spinlock_t list_lock; |
8 | struct list_head pgtable_list; | 8 | struct list_head pgtable_list; |
9 | struct list_head gmap_list; | ||
9 | unsigned long asce_bits; | 10 | unsigned long asce_bits; |
10 | unsigned long asce_limit; | 11 | unsigned long asce_limit; |
11 | unsigned long vdso_base; | 12 | unsigned long vdso_base; |
@@ -17,6 +18,7 @@ typedef struct { | |||
17 | 18 | ||
18 | #define INIT_MM_CONTEXT(name) \ | 19 | #define INIT_MM_CONTEXT(name) \ |
19 | .context.list_lock = __SPIN_LOCK_UNLOCKED(name.context.list_lock), \ | 20 | .context.list_lock = __SPIN_LOCK_UNLOCKED(name.context.list_lock), \ |
20 | .context.pgtable_list = LIST_HEAD_INIT(name.context.pgtable_list), | 21 | .context.pgtable_list = LIST_HEAD_INIT(name.context.pgtable_list), \ |
22 | .context.gmap_list = LIST_HEAD_INIT(name.context.gmap_list), | ||
21 | 23 | ||
22 | #endif | 24 | #endif |
diff --git a/arch/s390/include/asm/pgalloc.h b/arch/s390/include/asm/pgalloc.h index 38e71ebcd3c2..8eef9b5b3cf4 100644 --- a/arch/s390/include/asm/pgalloc.h +++ b/arch/s390/include/asm/pgalloc.h | |||
@@ -20,7 +20,7 @@ | |||
20 | unsigned long *crst_table_alloc(struct mm_struct *); | 20 | unsigned long *crst_table_alloc(struct mm_struct *); |
21 | void crst_table_free(struct mm_struct *, unsigned long *); | 21 | void crst_table_free(struct mm_struct *, unsigned long *); |
22 | 22 | ||
23 | unsigned long *page_table_alloc(struct mm_struct *); | 23 | unsigned long *page_table_alloc(struct mm_struct *, unsigned long); |
24 | void page_table_free(struct mm_struct *, unsigned long *); | 24 | void page_table_free(struct mm_struct *, unsigned long *); |
25 | #ifdef CONFIG_HAVE_RCU_TABLE_FREE | 25 | #ifdef CONFIG_HAVE_RCU_TABLE_FREE |
26 | void page_table_free_rcu(struct mmu_gather *, unsigned long *); | 26 | void page_table_free_rcu(struct mmu_gather *, unsigned long *); |
@@ -115,6 +115,7 @@ static inline pgd_t *pgd_alloc(struct mm_struct *mm) | |||
115 | { | 115 | { |
116 | spin_lock_init(&mm->context.list_lock); | 116 | spin_lock_init(&mm->context.list_lock); |
117 | INIT_LIST_HEAD(&mm->context.pgtable_list); | 117 | INIT_LIST_HEAD(&mm->context.pgtable_list); |
118 | INIT_LIST_HEAD(&mm->context.gmap_list); | ||
118 | return (pgd_t *) crst_table_alloc(mm); | 119 | return (pgd_t *) crst_table_alloc(mm); |
119 | } | 120 | } |
120 | #define pgd_free(mm, pgd) crst_table_free(mm, (unsigned long *) pgd) | 121 | #define pgd_free(mm, pgd) crst_table_free(mm, (unsigned long *) pgd) |
@@ -133,8 +134,8 @@ static inline void pmd_populate(struct mm_struct *mm, | |||
133 | /* | 134 | /* |
134 | * page table entry allocation/free routines. | 135 | * page table entry allocation/free routines. |
135 | */ | 136 | */ |
136 | #define pte_alloc_one_kernel(mm, vmaddr) ((pte_t *) page_table_alloc(mm)) | 137 | #define pte_alloc_one_kernel(mm, vmaddr) ((pte_t *) page_table_alloc(mm, vmaddr)) |
137 | #define pte_alloc_one(mm, vmaddr) ((pte_t *) page_table_alloc(mm)) | 138 | #define pte_alloc_one(mm, vmaddr) ((pte_t *) page_table_alloc(mm, vmaddr)) |
138 | 139 | ||
139 | #define pte_free_kernel(mm, pte) page_table_free(mm, (unsigned long *) pte) | 140 | #define pte_free_kernel(mm, pte) page_table_free(mm, (unsigned long *) pte) |
140 | #define pte_free(mm, pte) page_table_free(mm, (unsigned long *) pte) | 141 | #define pte_free(mm, pte) page_table_free(mm, (unsigned long *) pte) |
diff --git a/arch/s390/include/asm/pgtable.h b/arch/s390/include/asm/pgtable.h index 801fbe1d837d..519eb5f187ef 100644 --- a/arch/s390/include/asm/pgtable.h +++ b/arch/s390/include/asm/pgtable.h | |||
@@ -654,6 +654,48 @@ static inline void pgste_set_pte(pte_t *ptep, pgste_t pgste) | |||
654 | #endif | 654 | #endif |
655 | } | 655 | } |
656 | 656 | ||
657 | /** | ||
658 | * struct gmap_struct - guest address space | ||
659 | * @mm: pointer to the parent mm_struct | ||
660 | * @table: pointer to the page directory | ||
661 | * @crst_list: list of all crst tables used in the guest address space | ||
662 | */ | ||
663 | struct gmap { | ||
664 | struct list_head list; | ||
665 | struct mm_struct *mm; | ||
666 | unsigned long *table; | ||
667 | struct list_head crst_list; | ||
668 | }; | ||
669 | |||
670 | /** | ||
671 | * struct gmap_rmap - reverse mapping for segment table entries | ||
672 | * @next: pointer to the next gmap_rmap structure in the list | ||
673 | * @entry: pointer to a segment table entry | ||
674 | */ | ||
675 | struct gmap_rmap { | ||
676 | struct list_head list; | ||
677 | unsigned long *entry; | ||
678 | }; | ||
679 | |||
680 | /** | ||
681 | * struct gmap_pgtable - gmap information attached to a page table | ||
682 | * @vmaddr: address of the 1MB segment in the process virtual memory | ||
683 | * @mapper: list of segment table entries maping a page table | ||
684 | */ | ||
685 | struct gmap_pgtable { | ||
686 | unsigned long vmaddr; | ||
687 | struct list_head mapper; | ||
688 | }; | ||
689 | |||
690 | struct gmap *gmap_alloc(struct mm_struct *mm); | ||
691 | void gmap_free(struct gmap *gmap); | ||
692 | void gmap_enable(struct gmap *gmap); | ||
693 | void gmap_disable(struct gmap *gmap); | ||
694 | int gmap_map_segment(struct gmap *gmap, unsigned long from, | ||
695 | unsigned long to, unsigned long length); | ||
696 | int gmap_unmap_segment(struct gmap *gmap, unsigned long to, unsigned long len); | ||
697 | unsigned long gmap_fault(unsigned long address, struct gmap *); | ||
698 | |||
657 | /* | 699 | /* |
658 | * Certain architectures need to do special things when PTEs | 700 | * Certain architectures need to do special things when PTEs |
659 | * within a page table are directly modified. Thus, the following | 701 | * within a page table are directly modified. Thus, the following |
diff --git a/arch/s390/include/asm/processor.h b/arch/s390/include/asm/processor.h index 1300c3025334..55dfcc8bdc0d 100644 --- a/arch/s390/include/asm/processor.h +++ b/arch/s390/include/asm/processor.h | |||
@@ -80,6 +80,7 @@ struct thread_struct { | |||
80 | mm_segment_t mm_segment; | 80 | mm_segment_t mm_segment; |
81 | unsigned long prot_addr; /* address of protection-excep. */ | 81 | unsigned long prot_addr; /* address of protection-excep. */ |
82 | unsigned int trap_no; | 82 | unsigned int trap_no; |
83 | unsigned long gmap_addr; /* address of last gmap fault. */ | ||
83 | struct per_regs per_user; /* User specified PER registers */ | 84 | struct per_regs per_user; /* User specified PER registers */ |
84 | struct per_event per_event; /* Cause of the last PER trap */ | 85 | struct per_event per_event; /* Cause of the last PER trap */ |
85 | /* pfault_wait is used to block the process on a pfault event */ | 86 | /* pfault_wait is used to block the process on a pfault event */ |
diff --git a/arch/s390/include/asm/thread_info.h b/arch/s390/include/asm/thread_info.h index ad1382f7932e..1a5dbb6f1495 100644 --- a/arch/s390/include/asm/thread_info.h +++ b/arch/s390/include/asm/thread_info.h | |||
@@ -94,6 +94,7 @@ static inline struct thread_info *current_thread_info(void) | |||
94 | #define TIF_SYSCALL_AUDIT 9 /* syscall auditing active */ | 94 | #define TIF_SYSCALL_AUDIT 9 /* syscall auditing active */ |
95 | #define TIF_SECCOMP 10 /* secure computing */ | 95 | #define TIF_SECCOMP 10 /* secure computing */ |
96 | #define TIF_SYSCALL_TRACEPOINT 11 /* syscall tracepoint instrumentation */ | 96 | #define TIF_SYSCALL_TRACEPOINT 11 /* syscall tracepoint instrumentation */ |
97 | #define TIF_SIE 12 /* guest execution active */ | ||
97 | #define TIF_POLLING_NRFLAG 16 /* true if poll_idle() is polling | 98 | #define TIF_POLLING_NRFLAG 16 /* true if poll_idle() is polling |
98 | TIF_NEED_RESCHED */ | 99 | TIF_NEED_RESCHED */ |
99 | #define TIF_31BIT 17 /* 32bit process */ | 100 | #define TIF_31BIT 17 /* 32bit process */ |
@@ -113,6 +114,7 @@ static inline struct thread_info *current_thread_info(void) | |||
113 | #define _TIF_SYSCALL_AUDIT (1<<TIF_SYSCALL_AUDIT) | 114 | #define _TIF_SYSCALL_AUDIT (1<<TIF_SYSCALL_AUDIT) |
114 | #define _TIF_SECCOMP (1<<TIF_SECCOMP) | 115 | #define _TIF_SECCOMP (1<<TIF_SECCOMP) |
115 | #define _TIF_SYSCALL_TRACEPOINT (1<<TIF_SYSCALL_TRACEPOINT) | 116 | #define _TIF_SYSCALL_TRACEPOINT (1<<TIF_SYSCALL_TRACEPOINT) |
117 | #define _TIF_SIE (1<<TIF_SIE) | ||
116 | #define _TIF_POLLING_NRFLAG (1<<TIF_POLLING_NRFLAG) | 118 | #define _TIF_POLLING_NRFLAG (1<<TIF_POLLING_NRFLAG) |
117 | #define _TIF_31BIT (1<<TIF_31BIT) | 119 | #define _TIF_31BIT (1<<TIF_31BIT) |
118 | #define _TIF_SINGLE_STEP (1<<TIF_FREEZE) | 120 | #define _TIF_SINGLE_STEP (1<<TIF_FREEZE) |
diff --git a/arch/s390/include/asm/tlbflush.h b/arch/s390/include/asm/tlbflush.h index b7a4f2eb0057..304445382382 100644 --- a/arch/s390/include/asm/tlbflush.h +++ b/arch/s390/include/asm/tlbflush.h | |||
@@ -80,7 +80,7 @@ static inline void __tlb_flush_mm(struct mm_struct * mm) | |||
80 | * on all cpus instead of doing a local flush if the mm | 80 | * on all cpus instead of doing a local flush if the mm |
81 | * only ran on the local cpu. | 81 | * only ran on the local cpu. |
82 | */ | 82 | */ |
83 | if (MACHINE_HAS_IDTE) | 83 | if (MACHINE_HAS_IDTE && list_empty(&mm->context.gmap_list)) |
84 | __tlb_flush_idte((unsigned long) mm->pgd | | 84 | __tlb_flush_idte((unsigned long) mm->pgd | |
85 | mm->context.asce_bits); | 85 | mm->context.asce_bits); |
86 | else | 86 | else |
diff --git a/arch/s390/kernel/asm-offsets.c b/arch/s390/kernel/asm-offsets.c index edfbd17d7082..05d8f38734ec 100644 --- a/arch/s390/kernel/asm-offsets.c +++ b/arch/s390/kernel/asm-offsets.c | |||
@@ -151,7 +151,7 @@ int main(void) | |||
151 | DEFINE(__LC_FP_CREG_SAVE_AREA, offsetof(struct _lowcore, fpt_creg_save_area)); | 151 | DEFINE(__LC_FP_CREG_SAVE_AREA, offsetof(struct _lowcore, fpt_creg_save_area)); |
152 | DEFINE(__LC_LAST_BREAK, offsetof(struct _lowcore, breaking_event_addr)); | 152 | DEFINE(__LC_LAST_BREAK, offsetof(struct _lowcore, breaking_event_addr)); |
153 | DEFINE(__LC_VDSO_PER_CPU, offsetof(struct _lowcore, vdso_per_cpu_data)); | 153 | DEFINE(__LC_VDSO_PER_CPU, offsetof(struct _lowcore, vdso_per_cpu_data)); |
154 | DEFINE(__LC_SIE_HOOK, offsetof(struct _lowcore, sie_hook)); | 154 | DEFINE(__LC_GMAP, offsetof(struct _lowcore, gmap)); |
155 | DEFINE(__LC_CMF_HPP, offsetof(struct _lowcore, cmf_hpp)); | 155 | DEFINE(__LC_CMF_HPP, offsetof(struct _lowcore, cmf_hpp)); |
156 | #endif /* CONFIG_32BIT */ | 156 | #endif /* CONFIG_32BIT */ |
157 | return 0; | 157 | return 0; |
diff --git a/arch/s390/kernel/base.S b/arch/s390/kernel/base.S index 15e46ca94335..209938c1dfc8 100644 --- a/arch/s390/kernel/base.S +++ b/arch/s390/kernel/base.S | |||
@@ -6,13 +6,13 @@ | |||
6 | * Michael Holzheu <holzheu@de.ibm.com> | 6 | * Michael Holzheu <holzheu@de.ibm.com> |
7 | */ | 7 | */ |
8 | 8 | ||
9 | #include <linux/linkage.h> | ||
9 | #include <asm/asm-offsets.h> | 10 | #include <asm/asm-offsets.h> |
10 | #include <asm/ptrace.h> | 11 | #include <asm/ptrace.h> |
11 | 12 | ||
12 | #ifdef CONFIG_64BIT | 13 | #ifdef CONFIG_64BIT |
13 | 14 | ||
14 | .globl s390_base_mcck_handler | 15 | ENTRY(s390_base_mcck_handler) |
15 | s390_base_mcck_handler: | ||
16 | basr %r13,0 | 16 | basr %r13,0 |
17 | 0: lg %r15,__LC_PANIC_STACK # load panic stack | 17 | 0: lg %r15,__LC_PANIC_STACK # load panic stack |
18 | aghi %r15,-STACK_FRAME_OVERHEAD | 18 | aghi %r15,-STACK_FRAME_OVERHEAD |
@@ -26,13 +26,13 @@ s390_base_mcck_handler: | |||
26 | lpswe __LC_MCK_OLD_PSW | 26 | lpswe __LC_MCK_OLD_PSW |
27 | 27 | ||
28 | .section .bss | 28 | .section .bss |
29 | .align 8 | ||
29 | .globl s390_base_mcck_handler_fn | 30 | .globl s390_base_mcck_handler_fn |
30 | s390_base_mcck_handler_fn: | 31 | s390_base_mcck_handler_fn: |
31 | .quad 0 | 32 | .quad 0 |
32 | .previous | 33 | .previous |
33 | 34 | ||
34 | .globl s390_base_ext_handler | 35 | ENTRY(s390_base_ext_handler) |
35 | s390_base_ext_handler: | ||
36 | stmg %r0,%r15,__LC_SAVE_AREA | 36 | stmg %r0,%r15,__LC_SAVE_AREA |
37 | basr %r13,0 | 37 | basr %r13,0 |
38 | 0: aghi %r15,-STACK_FRAME_OVERHEAD | 38 | 0: aghi %r15,-STACK_FRAME_OVERHEAD |
@@ -46,13 +46,13 @@ s390_base_ext_handler: | |||
46 | lpswe __LC_EXT_OLD_PSW | 46 | lpswe __LC_EXT_OLD_PSW |
47 | 47 | ||
48 | .section .bss | 48 | .section .bss |
49 | .align 8 | ||
49 | .globl s390_base_ext_handler_fn | 50 | .globl s390_base_ext_handler_fn |
50 | s390_base_ext_handler_fn: | 51 | s390_base_ext_handler_fn: |
51 | .quad 0 | 52 | .quad 0 |
52 | .previous | 53 | .previous |
53 | 54 | ||
54 | .globl s390_base_pgm_handler | 55 | ENTRY(s390_base_pgm_handler) |
55 | s390_base_pgm_handler: | ||
56 | stmg %r0,%r15,__LC_SAVE_AREA | 56 | stmg %r0,%r15,__LC_SAVE_AREA |
57 | basr %r13,0 | 57 | basr %r13,0 |
58 | 0: aghi %r15,-STACK_FRAME_OVERHEAD | 58 | 0: aghi %r15,-STACK_FRAME_OVERHEAD |
@@ -70,6 +70,7 @@ disabled_wait_psw: | |||
70 | .quad 0x0002000180000000,0x0000000000000000 + s390_base_pgm_handler | 70 | .quad 0x0002000180000000,0x0000000000000000 + s390_base_pgm_handler |
71 | 71 | ||
72 | .section .bss | 72 | .section .bss |
73 | .align 8 | ||
73 | .globl s390_base_pgm_handler_fn | 74 | .globl s390_base_pgm_handler_fn |
74 | s390_base_pgm_handler_fn: | 75 | s390_base_pgm_handler_fn: |
75 | .quad 0 | 76 | .quad 0 |
@@ -77,8 +78,7 @@ s390_base_pgm_handler_fn: | |||
77 | 78 | ||
78 | #else /* CONFIG_64BIT */ | 79 | #else /* CONFIG_64BIT */ |
79 | 80 | ||
80 | .globl s390_base_mcck_handler | 81 | ENTRY(s390_base_mcck_handler) |
81 | s390_base_mcck_handler: | ||
82 | basr %r13,0 | 82 | basr %r13,0 |
83 | 0: l %r15,__LC_PANIC_STACK # load panic stack | 83 | 0: l %r15,__LC_PANIC_STACK # load panic stack |
84 | ahi %r15,-STACK_FRAME_OVERHEAD | 84 | ahi %r15,-STACK_FRAME_OVERHEAD |
@@ -93,13 +93,13 @@ s390_base_mcck_handler: | |||
93 | 2: .long s390_base_mcck_handler_fn | 93 | 2: .long s390_base_mcck_handler_fn |
94 | 94 | ||
95 | .section .bss | 95 | .section .bss |
96 | .align 4 | ||
96 | .globl s390_base_mcck_handler_fn | 97 | .globl s390_base_mcck_handler_fn |
97 | s390_base_mcck_handler_fn: | 98 | s390_base_mcck_handler_fn: |
98 | .long 0 | 99 | .long 0 |
99 | .previous | 100 | .previous |
100 | 101 | ||
101 | .globl s390_base_ext_handler | 102 | ENTRY(s390_base_ext_handler) |
102 | s390_base_ext_handler: | ||
103 | stm %r0,%r15,__LC_SAVE_AREA | 103 | stm %r0,%r15,__LC_SAVE_AREA |
104 | basr %r13,0 | 104 | basr %r13,0 |
105 | 0: ahi %r15,-STACK_FRAME_OVERHEAD | 105 | 0: ahi %r15,-STACK_FRAME_OVERHEAD |
@@ -115,13 +115,13 @@ s390_base_ext_handler: | |||
115 | 2: .long s390_base_ext_handler_fn | 115 | 2: .long s390_base_ext_handler_fn |
116 | 116 | ||
117 | .section .bss | 117 | .section .bss |
118 | .align 4 | ||
118 | .globl s390_base_ext_handler_fn | 119 | .globl s390_base_ext_handler_fn |
119 | s390_base_ext_handler_fn: | 120 | s390_base_ext_handler_fn: |
120 | .long 0 | 121 | .long 0 |
121 | .previous | 122 | .previous |
122 | 123 | ||
123 | .globl s390_base_pgm_handler | 124 | ENTRY(s390_base_pgm_handler) |
124 | s390_base_pgm_handler: | ||
125 | stm %r0,%r15,__LC_SAVE_AREA | 125 | stm %r0,%r15,__LC_SAVE_AREA |
126 | basr %r13,0 | 126 | basr %r13,0 |
127 | 0: ahi %r15,-STACK_FRAME_OVERHEAD | 127 | 0: ahi %r15,-STACK_FRAME_OVERHEAD |
@@ -142,6 +142,7 @@ disabled_wait_psw: | |||
142 | .long 0x000a0000,0x00000000 + s390_base_pgm_handler | 142 | .long 0x000a0000,0x00000000 + s390_base_pgm_handler |
143 | 143 | ||
144 | .section .bss | 144 | .section .bss |
145 | .align 4 | ||
145 | .globl s390_base_pgm_handler_fn | 146 | .globl s390_base_pgm_handler_fn |
146 | s390_base_pgm_handler_fn: | 147 | s390_base_pgm_handler_fn: |
147 | .long 0 | 148 | .long 0 |
diff --git a/arch/s390/kernel/compat_wrapper.S b/arch/s390/kernel/compat_wrapper.S index 1f5eb789c3a7..08ab9aa6a0d5 100644 --- a/arch/s390/kernel/compat_wrapper.S +++ b/arch/s390/kernel/compat_wrapper.S | |||
@@ -7,86 +7,74 @@ | |||
7 | * Thomas Spatzier (tspat@de.ibm.com) | 7 | * Thomas Spatzier (tspat@de.ibm.com) |
8 | */ | 8 | */ |
9 | 9 | ||
10 | .globl sys32_exit_wrapper | 10 | #include <linux/linkage.h> |
11 | sys32_exit_wrapper: | 11 | |
12 | ENTRY(sys32_exit_wrapper) | ||
12 | lgfr %r2,%r2 # int | 13 | lgfr %r2,%r2 # int |
13 | jg sys_exit # branch to sys_exit | 14 | jg sys_exit # branch to sys_exit |
14 | 15 | ||
15 | .globl sys32_read_wrapper | 16 | ENTRY(sys32_read_wrapper) |
16 | sys32_read_wrapper: | ||
17 | llgfr %r2,%r2 # unsigned int | 17 | llgfr %r2,%r2 # unsigned int |
18 | llgtr %r3,%r3 # char * | 18 | llgtr %r3,%r3 # char * |
19 | llgfr %r4,%r4 # size_t | 19 | llgfr %r4,%r4 # size_t |
20 | jg sys32_read # branch to sys_read | 20 | jg sys32_read # branch to sys_read |
21 | 21 | ||
22 | .globl sys32_write_wrapper | 22 | ENTRY(sys32_write_wrapper) |
23 | sys32_write_wrapper: | ||
24 | llgfr %r2,%r2 # unsigned int | 23 | llgfr %r2,%r2 # unsigned int |
25 | llgtr %r3,%r3 # const char * | 24 | llgtr %r3,%r3 # const char * |
26 | llgfr %r4,%r4 # size_t | 25 | llgfr %r4,%r4 # size_t |
27 | jg sys32_write # branch to system call | 26 | jg sys32_write # branch to system call |
28 | 27 | ||
29 | .globl sys32_open_wrapper | 28 | ENTRY(sys32_open_wrapper) |
30 | sys32_open_wrapper: | ||
31 | llgtr %r2,%r2 # const char * | 29 | llgtr %r2,%r2 # const char * |
32 | lgfr %r3,%r3 # int | 30 | lgfr %r3,%r3 # int |
33 | lgfr %r4,%r4 # int | 31 | lgfr %r4,%r4 # int |
34 | jg sys_open # branch to system call | 32 | jg sys_open # branch to system call |
35 | 33 | ||
36 | .globl sys32_close_wrapper | 34 | ENTRY(sys32_close_wrapper) |
37 | sys32_close_wrapper: | ||
38 | llgfr %r2,%r2 # unsigned int | 35 | llgfr %r2,%r2 # unsigned int |
39 | jg sys_close # branch to system call | 36 | jg sys_close # branch to system call |
40 | 37 | ||
41 | .globl sys32_creat_wrapper | 38 | ENTRY(sys32_creat_wrapper) |
42 | sys32_creat_wrapper: | ||
43 | llgtr %r2,%r2 # const char * | 39 | llgtr %r2,%r2 # const char * |
44 | lgfr %r3,%r3 # int | 40 | lgfr %r3,%r3 # int |
45 | jg sys_creat # branch to system call | 41 | jg sys_creat # branch to system call |
46 | 42 | ||
47 | .globl sys32_link_wrapper | 43 | ENTRY(sys32_link_wrapper) |
48 | sys32_link_wrapper: | ||
49 | llgtr %r2,%r2 # const char * | 44 | llgtr %r2,%r2 # const char * |
50 | llgtr %r3,%r3 # const char * | 45 | llgtr %r3,%r3 # const char * |
51 | jg sys_link # branch to system call | 46 | jg sys_link # branch to system call |
52 | 47 | ||
53 | .globl sys32_unlink_wrapper | 48 | ENTRY(sys32_unlink_wrapper) |
54 | sys32_unlink_wrapper: | ||
55 | llgtr %r2,%r2 # const char * | 49 | llgtr %r2,%r2 # const char * |
56 | jg sys_unlink # branch to system call | 50 | jg sys_unlink # branch to system call |
57 | 51 | ||
58 | .globl sys32_chdir_wrapper | 52 | ENTRY(sys32_chdir_wrapper) |
59 | sys32_chdir_wrapper: | ||
60 | llgtr %r2,%r2 # const char * | 53 | llgtr %r2,%r2 # const char * |
61 | jg sys_chdir # branch to system call | 54 | jg sys_chdir # branch to system call |
62 | 55 | ||
63 | .globl sys32_time_wrapper | 56 | ENTRY(sys32_time_wrapper) |
64 | sys32_time_wrapper: | ||
65 | llgtr %r2,%r2 # int * | 57 | llgtr %r2,%r2 # int * |
66 | jg compat_sys_time # branch to system call | 58 | jg compat_sys_time # branch to system call |
67 | 59 | ||
68 | .globl sys32_mknod_wrapper | 60 | ENTRY(sys32_mknod_wrapper) |
69 | sys32_mknod_wrapper: | ||
70 | llgtr %r2,%r2 # const char * | 61 | llgtr %r2,%r2 # const char * |
71 | lgfr %r3,%r3 # int | 62 | lgfr %r3,%r3 # int |
72 | llgfr %r4,%r4 # dev | 63 | llgfr %r4,%r4 # dev |
73 | jg sys_mknod # branch to system call | 64 | jg sys_mknod # branch to system call |
74 | 65 | ||
75 | .globl sys32_chmod_wrapper | 66 | ENTRY(sys32_chmod_wrapper) |
76 | sys32_chmod_wrapper: | ||
77 | llgtr %r2,%r2 # const char * | 67 | llgtr %r2,%r2 # const char * |
78 | llgfr %r3,%r3 # mode_t | 68 | llgfr %r3,%r3 # mode_t |
79 | jg sys_chmod # branch to system call | 69 | jg sys_chmod # branch to system call |
80 | 70 | ||
81 | .globl sys32_lchown16_wrapper | 71 | ENTRY(sys32_lchown16_wrapper) |
82 | sys32_lchown16_wrapper: | ||
83 | llgtr %r2,%r2 # const char * | 72 | llgtr %r2,%r2 # const char * |
84 | llgfr %r3,%r3 # __kernel_old_uid_emu31_t | 73 | llgfr %r3,%r3 # __kernel_old_uid_emu31_t |
85 | llgfr %r4,%r4 # __kernel_old_uid_emu31_t | 74 | llgfr %r4,%r4 # __kernel_old_uid_emu31_t |
86 | jg sys32_lchown16 # branch to system call | 75 | jg sys32_lchown16 # branch to system call |
87 | 76 | ||
88 | .globl sys32_lseek_wrapper | 77 | ENTRY(sys32_lseek_wrapper) |
89 | sys32_lseek_wrapper: | ||
90 | llgfr %r2,%r2 # unsigned int | 78 | llgfr %r2,%r2 # unsigned int |
91 | lgfr %r3,%r3 # off_t | 79 | lgfr %r3,%r3 # off_t |
92 | llgfr %r4,%r4 # unsigned int | 80 | llgfr %r4,%r4 # unsigned int |
@@ -94,8 +82,7 @@ sys32_lseek_wrapper: | |||
94 | 82 | ||
95 | #sys32_getpid_wrapper # void | 83 | #sys32_getpid_wrapper # void |
96 | 84 | ||
97 | .globl sys32_mount_wrapper | 85 | ENTRY(sys32_mount_wrapper) |
98 | sys32_mount_wrapper: | ||
99 | llgtr %r2,%r2 # char * | 86 | llgtr %r2,%r2 # char * |
100 | llgtr %r3,%r3 # char * | 87 | llgtr %r3,%r3 # char * |
101 | llgtr %r4,%r4 # char * | 88 | llgtr %r4,%r4 # char * |
@@ -103,102 +90,85 @@ sys32_mount_wrapper: | |||
103 | llgtr %r6,%r6 # void * | 90 | llgtr %r6,%r6 # void * |
104 | jg compat_sys_mount # branch to system call | 91 | jg compat_sys_mount # branch to system call |
105 | 92 | ||
106 | .globl sys32_oldumount_wrapper | 93 | ENTRY(sys32_oldumount_wrapper) |
107 | sys32_oldumount_wrapper: | ||
108 | llgtr %r2,%r2 # char * | 94 | llgtr %r2,%r2 # char * |
109 | jg sys_oldumount # branch to system call | 95 | jg sys_oldumount # branch to system call |
110 | 96 | ||
111 | .globl sys32_setuid16_wrapper | 97 | ENTRY(sys32_setuid16_wrapper) |
112 | sys32_setuid16_wrapper: | ||
113 | llgfr %r2,%r2 # __kernel_old_uid_emu31_t | 98 | llgfr %r2,%r2 # __kernel_old_uid_emu31_t |
114 | jg sys32_setuid16 # branch to system call | 99 | jg sys32_setuid16 # branch to system call |
115 | 100 | ||
116 | #sys32_getuid16_wrapper # void | 101 | #sys32_getuid16_wrapper # void |
117 | 102 | ||
118 | .globl sys32_ptrace_wrapper | 103 | ENTRY(sys32_ptrace_wrapper) |
119 | sys32_ptrace_wrapper: | ||
120 | lgfr %r2,%r2 # long | 104 | lgfr %r2,%r2 # long |
121 | lgfr %r3,%r3 # long | 105 | lgfr %r3,%r3 # long |
122 | llgtr %r4,%r4 # long | 106 | llgtr %r4,%r4 # long |
123 | llgfr %r5,%r5 # long | 107 | llgfr %r5,%r5 # long |
124 | jg compat_sys_ptrace # branch to system call | 108 | jg compat_sys_ptrace # branch to system call |
125 | 109 | ||
126 | .globl sys32_alarm_wrapper | 110 | ENTRY(sys32_alarm_wrapper) |
127 | sys32_alarm_wrapper: | ||
128 | llgfr %r2,%r2 # unsigned int | 111 | llgfr %r2,%r2 # unsigned int |
129 | jg sys_alarm # branch to system call | 112 | jg sys_alarm # branch to system call |
130 | 113 | ||
131 | .globl compat_sys_utime_wrapper | 114 | ENTRY(compat_sys_utime_wrapper) |
132 | compat_sys_utime_wrapper: | ||
133 | llgtr %r2,%r2 # char * | 115 | llgtr %r2,%r2 # char * |
134 | llgtr %r3,%r3 # struct compat_utimbuf * | 116 | llgtr %r3,%r3 # struct compat_utimbuf * |
135 | jg compat_sys_utime # branch to system call | 117 | jg compat_sys_utime # branch to system call |
136 | 118 | ||
137 | .globl sys32_access_wrapper | 119 | ENTRY(sys32_access_wrapper) |
138 | sys32_access_wrapper: | ||
139 | llgtr %r2,%r2 # const char * | 120 | llgtr %r2,%r2 # const char * |
140 | lgfr %r3,%r3 # int | 121 | lgfr %r3,%r3 # int |
141 | jg sys_access # branch to system call | 122 | jg sys_access # branch to system call |
142 | 123 | ||
143 | .globl sys32_nice_wrapper | 124 | ENTRY(sys32_nice_wrapper) |
144 | sys32_nice_wrapper: | ||
145 | lgfr %r2,%r2 # int | 125 | lgfr %r2,%r2 # int |
146 | jg sys_nice # branch to system call | 126 | jg sys_nice # branch to system call |
147 | 127 | ||
148 | #sys32_sync_wrapper # void | 128 | #sys32_sync_wrapper # void |
149 | 129 | ||
150 | .globl sys32_kill_wrapper | 130 | ENTRY(sys32_kill_wrapper) |
151 | sys32_kill_wrapper: | ||
152 | lgfr %r2,%r2 # int | 131 | lgfr %r2,%r2 # int |
153 | lgfr %r3,%r3 # int | 132 | lgfr %r3,%r3 # int |
154 | jg sys_kill # branch to system call | 133 | jg sys_kill # branch to system call |
155 | 134 | ||
156 | .globl sys32_rename_wrapper | 135 | ENTRY(sys32_rename_wrapper) |
157 | sys32_rename_wrapper: | ||
158 | llgtr %r2,%r2 # const char * | 136 | llgtr %r2,%r2 # const char * |
159 | llgtr %r3,%r3 # const char * | 137 | llgtr %r3,%r3 # const char * |
160 | jg sys_rename # branch to system call | 138 | jg sys_rename # branch to system call |
161 | 139 | ||
162 | .globl sys32_mkdir_wrapper | 140 | ENTRY(sys32_mkdir_wrapper) |
163 | sys32_mkdir_wrapper: | ||
164 | llgtr %r2,%r2 # const char * | 141 | llgtr %r2,%r2 # const char * |
165 | lgfr %r3,%r3 # int | 142 | lgfr %r3,%r3 # int |
166 | jg sys_mkdir # branch to system call | 143 | jg sys_mkdir # branch to system call |
167 | 144 | ||
168 | .globl sys32_rmdir_wrapper | 145 | ENTRY(sys32_rmdir_wrapper) |
169 | sys32_rmdir_wrapper: | ||
170 | llgtr %r2,%r2 # const char * | 146 | llgtr %r2,%r2 # const char * |
171 | jg sys_rmdir # branch to system call | 147 | jg sys_rmdir # branch to system call |
172 | 148 | ||
173 | .globl sys32_dup_wrapper | 149 | ENTRY(sys32_dup_wrapper) |
174 | sys32_dup_wrapper: | ||
175 | llgfr %r2,%r2 # unsigned int | 150 | llgfr %r2,%r2 # unsigned int |
176 | jg sys_dup # branch to system call | 151 | jg sys_dup # branch to system call |
177 | 152 | ||
178 | .globl sys32_pipe_wrapper | 153 | ENTRY(sys32_pipe_wrapper) |
179 | sys32_pipe_wrapper: | ||
180 | llgtr %r2,%r2 # u32 * | 154 | llgtr %r2,%r2 # u32 * |
181 | jg sys_pipe # branch to system call | 155 | jg sys_pipe # branch to system call |
182 | 156 | ||
183 | .globl compat_sys_times_wrapper | 157 | ENTRY(compat_sys_times_wrapper) |
184 | compat_sys_times_wrapper: | ||
185 | llgtr %r2,%r2 # struct compat_tms * | 158 | llgtr %r2,%r2 # struct compat_tms * |
186 | jg compat_sys_times # branch to system call | 159 | jg compat_sys_times # branch to system call |
187 | 160 | ||
188 | .globl sys32_brk_wrapper | 161 | ENTRY(sys32_brk_wrapper) |
189 | sys32_brk_wrapper: | ||
190 | llgtr %r2,%r2 # unsigned long | 162 | llgtr %r2,%r2 # unsigned long |
191 | jg sys_brk # branch to system call | 163 | jg sys_brk # branch to system call |
192 | 164 | ||
193 | .globl sys32_setgid16_wrapper | 165 | ENTRY(sys32_setgid16_wrapper) |
194 | sys32_setgid16_wrapper: | ||
195 | llgfr %r2,%r2 # __kernel_old_gid_emu31_t | 166 | llgfr %r2,%r2 # __kernel_old_gid_emu31_t |
196 | jg sys32_setgid16 # branch to system call | 167 | jg sys32_setgid16 # branch to system call |
197 | 168 | ||
198 | #sys32_getgid16_wrapper # void | 169 | #sys32_getgid16_wrapper # void |
199 | 170 | ||
200 | .globl sys32_signal_wrapper | 171 | ENTRY(sys32_signal_wrapper) |
201 | sys32_signal_wrapper: | ||
202 | lgfr %r2,%r2 # int | 172 | lgfr %r2,%r2 # int |
203 | llgtr %r3,%r3 # __sighandler_t | 173 | llgtr %r3,%r3 # __sighandler_t |
204 | jg sys_signal | 174 | jg sys_signal |
@@ -207,55 +177,46 @@ sys32_signal_wrapper: | |||
207 | 177 | ||
208 | #sys32_getegid16_wrapper # void | 178 | #sys32_getegid16_wrapper # void |
209 | 179 | ||
210 | .globl sys32_acct_wrapper | 180 | ENTRY(sys32_acct_wrapper) |
211 | sys32_acct_wrapper: | ||
212 | llgtr %r2,%r2 # char * | 181 | llgtr %r2,%r2 # char * |
213 | jg sys_acct # branch to system call | 182 | jg sys_acct # branch to system call |
214 | 183 | ||
215 | .globl sys32_umount_wrapper | 184 | ENTRY(sys32_umount_wrapper) |
216 | sys32_umount_wrapper: | ||
217 | llgtr %r2,%r2 # char * | 185 | llgtr %r2,%r2 # char * |
218 | lgfr %r3,%r3 # int | 186 | lgfr %r3,%r3 # int |
219 | jg sys_umount # branch to system call | 187 | jg sys_umount # branch to system call |
220 | 188 | ||
221 | .globl compat_sys_ioctl_wrapper | 189 | ENTRY(compat_sys_ioctl_wrapper) |
222 | compat_sys_ioctl_wrapper: | ||
223 | llgfr %r2,%r2 # unsigned int | 190 | llgfr %r2,%r2 # unsigned int |
224 | llgfr %r3,%r3 # unsigned int | 191 | llgfr %r3,%r3 # unsigned int |
225 | llgfr %r4,%r4 # unsigned int | 192 | llgfr %r4,%r4 # unsigned int |
226 | jg compat_sys_ioctl # branch to system call | 193 | jg compat_sys_ioctl # branch to system call |
227 | 194 | ||
228 | .globl compat_sys_fcntl_wrapper | 195 | ENTRY(compat_sys_fcntl_wrapper) |
229 | compat_sys_fcntl_wrapper: | ||
230 | llgfr %r2,%r2 # unsigned int | 196 | llgfr %r2,%r2 # unsigned int |
231 | llgfr %r3,%r3 # unsigned int | 197 | llgfr %r3,%r3 # unsigned int |
232 | llgfr %r4,%r4 # unsigned long | 198 | llgfr %r4,%r4 # unsigned long |
233 | jg compat_sys_fcntl # branch to system call | 199 | jg compat_sys_fcntl # branch to system call |
234 | 200 | ||
235 | .globl sys32_setpgid_wrapper | 201 | ENTRY(sys32_setpgid_wrapper) |
236 | sys32_setpgid_wrapper: | ||
237 | lgfr %r2,%r2 # pid_t | 202 | lgfr %r2,%r2 # pid_t |
238 | lgfr %r3,%r3 # pid_t | 203 | lgfr %r3,%r3 # pid_t |
239 | jg sys_setpgid # branch to system call | 204 | jg sys_setpgid # branch to system call |
240 | 205 | ||
241 | .globl sys32_umask_wrapper | 206 | ENTRY(sys32_umask_wrapper) |
242 | sys32_umask_wrapper: | ||
243 | lgfr %r2,%r2 # int | 207 | lgfr %r2,%r2 # int |
244 | jg sys_umask # branch to system call | 208 | jg sys_umask # branch to system call |
245 | 209 | ||
246 | .globl sys32_chroot_wrapper | 210 | ENTRY(sys32_chroot_wrapper) |
247 | sys32_chroot_wrapper: | ||
248 | llgtr %r2,%r2 # char * | 211 | llgtr %r2,%r2 # char * |
249 | jg sys_chroot # branch to system call | 212 | jg sys_chroot # branch to system call |
250 | 213 | ||
251 | .globl sys32_ustat_wrapper | 214 | ENTRY(sys32_ustat_wrapper) |
252 | sys32_ustat_wrapper: | ||
253 | llgfr %r2,%r2 # dev_t | 215 | llgfr %r2,%r2 # dev_t |
254 | llgtr %r3,%r3 # struct ustat * | 216 | llgtr %r3,%r3 # struct ustat * |
255 | jg compat_sys_ustat | 217 | jg compat_sys_ustat |
256 | 218 | ||
257 | .globl sys32_dup2_wrapper | 219 | ENTRY(sys32_dup2_wrapper) |
258 | sys32_dup2_wrapper: | ||
259 | llgfr %r2,%r2 # unsigned int | 220 | llgfr %r2,%r2 # unsigned int |
260 | llgfr %r3,%r3 # unsigned int | 221 | llgfr %r3,%r3 # unsigned int |
261 | jg sys_dup2 # branch to system call | 222 | jg sys_dup2 # branch to system call |
@@ -266,262 +227,220 @@ sys32_dup2_wrapper: | |||
266 | 227 | ||
267 | #sys32_setsid_wrapper # void | 228 | #sys32_setsid_wrapper # void |
268 | 229 | ||
269 | .globl sys32_sigaction_wrapper | 230 | ENTRY(sys32_sigaction_wrapper) |
270 | sys32_sigaction_wrapper: | ||
271 | lgfr %r2,%r2 # int | 231 | lgfr %r2,%r2 # int |
272 | llgtr %r3,%r3 # const struct old_sigaction * | 232 | llgtr %r3,%r3 # const struct old_sigaction * |
273 | llgtr %r4,%r4 # struct old_sigaction32 * | 233 | llgtr %r4,%r4 # struct old_sigaction32 * |
274 | jg sys32_sigaction # branch to system call | 234 | jg sys32_sigaction # branch to system call |
275 | 235 | ||
276 | .globl sys32_setreuid16_wrapper | 236 | ENTRY(sys32_setreuid16_wrapper) |
277 | sys32_setreuid16_wrapper: | ||
278 | llgfr %r2,%r2 # __kernel_old_uid_emu31_t | 237 | llgfr %r2,%r2 # __kernel_old_uid_emu31_t |
279 | llgfr %r3,%r3 # __kernel_old_uid_emu31_t | 238 | llgfr %r3,%r3 # __kernel_old_uid_emu31_t |
280 | jg sys32_setreuid16 # branch to system call | 239 | jg sys32_setreuid16 # branch to system call |
281 | 240 | ||
282 | .globl sys32_setregid16_wrapper | 241 | ENTRY(sys32_setregid16_wrapper) |
283 | sys32_setregid16_wrapper: | ||
284 | llgfr %r2,%r2 # __kernel_old_gid_emu31_t | 242 | llgfr %r2,%r2 # __kernel_old_gid_emu31_t |
285 | llgfr %r3,%r3 # __kernel_old_gid_emu31_t | 243 | llgfr %r3,%r3 # __kernel_old_gid_emu31_t |
286 | jg sys32_setregid16 # branch to system call | 244 | jg sys32_setregid16 # branch to system call |
287 | 245 | ||
288 | .globl sys_sigsuspend_wrapper | 246 | ENTRY(sys_sigsuspend_wrapper) |
289 | sys_sigsuspend_wrapper: | ||
290 | lgfr %r2,%r2 # int | 247 | lgfr %r2,%r2 # int |
291 | lgfr %r3,%r3 # int | 248 | lgfr %r3,%r3 # int |
292 | llgfr %r4,%r4 # old_sigset_t | 249 | llgfr %r4,%r4 # old_sigset_t |
293 | jg sys_sigsuspend | 250 | jg sys_sigsuspend |
294 | 251 | ||
295 | .globl compat_sys_sigpending_wrapper | 252 | ENTRY(compat_sys_sigpending_wrapper) |
296 | compat_sys_sigpending_wrapper: | ||
297 | llgtr %r2,%r2 # compat_old_sigset_t * | 253 | llgtr %r2,%r2 # compat_old_sigset_t * |
298 | jg compat_sys_sigpending # branch to system call | 254 | jg compat_sys_sigpending # branch to system call |
299 | 255 | ||
300 | .globl sys32_sethostname_wrapper | 256 | ENTRY(sys32_sethostname_wrapper) |
301 | sys32_sethostname_wrapper: | ||
302 | llgtr %r2,%r2 # char * | 257 | llgtr %r2,%r2 # char * |
303 | lgfr %r3,%r3 # int | 258 | lgfr %r3,%r3 # int |
304 | jg sys_sethostname # branch to system call | 259 | jg sys_sethostname # branch to system call |
305 | 260 | ||
306 | .globl compat_sys_setrlimit_wrapper | 261 | ENTRY(compat_sys_setrlimit_wrapper) |
307 | compat_sys_setrlimit_wrapper: | ||
308 | llgfr %r2,%r2 # unsigned int | 262 | llgfr %r2,%r2 # unsigned int |
309 | llgtr %r3,%r3 # struct rlimit_emu31 * | 263 | llgtr %r3,%r3 # struct rlimit_emu31 * |
310 | jg compat_sys_setrlimit # branch to system call | 264 | jg compat_sys_setrlimit # branch to system call |
311 | 265 | ||
312 | .globl compat_sys_old_getrlimit_wrapper | 266 | ENTRY(compat_sys_old_getrlimit_wrapper) |
313 | compat_sys_old_getrlimit_wrapper: | ||
314 | llgfr %r2,%r2 # unsigned int | 267 | llgfr %r2,%r2 # unsigned int |
315 | llgtr %r3,%r3 # struct rlimit_emu31 * | 268 | llgtr %r3,%r3 # struct rlimit_emu31 * |
316 | jg compat_sys_old_getrlimit # branch to system call | 269 | jg compat_sys_old_getrlimit # branch to system call |
317 | 270 | ||
318 | .globl compat_sys_getrlimit_wrapper | 271 | ENTRY(compat_sys_getrlimit_wrapper) |
319 | compat_sys_getrlimit_wrapper: | ||
320 | llgfr %r2,%r2 # unsigned int | 272 | llgfr %r2,%r2 # unsigned int |
321 | llgtr %r3,%r3 # struct rlimit_emu31 * | 273 | llgtr %r3,%r3 # struct rlimit_emu31 * |
322 | jg compat_sys_getrlimit # branch to system call | 274 | jg compat_sys_getrlimit # branch to system call |
323 | 275 | ||
324 | .globl sys32_mmap2_wrapper | 276 | ENTRY(sys32_mmap2_wrapper) |
325 | sys32_mmap2_wrapper: | ||
326 | llgtr %r2,%r2 # struct mmap_arg_struct_emu31 * | 277 | llgtr %r2,%r2 # struct mmap_arg_struct_emu31 * |
327 | jg sys32_mmap2 # branch to system call | 278 | jg sys32_mmap2 # branch to system call |
328 | 279 | ||
329 | .globl compat_sys_getrusage_wrapper | 280 | ENTRY(compat_sys_getrusage_wrapper) |
330 | compat_sys_getrusage_wrapper: | ||
331 | lgfr %r2,%r2 # int | 281 | lgfr %r2,%r2 # int |
332 | llgtr %r3,%r3 # struct rusage_emu31 * | 282 | llgtr %r3,%r3 # struct rusage_emu31 * |
333 | jg compat_sys_getrusage # branch to system call | 283 | jg compat_sys_getrusage # branch to system call |
334 | 284 | ||
335 | .globl compat_sys_gettimeofday_wrapper | 285 | ENTRY(compat_sys_gettimeofday_wrapper) |
336 | compat_sys_gettimeofday_wrapper: | ||
337 | llgtr %r2,%r2 # struct timeval_emu31 * | 286 | llgtr %r2,%r2 # struct timeval_emu31 * |
338 | llgtr %r3,%r3 # struct timezone * | 287 | llgtr %r3,%r3 # struct timezone * |
339 | jg compat_sys_gettimeofday # branch to system call | 288 | jg compat_sys_gettimeofday # branch to system call |
340 | 289 | ||
341 | .globl compat_sys_settimeofday_wrapper | 290 | ENTRY(compat_sys_settimeofday_wrapper) |
342 | compat_sys_settimeofday_wrapper: | ||
343 | llgtr %r2,%r2 # struct timeval_emu31 * | 291 | llgtr %r2,%r2 # struct timeval_emu31 * |
344 | llgtr %r3,%r3 # struct timezone * | 292 | llgtr %r3,%r3 # struct timezone * |
345 | jg compat_sys_settimeofday # branch to system call | 293 | jg compat_sys_settimeofday # branch to system call |
346 | 294 | ||
347 | .globl sys32_getgroups16_wrapper | 295 | ENTRY(sys32_getgroups16_wrapper) |
348 | sys32_getgroups16_wrapper: | ||
349 | lgfr %r2,%r2 # int | 296 | lgfr %r2,%r2 # int |
350 | llgtr %r3,%r3 # __kernel_old_gid_emu31_t * | 297 | llgtr %r3,%r3 # __kernel_old_gid_emu31_t * |
351 | jg sys32_getgroups16 # branch to system call | 298 | jg sys32_getgroups16 # branch to system call |
352 | 299 | ||
353 | .globl sys32_setgroups16_wrapper | 300 | ENTRY(sys32_setgroups16_wrapper) |
354 | sys32_setgroups16_wrapper: | ||
355 | lgfr %r2,%r2 # int | 301 | lgfr %r2,%r2 # int |
356 | llgtr %r3,%r3 # __kernel_old_gid_emu31_t * | 302 | llgtr %r3,%r3 # __kernel_old_gid_emu31_t * |
357 | jg sys32_setgroups16 # branch to system call | 303 | jg sys32_setgroups16 # branch to system call |
358 | 304 | ||
359 | .globl sys32_symlink_wrapper | 305 | ENTRY(sys32_symlink_wrapper) |
360 | sys32_symlink_wrapper: | ||
361 | llgtr %r2,%r2 # const char * | 306 | llgtr %r2,%r2 # const char * |
362 | llgtr %r3,%r3 # const char * | 307 | llgtr %r3,%r3 # const char * |
363 | jg sys_symlink # branch to system call | 308 | jg sys_symlink # branch to system call |
364 | 309 | ||
365 | .globl sys32_readlink_wrapper | 310 | ENTRY(sys32_readlink_wrapper) |
366 | sys32_readlink_wrapper: | ||
367 | llgtr %r2,%r2 # const char * | 311 | llgtr %r2,%r2 # const char * |
368 | llgtr %r3,%r3 # char * | 312 | llgtr %r3,%r3 # char * |
369 | lgfr %r4,%r4 # int | 313 | lgfr %r4,%r4 # int |
370 | jg sys_readlink # branch to system call | 314 | jg sys_readlink # branch to system call |
371 | 315 | ||
372 | .globl sys32_uselib_wrapper | 316 | ENTRY(sys32_uselib_wrapper) |
373 | sys32_uselib_wrapper: | ||
374 | llgtr %r2,%r2 # const char * | 317 | llgtr %r2,%r2 # const char * |
375 | jg sys_uselib # branch to system call | 318 | jg sys_uselib # branch to system call |
376 | 319 | ||
377 | .globl sys32_swapon_wrapper | 320 | ENTRY(sys32_swapon_wrapper) |
378 | sys32_swapon_wrapper: | ||
379 | llgtr %r2,%r2 # const char * | 321 | llgtr %r2,%r2 # const char * |
380 | lgfr %r3,%r3 # int | 322 | lgfr %r3,%r3 # int |
381 | jg sys_swapon # branch to system call | 323 | jg sys_swapon # branch to system call |
382 | 324 | ||
383 | .globl sys32_reboot_wrapper | 325 | ENTRY(sys32_reboot_wrapper) |
384 | sys32_reboot_wrapper: | ||
385 | lgfr %r2,%r2 # int | 326 | lgfr %r2,%r2 # int |
386 | lgfr %r3,%r3 # int | 327 | lgfr %r3,%r3 # int |
387 | llgfr %r4,%r4 # unsigned int | 328 | llgfr %r4,%r4 # unsigned int |
388 | llgtr %r5,%r5 # void * | 329 | llgtr %r5,%r5 # void * |
389 | jg sys_reboot # branch to system call | 330 | jg sys_reboot # branch to system call |
390 | 331 | ||
391 | .globl old32_readdir_wrapper | 332 | ENTRY(old32_readdir_wrapper) |
392 | old32_readdir_wrapper: | ||
393 | llgfr %r2,%r2 # unsigned int | 333 | llgfr %r2,%r2 # unsigned int |
394 | llgtr %r3,%r3 # void * | 334 | llgtr %r3,%r3 # void * |
395 | llgfr %r4,%r4 # unsigned int | 335 | llgfr %r4,%r4 # unsigned int |
396 | jg compat_sys_old_readdir # branch to system call | 336 | jg compat_sys_old_readdir # branch to system call |
397 | 337 | ||
398 | .globl old32_mmap_wrapper | 338 | ENTRY(old32_mmap_wrapper) |
399 | old32_mmap_wrapper: | ||
400 | llgtr %r2,%r2 # struct mmap_arg_struct_emu31 * | 339 | llgtr %r2,%r2 # struct mmap_arg_struct_emu31 * |
401 | jg old32_mmap # branch to system call | 340 | jg old32_mmap # branch to system call |
402 | 341 | ||
403 | .globl sys32_munmap_wrapper | 342 | ENTRY(sys32_munmap_wrapper) |
404 | sys32_munmap_wrapper: | ||
405 | llgfr %r2,%r2 # unsigned long | 343 | llgfr %r2,%r2 # unsigned long |
406 | llgfr %r3,%r3 # size_t | 344 | llgfr %r3,%r3 # size_t |
407 | jg sys_munmap # branch to system call | 345 | jg sys_munmap # branch to system call |
408 | 346 | ||
409 | .globl sys32_truncate_wrapper | 347 | ENTRY(sys32_truncate_wrapper) |
410 | sys32_truncate_wrapper: | ||
411 | llgtr %r2,%r2 # const char * | 348 | llgtr %r2,%r2 # const char * |
412 | lgfr %r3,%r3 # long | 349 | lgfr %r3,%r3 # long |
413 | jg sys_truncate # branch to system call | 350 | jg sys_truncate # branch to system call |
414 | 351 | ||
415 | .globl sys32_ftruncate_wrapper | 352 | ENTRY(sys32_ftruncate_wrapper) |
416 | sys32_ftruncate_wrapper: | ||
417 | llgfr %r2,%r2 # unsigned int | 353 | llgfr %r2,%r2 # unsigned int |
418 | llgfr %r3,%r3 # unsigned long | 354 | llgfr %r3,%r3 # unsigned long |
419 | jg sys_ftruncate # branch to system call | 355 | jg sys_ftruncate # branch to system call |
420 | 356 | ||
421 | .globl sys32_fchmod_wrapper | 357 | ENTRY(sys32_fchmod_wrapper) |
422 | sys32_fchmod_wrapper: | ||
423 | llgfr %r2,%r2 # unsigned int | 358 | llgfr %r2,%r2 # unsigned int |
424 | llgfr %r3,%r3 # mode_t | 359 | llgfr %r3,%r3 # mode_t |
425 | jg sys_fchmod # branch to system call | 360 | jg sys_fchmod # branch to system call |
426 | 361 | ||
427 | .globl sys32_fchown16_wrapper | 362 | ENTRY(sys32_fchown16_wrapper) |
428 | sys32_fchown16_wrapper: | ||
429 | llgfr %r2,%r2 # unsigned int | 363 | llgfr %r2,%r2 # unsigned int |
430 | llgfr %r3,%r3 # compat_uid_t | 364 | llgfr %r3,%r3 # compat_uid_t |
431 | llgfr %r4,%r4 # compat_uid_t | 365 | llgfr %r4,%r4 # compat_uid_t |
432 | jg sys32_fchown16 # branch to system call | 366 | jg sys32_fchown16 # branch to system call |
433 | 367 | ||
434 | .globl sys32_getpriority_wrapper | 368 | ENTRY(sys32_getpriority_wrapper) |
435 | sys32_getpriority_wrapper: | ||
436 | lgfr %r2,%r2 # int | 369 | lgfr %r2,%r2 # int |
437 | lgfr %r3,%r3 # int | 370 | lgfr %r3,%r3 # int |
438 | jg sys_getpriority # branch to system call | 371 | jg sys_getpriority # branch to system call |
439 | 372 | ||
440 | .globl sys32_setpriority_wrapper | 373 | ENTRY(sys32_setpriority_wrapper) |
441 | sys32_setpriority_wrapper: | ||
442 | lgfr %r2,%r2 # int | 374 | lgfr %r2,%r2 # int |
443 | lgfr %r3,%r3 # int | 375 | lgfr %r3,%r3 # int |
444 | lgfr %r4,%r4 # int | 376 | lgfr %r4,%r4 # int |
445 | jg sys_setpriority # branch to system call | 377 | jg sys_setpriority # branch to system call |
446 | 378 | ||
447 | .globl compat_sys_statfs_wrapper | 379 | ENTRY(compat_sys_statfs_wrapper) |
448 | compat_sys_statfs_wrapper: | ||
449 | llgtr %r2,%r2 # char * | 380 | llgtr %r2,%r2 # char * |
450 | llgtr %r3,%r3 # struct compat_statfs * | 381 | llgtr %r3,%r3 # struct compat_statfs * |
451 | jg compat_sys_statfs # branch to system call | 382 | jg compat_sys_statfs # branch to system call |
452 | 383 | ||
453 | .globl compat_sys_fstatfs_wrapper | 384 | ENTRY(compat_sys_fstatfs_wrapper) |
454 | compat_sys_fstatfs_wrapper: | ||
455 | llgfr %r2,%r2 # unsigned int | 385 | llgfr %r2,%r2 # unsigned int |
456 | llgtr %r3,%r3 # struct compat_statfs * | 386 | llgtr %r3,%r3 # struct compat_statfs * |
457 | jg compat_sys_fstatfs # branch to system call | 387 | jg compat_sys_fstatfs # branch to system call |
458 | 388 | ||
459 | .globl compat_sys_socketcall_wrapper | 389 | ENTRY(compat_sys_socketcall_wrapper) |
460 | compat_sys_socketcall_wrapper: | ||
461 | lgfr %r2,%r2 # int | 390 | lgfr %r2,%r2 # int |
462 | llgtr %r3,%r3 # u32 * | 391 | llgtr %r3,%r3 # u32 * |
463 | jg compat_sys_socketcall # branch to system call | 392 | jg compat_sys_socketcall # branch to system call |
464 | 393 | ||
465 | .globl sys32_syslog_wrapper | 394 | ENTRY(sys32_syslog_wrapper) |
466 | sys32_syslog_wrapper: | ||
467 | lgfr %r2,%r2 # int | 395 | lgfr %r2,%r2 # int |
468 | llgtr %r3,%r3 # char * | 396 | llgtr %r3,%r3 # char * |
469 | lgfr %r4,%r4 # int | 397 | lgfr %r4,%r4 # int |
470 | jg sys_syslog # branch to system call | 398 | jg sys_syslog # branch to system call |
471 | 399 | ||
472 | .globl compat_sys_setitimer_wrapper | 400 | ENTRY(compat_sys_setitimer_wrapper) |
473 | compat_sys_setitimer_wrapper: | ||
474 | lgfr %r2,%r2 # int | 401 | lgfr %r2,%r2 # int |
475 | llgtr %r3,%r3 # struct itimerval_emu31 * | 402 | llgtr %r3,%r3 # struct itimerval_emu31 * |
476 | llgtr %r4,%r4 # struct itimerval_emu31 * | 403 | llgtr %r4,%r4 # struct itimerval_emu31 * |
477 | jg compat_sys_setitimer # branch to system call | 404 | jg compat_sys_setitimer # branch to system call |
478 | 405 | ||
479 | .globl compat_sys_getitimer_wrapper | 406 | ENTRY(compat_sys_getitimer_wrapper) |
480 | compat_sys_getitimer_wrapper: | ||
481 | lgfr %r2,%r2 # int | 407 | lgfr %r2,%r2 # int |
482 | llgtr %r3,%r3 # struct itimerval_emu31 * | 408 | llgtr %r3,%r3 # struct itimerval_emu31 * |
483 | jg compat_sys_getitimer # branch to system call | 409 | jg compat_sys_getitimer # branch to system call |
484 | 410 | ||
485 | .globl compat_sys_newstat_wrapper | 411 | ENTRY(compat_sys_newstat_wrapper) |
486 | compat_sys_newstat_wrapper: | ||
487 | llgtr %r2,%r2 # char * | 412 | llgtr %r2,%r2 # char * |
488 | llgtr %r3,%r3 # struct stat_emu31 * | 413 | llgtr %r3,%r3 # struct stat_emu31 * |
489 | jg compat_sys_newstat # branch to system call | 414 | jg compat_sys_newstat # branch to system call |
490 | 415 | ||
491 | .globl compat_sys_newlstat_wrapper | 416 | ENTRY(compat_sys_newlstat_wrapper) |
492 | compat_sys_newlstat_wrapper: | ||
493 | llgtr %r2,%r2 # char * | 417 | llgtr %r2,%r2 # char * |
494 | llgtr %r3,%r3 # struct stat_emu31 * | 418 | llgtr %r3,%r3 # struct stat_emu31 * |
495 | jg compat_sys_newlstat # branch to system call | 419 | jg compat_sys_newlstat # branch to system call |
496 | 420 | ||
497 | .globl compat_sys_newfstat_wrapper | 421 | ENTRY(compat_sys_newfstat_wrapper) |
498 | compat_sys_newfstat_wrapper: | ||
499 | llgfr %r2,%r2 # unsigned int | 422 | llgfr %r2,%r2 # unsigned int |
500 | llgtr %r3,%r3 # struct stat_emu31 * | 423 | llgtr %r3,%r3 # struct stat_emu31 * |
501 | jg compat_sys_newfstat # branch to system call | 424 | jg compat_sys_newfstat # branch to system call |
502 | 425 | ||
503 | #sys32_vhangup_wrapper # void | 426 | #sys32_vhangup_wrapper # void |
504 | 427 | ||
505 | .globl compat_sys_wait4_wrapper | 428 | ENTRY(compat_sys_wait4_wrapper) |
506 | compat_sys_wait4_wrapper: | ||
507 | lgfr %r2,%r2 # pid_t | 429 | lgfr %r2,%r2 # pid_t |
508 | llgtr %r3,%r3 # unsigned int * | 430 | llgtr %r3,%r3 # unsigned int * |
509 | lgfr %r4,%r4 # int | 431 | lgfr %r4,%r4 # int |
510 | llgtr %r5,%r5 # struct rusage * | 432 | llgtr %r5,%r5 # struct rusage * |
511 | jg compat_sys_wait4 # branch to system call | 433 | jg compat_sys_wait4 # branch to system call |
512 | 434 | ||
513 | .globl sys32_swapoff_wrapper | 435 | ENTRY(sys32_swapoff_wrapper) |
514 | sys32_swapoff_wrapper: | ||
515 | llgtr %r2,%r2 # const char * | 436 | llgtr %r2,%r2 # const char * |
516 | jg sys_swapoff # branch to system call | 437 | jg sys_swapoff # branch to system call |
517 | 438 | ||
518 | .globl compat_sys_sysinfo_wrapper | 439 | ENTRY(compat_sys_sysinfo_wrapper) |
519 | compat_sys_sysinfo_wrapper: | ||
520 | llgtr %r2,%r2 # struct sysinfo_emu31 * | 440 | llgtr %r2,%r2 # struct sysinfo_emu31 * |
521 | jg compat_sys_sysinfo # branch to system call | 441 | jg compat_sys_sysinfo # branch to system call |
522 | 442 | ||
523 | .globl sys32_ipc_wrapper | 443 | ENTRY(sys32_ipc_wrapper) |
524 | sys32_ipc_wrapper: | ||
525 | llgfr %r2,%r2 # uint | 444 | llgfr %r2,%r2 # uint |
526 | lgfr %r3,%r3 # int | 445 | lgfr %r3,%r3 # int |
527 | lgfr %r4,%r4 # int | 446 | lgfr %r4,%r4 # int |
@@ -529,8 +448,7 @@ sys32_ipc_wrapper: | |||
529 | llgfr %r6,%r6 # u32 | 448 | llgfr %r6,%r6 # u32 |
530 | jg sys32_ipc # branch to system call | 449 | jg sys32_ipc # branch to system call |
531 | 450 | ||
532 | .globl sys32_fsync_wrapper | 451 | ENTRY(sys32_fsync_wrapper) |
533 | sys32_fsync_wrapper: | ||
534 | llgfr %r2,%r2 # unsigned int | 452 | llgfr %r2,%r2 # unsigned int |
535 | jg sys_fsync # branch to system call | 453 | jg sys_fsync # branch to system call |
536 | 454 | ||
@@ -538,97 +456,81 @@ sys32_fsync_wrapper: | |||
538 | 456 | ||
539 | #sys32_clone_wrapper # done in clone_glue | 457 | #sys32_clone_wrapper # done in clone_glue |
540 | 458 | ||
541 | .globl sys32_setdomainname_wrapper | 459 | ENTRY(sys32_setdomainname_wrapper) |
542 | sys32_setdomainname_wrapper: | ||
543 | llgtr %r2,%r2 # char * | 460 | llgtr %r2,%r2 # char * |
544 | lgfr %r3,%r3 # int | 461 | lgfr %r3,%r3 # int |
545 | jg sys_setdomainname # branch to system call | 462 | jg sys_setdomainname # branch to system call |
546 | 463 | ||
547 | .globl sys32_newuname_wrapper | 464 | ENTRY(sys32_newuname_wrapper) |
548 | sys32_newuname_wrapper: | ||
549 | llgtr %r2,%r2 # struct new_utsname * | 465 | llgtr %r2,%r2 # struct new_utsname * |
550 | jg sys_newuname # branch to system call | 466 | jg sys_newuname # branch to system call |
551 | 467 | ||
552 | .globl compat_sys_adjtimex_wrapper | 468 | ENTRY(compat_sys_adjtimex_wrapper) |
553 | compat_sys_adjtimex_wrapper: | ||
554 | llgtr %r2,%r2 # struct compat_timex * | 469 | llgtr %r2,%r2 # struct compat_timex * |
555 | jg compat_sys_adjtimex # branch to system call | 470 | jg compat_sys_adjtimex # branch to system call |
556 | 471 | ||
557 | .globl sys32_mprotect_wrapper | 472 | ENTRY(sys32_mprotect_wrapper) |
558 | sys32_mprotect_wrapper: | ||
559 | llgtr %r2,%r2 # unsigned long (actually pointer | 473 | llgtr %r2,%r2 # unsigned long (actually pointer |
560 | llgfr %r3,%r3 # size_t | 474 | llgfr %r3,%r3 # size_t |
561 | llgfr %r4,%r4 # unsigned long | 475 | llgfr %r4,%r4 # unsigned long |
562 | jg sys_mprotect # branch to system call | 476 | jg sys_mprotect # branch to system call |
563 | 477 | ||
564 | .globl compat_sys_sigprocmask_wrapper | 478 | ENTRY(compat_sys_sigprocmask_wrapper) |
565 | compat_sys_sigprocmask_wrapper: | ||
566 | lgfr %r2,%r2 # int | 479 | lgfr %r2,%r2 # int |
567 | llgtr %r3,%r3 # compat_old_sigset_t * | 480 | llgtr %r3,%r3 # compat_old_sigset_t * |
568 | llgtr %r4,%r4 # compat_old_sigset_t * | 481 | llgtr %r4,%r4 # compat_old_sigset_t * |
569 | jg compat_sys_sigprocmask # branch to system call | 482 | jg compat_sys_sigprocmask # branch to system call |
570 | 483 | ||
571 | .globl sys_init_module_wrapper | 484 | ENTRY(sys_init_module_wrapper) |
572 | sys_init_module_wrapper: | ||
573 | llgtr %r2,%r2 # void * | 485 | llgtr %r2,%r2 # void * |
574 | llgfr %r3,%r3 # unsigned long | 486 | llgfr %r3,%r3 # unsigned long |
575 | llgtr %r4,%r4 # char * | 487 | llgtr %r4,%r4 # char * |
576 | jg sys_init_module # branch to system call | 488 | jg sys_init_module # branch to system call |
577 | 489 | ||
578 | .globl sys_delete_module_wrapper | 490 | ENTRY(sys_delete_module_wrapper) |
579 | sys_delete_module_wrapper: | ||
580 | llgtr %r2,%r2 # const char * | 491 | llgtr %r2,%r2 # const char * |
581 | llgfr %r3,%r3 # unsigned int | 492 | llgfr %r3,%r3 # unsigned int |
582 | jg sys_delete_module # branch to system call | 493 | jg sys_delete_module # branch to system call |
583 | 494 | ||
584 | .globl sys32_quotactl_wrapper | 495 | ENTRY(sys32_quotactl_wrapper) |
585 | sys32_quotactl_wrapper: | ||
586 | llgfr %r2,%r2 # unsigned int | 496 | llgfr %r2,%r2 # unsigned int |
587 | llgtr %r3,%r3 # const char * | 497 | llgtr %r3,%r3 # const char * |
588 | llgfr %r4,%r4 # qid_t | 498 | llgfr %r4,%r4 # qid_t |
589 | llgtr %r5,%r5 # caddr_t | 499 | llgtr %r5,%r5 # caddr_t |
590 | jg sys_quotactl # branch to system call | 500 | jg sys_quotactl # branch to system call |
591 | 501 | ||
592 | .globl sys32_getpgid_wrapper | 502 | ENTRY(sys32_getpgid_wrapper) |
593 | sys32_getpgid_wrapper: | ||
594 | lgfr %r2,%r2 # pid_t | 503 | lgfr %r2,%r2 # pid_t |
595 | jg sys_getpgid # branch to system call | 504 | jg sys_getpgid # branch to system call |
596 | 505 | ||
597 | .globl sys32_fchdir_wrapper | 506 | ENTRY(sys32_fchdir_wrapper) |
598 | sys32_fchdir_wrapper: | ||
599 | llgfr %r2,%r2 # unsigned int | 507 | llgfr %r2,%r2 # unsigned int |
600 | jg sys_fchdir # branch to system call | 508 | jg sys_fchdir # branch to system call |
601 | 509 | ||
602 | .globl sys32_bdflush_wrapper | 510 | ENTRY(sys32_bdflush_wrapper) |
603 | sys32_bdflush_wrapper: | ||
604 | lgfr %r2,%r2 # int | 511 | lgfr %r2,%r2 # int |
605 | lgfr %r3,%r3 # long | 512 | lgfr %r3,%r3 # long |
606 | jg sys_bdflush # branch to system call | 513 | jg sys_bdflush # branch to system call |
607 | 514 | ||
608 | .globl sys32_sysfs_wrapper | 515 | ENTRY(sys32_sysfs_wrapper) |
609 | sys32_sysfs_wrapper: | ||
610 | lgfr %r2,%r2 # int | 516 | lgfr %r2,%r2 # int |
611 | llgfr %r3,%r3 # unsigned long | 517 | llgfr %r3,%r3 # unsigned long |
612 | llgfr %r4,%r4 # unsigned long | 518 | llgfr %r4,%r4 # unsigned long |
613 | jg sys_sysfs # branch to system call | 519 | jg sys_sysfs # branch to system call |
614 | 520 | ||
615 | .globl sys32_personality_wrapper | 521 | ENTRY(sys32_personality_wrapper) |
616 | sys32_personality_wrapper: | ||
617 | llgfr %r2,%r2 # unsigned int | 522 | llgfr %r2,%r2 # unsigned int |
618 | jg sys_s390_personality # branch to system call | 523 | jg sys_s390_personality # branch to system call |
619 | 524 | ||
620 | .globl sys32_setfsuid16_wrapper | 525 | ENTRY(sys32_setfsuid16_wrapper) |
621 | sys32_setfsuid16_wrapper: | ||
622 | llgfr %r2,%r2 # __kernel_old_uid_emu31_t | 526 | llgfr %r2,%r2 # __kernel_old_uid_emu31_t |
623 | jg sys32_setfsuid16 # branch to system call | 527 | jg sys32_setfsuid16 # branch to system call |
624 | 528 | ||
625 | .globl sys32_setfsgid16_wrapper | 529 | ENTRY(sys32_setfsgid16_wrapper) |
626 | sys32_setfsgid16_wrapper: | ||
627 | llgfr %r2,%r2 # __kernel_old_gid_emu31_t | 530 | llgfr %r2,%r2 # __kernel_old_gid_emu31_t |
628 | jg sys32_setfsgid16 # branch to system call | 531 | jg sys32_setfsgid16 # branch to system call |
629 | 532 | ||
630 | .globl sys32_llseek_wrapper | 533 | ENTRY(sys32_llseek_wrapper) |
631 | sys32_llseek_wrapper: | ||
632 | llgfr %r2,%r2 # unsigned int | 534 | llgfr %r2,%r2 # unsigned int |
633 | llgfr %r3,%r3 # unsigned long | 535 | llgfr %r3,%r3 # unsigned long |
634 | llgfr %r4,%r4 # unsigned long | 536 | llgfr %r4,%r4 # unsigned long |
@@ -636,15 +538,13 @@ sys32_llseek_wrapper: | |||
636 | llgfr %r6,%r6 # unsigned int | 538 | llgfr %r6,%r6 # unsigned int |
637 | jg sys_llseek # branch to system call | 539 | jg sys_llseek # branch to system call |
638 | 540 | ||
639 | .globl sys32_getdents_wrapper | 541 | ENTRY(sys32_getdents_wrapper) |
640 | sys32_getdents_wrapper: | ||
641 | llgfr %r2,%r2 # unsigned int | 542 | llgfr %r2,%r2 # unsigned int |
642 | llgtr %r3,%r3 # void * | 543 | llgtr %r3,%r3 # void * |
643 | llgfr %r4,%r4 # unsigned int | 544 | llgfr %r4,%r4 # unsigned int |
644 | jg compat_sys_getdents # branch to system call | 545 | jg compat_sys_getdents # branch to system call |
645 | 546 | ||
646 | .globl compat_sys_select_wrapper | 547 | ENTRY(compat_sys_select_wrapper) |
647 | compat_sys_select_wrapper: | ||
648 | lgfr %r2,%r2 # int | 548 | lgfr %r2,%r2 # int |
649 | llgtr %r3,%r3 # compat_fd_set * | 549 | llgtr %r3,%r3 # compat_fd_set * |
650 | llgtr %r4,%r4 # compat_fd_set * | 550 | llgtr %r4,%r4 # compat_fd_set * |
@@ -652,112 +552,94 @@ compat_sys_select_wrapper: | |||
652 | llgtr %r6,%r6 # struct compat_timeval * | 552 | llgtr %r6,%r6 # struct compat_timeval * |
653 | jg compat_sys_select # branch to system call | 553 | jg compat_sys_select # branch to system call |
654 | 554 | ||
655 | .globl sys32_flock_wrapper | 555 | ENTRY(sys32_flock_wrapper) |
656 | sys32_flock_wrapper: | ||
657 | llgfr %r2,%r2 # unsigned int | 556 | llgfr %r2,%r2 # unsigned int |
658 | llgfr %r3,%r3 # unsigned int | 557 | llgfr %r3,%r3 # unsigned int |
659 | jg sys_flock # branch to system call | 558 | jg sys_flock # branch to system call |
660 | 559 | ||
661 | .globl sys32_msync_wrapper | 560 | ENTRY(sys32_msync_wrapper) |
662 | sys32_msync_wrapper: | ||
663 | llgfr %r2,%r2 # unsigned long | 561 | llgfr %r2,%r2 # unsigned long |
664 | llgfr %r3,%r3 # size_t | 562 | llgfr %r3,%r3 # size_t |
665 | lgfr %r4,%r4 # int | 563 | lgfr %r4,%r4 # int |
666 | jg sys_msync # branch to system call | 564 | jg sys_msync # branch to system call |
667 | 565 | ||
668 | .globl compat_sys_readv_wrapper | 566 | ENTRY(compat_sys_readv_wrapper) |
669 | compat_sys_readv_wrapper: | ||
670 | lgfr %r2,%r2 # int | 567 | lgfr %r2,%r2 # int |
671 | llgtr %r3,%r3 # const struct compat_iovec * | 568 | llgtr %r3,%r3 # const struct compat_iovec * |
672 | llgfr %r4,%r4 # unsigned long | 569 | llgfr %r4,%r4 # unsigned long |
673 | jg compat_sys_readv # branch to system call | 570 | jg compat_sys_readv # branch to system call |
674 | 571 | ||
675 | .globl compat_sys_writev_wrapper | 572 | ENTRY(compat_sys_writev_wrapper) |
676 | compat_sys_writev_wrapper: | ||
677 | lgfr %r2,%r2 # int | 573 | lgfr %r2,%r2 # int |
678 | llgtr %r3,%r3 # const struct compat_iovec * | 574 | llgtr %r3,%r3 # const struct compat_iovec * |
679 | llgfr %r4,%r4 # unsigned long | 575 | llgfr %r4,%r4 # unsigned long |
680 | jg compat_sys_writev # branch to system call | 576 | jg compat_sys_writev # branch to system call |
681 | 577 | ||
682 | .globl sys32_getsid_wrapper | 578 | ENTRY(sys32_getsid_wrapper) |
683 | sys32_getsid_wrapper: | ||
684 | lgfr %r2,%r2 # pid_t | 579 | lgfr %r2,%r2 # pid_t |
685 | jg sys_getsid # branch to system call | 580 | jg sys_getsid # branch to system call |
686 | 581 | ||
687 | .globl sys32_fdatasync_wrapper | 582 | ENTRY(sys32_fdatasync_wrapper) |
688 | sys32_fdatasync_wrapper: | ||
689 | llgfr %r2,%r2 # unsigned int | 583 | llgfr %r2,%r2 # unsigned int |
690 | jg sys_fdatasync # branch to system call | 584 | jg sys_fdatasync # branch to system call |
691 | 585 | ||
692 | .globl sys32_mlock_wrapper | 586 | ENTRY(sys32_mlock_wrapper) |
693 | sys32_mlock_wrapper: | ||
694 | llgfr %r2,%r2 # unsigned long | 587 | llgfr %r2,%r2 # unsigned long |
695 | llgfr %r3,%r3 # size_t | 588 | llgfr %r3,%r3 # size_t |
696 | jg sys_mlock # branch to system call | 589 | jg sys_mlock # branch to system call |
697 | 590 | ||
698 | .globl sys32_munlock_wrapper | 591 | ENTRY(sys32_munlock_wrapper) |
699 | sys32_munlock_wrapper: | ||
700 | llgfr %r2,%r2 # unsigned long | 592 | llgfr %r2,%r2 # unsigned long |
701 | llgfr %r3,%r3 # size_t | 593 | llgfr %r3,%r3 # size_t |
702 | jg sys_munlock # branch to system call | 594 | jg sys_munlock # branch to system call |
703 | 595 | ||
704 | .globl sys32_mlockall_wrapper | 596 | ENTRY(sys32_mlockall_wrapper) |
705 | sys32_mlockall_wrapper: | ||
706 | lgfr %r2,%r2 # int | 597 | lgfr %r2,%r2 # int |
707 | jg sys_mlockall # branch to system call | 598 | jg sys_mlockall # branch to system call |
708 | 599 | ||
709 | #sys32_munlockall_wrapper # void | 600 | #sys32_munlockall_wrapper # void |
710 | 601 | ||
711 | .globl sys32_sched_setparam_wrapper | 602 | ENTRY(sys32_sched_setparam_wrapper) |
712 | sys32_sched_setparam_wrapper: | ||
713 | lgfr %r2,%r2 # pid_t | 603 | lgfr %r2,%r2 # pid_t |
714 | llgtr %r3,%r3 # struct sched_param * | 604 | llgtr %r3,%r3 # struct sched_param * |
715 | jg sys_sched_setparam # branch to system call | 605 | jg sys_sched_setparam # branch to system call |
716 | 606 | ||
717 | .globl sys32_sched_getparam_wrapper | 607 | ENTRY(sys32_sched_getparam_wrapper) |
718 | sys32_sched_getparam_wrapper: | ||
719 | lgfr %r2,%r2 # pid_t | 608 | lgfr %r2,%r2 # pid_t |
720 | llgtr %r3,%r3 # struct sched_param * | 609 | llgtr %r3,%r3 # struct sched_param * |
721 | jg sys_sched_getparam # branch to system call | 610 | jg sys_sched_getparam # branch to system call |
722 | 611 | ||
723 | .globl sys32_sched_setscheduler_wrapper | 612 | ENTRY(sys32_sched_setscheduler_wrapper) |
724 | sys32_sched_setscheduler_wrapper: | ||
725 | lgfr %r2,%r2 # pid_t | 613 | lgfr %r2,%r2 # pid_t |
726 | lgfr %r3,%r3 # int | 614 | lgfr %r3,%r3 # int |
727 | llgtr %r4,%r4 # struct sched_param * | 615 | llgtr %r4,%r4 # struct sched_param * |
728 | jg sys_sched_setscheduler # branch to system call | 616 | jg sys_sched_setscheduler # branch to system call |
729 | 617 | ||
730 | .globl sys32_sched_getscheduler_wrapper | 618 | ENTRY(sys32_sched_getscheduler_wrapper) |
731 | sys32_sched_getscheduler_wrapper: | ||
732 | lgfr %r2,%r2 # pid_t | 619 | lgfr %r2,%r2 # pid_t |
733 | jg sys_sched_getscheduler # branch to system call | 620 | jg sys_sched_getscheduler # branch to system call |
734 | 621 | ||
735 | #sys32_sched_yield_wrapper # void | 622 | #sys32_sched_yield_wrapper # void |
736 | 623 | ||
737 | .globl sys32_sched_get_priority_max_wrapper | 624 | ENTRY(sys32_sched_get_priority_max_wrapper) |
738 | sys32_sched_get_priority_max_wrapper: | ||
739 | lgfr %r2,%r2 # int | 625 | lgfr %r2,%r2 # int |
740 | jg sys_sched_get_priority_max # branch to system call | 626 | jg sys_sched_get_priority_max # branch to system call |
741 | 627 | ||
742 | .globl sys32_sched_get_priority_min_wrapper | 628 | ENTRY(sys32_sched_get_priority_min_wrapper) |
743 | sys32_sched_get_priority_min_wrapper: | ||
744 | lgfr %r2,%r2 # int | 629 | lgfr %r2,%r2 # int |
745 | jg sys_sched_get_priority_min # branch to system call | 630 | jg sys_sched_get_priority_min # branch to system call |
746 | 631 | ||
747 | .globl sys32_sched_rr_get_interval_wrapper | 632 | ENTRY(sys32_sched_rr_get_interval_wrapper) |
748 | sys32_sched_rr_get_interval_wrapper: | ||
749 | lgfr %r2,%r2 # pid_t | 633 | lgfr %r2,%r2 # pid_t |
750 | llgtr %r3,%r3 # struct compat_timespec * | 634 | llgtr %r3,%r3 # struct compat_timespec * |
751 | jg sys32_sched_rr_get_interval # branch to system call | 635 | jg sys32_sched_rr_get_interval # branch to system call |
752 | 636 | ||
753 | .globl compat_sys_nanosleep_wrapper | 637 | ENTRY(compat_sys_nanosleep_wrapper) |
754 | compat_sys_nanosleep_wrapper: | ||
755 | llgtr %r2,%r2 # struct compat_timespec * | 638 | llgtr %r2,%r2 # struct compat_timespec * |
756 | llgtr %r3,%r3 # struct compat_timespec * | 639 | llgtr %r3,%r3 # struct compat_timespec * |
757 | jg compat_sys_nanosleep # branch to system call | 640 | jg compat_sys_nanosleep # branch to system call |
758 | 641 | ||
759 | .globl sys32_mremap_wrapper | 642 | ENTRY(sys32_mremap_wrapper) |
760 | sys32_mremap_wrapper: | ||
761 | llgfr %r2,%r2 # unsigned long | 643 | llgfr %r2,%r2 # unsigned long |
762 | llgfr %r3,%r3 # unsigned long | 644 | llgfr %r3,%r3 # unsigned long |
763 | llgfr %r4,%r4 # unsigned long | 645 | llgfr %r4,%r4 # unsigned long |
@@ -765,50 +647,43 @@ sys32_mremap_wrapper: | |||
765 | llgfr %r6,%r6 # unsigned long | 647 | llgfr %r6,%r6 # unsigned long |
766 | jg sys_mremap # branch to system call | 648 | jg sys_mremap # branch to system call |
767 | 649 | ||
768 | .globl sys32_setresuid16_wrapper | 650 | ENTRY(sys32_setresuid16_wrapper) |
769 | sys32_setresuid16_wrapper: | ||
770 | llgfr %r2,%r2 # __kernel_old_uid_emu31_t | 651 | llgfr %r2,%r2 # __kernel_old_uid_emu31_t |
771 | llgfr %r3,%r3 # __kernel_old_uid_emu31_t | 652 | llgfr %r3,%r3 # __kernel_old_uid_emu31_t |
772 | llgfr %r4,%r4 # __kernel_old_uid_emu31_t | 653 | llgfr %r4,%r4 # __kernel_old_uid_emu31_t |
773 | jg sys32_setresuid16 # branch to system call | 654 | jg sys32_setresuid16 # branch to system call |
774 | 655 | ||
775 | .globl sys32_getresuid16_wrapper | 656 | ENTRY(sys32_getresuid16_wrapper) |
776 | sys32_getresuid16_wrapper: | ||
777 | llgtr %r2,%r2 # __kernel_old_uid_emu31_t * | 657 | llgtr %r2,%r2 # __kernel_old_uid_emu31_t * |
778 | llgtr %r3,%r3 # __kernel_old_uid_emu31_t * | 658 | llgtr %r3,%r3 # __kernel_old_uid_emu31_t * |
779 | llgtr %r4,%r4 # __kernel_old_uid_emu31_t * | 659 | llgtr %r4,%r4 # __kernel_old_uid_emu31_t * |
780 | jg sys32_getresuid16 # branch to system call | 660 | jg sys32_getresuid16 # branch to system call |
781 | 661 | ||
782 | .globl sys32_poll_wrapper | 662 | ENTRY(sys32_poll_wrapper) |
783 | sys32_poll_wrapper: | ||
784 | llgtr %r2,%r2 # struct pollfd * | 663 | llgtr %r2,%r2 # struct pollfd * |
785 | llgfr %r3,%r3 # unsigned int | 664 | llgfr %r3,%r3 # unsigned int |
786 | lgfr %r4,%r4 # long | 665 | lgfr %r4,%r4 # long |
787 | jg sys_poll # branch to system call | 666 | jg sys_poll # branch to system call |
788 | 667 | ||
789 | .globl compat_sys_nfsservctl_wrapper | 668 | ENTRY(compat_sys_nfsservctl_wrapper) |
790 | compat_sys_nfsservctl_wrapper: | ||
791 | lgfr %r2,%r2 # int | 669 | lgfr %r2,%r2 # int |
792 | llgtr %r3,%r3 # struct compat_nfsctl_arg* | 670 | llgtr %r3,%r3 # struct compat_nfsctl_arg* |
793 | llgtr %r4,%r4 # union compat_nfsctl_res* | 671 | llgtr %r4,%r4 # union compat_nfsctl_res* |
794 | jg compat_sys_nfsservctl # branch to system call | 672 | jg compat_sys_nfsservctl # branch to system call |
795 | 673 | ||
796 | .globl sys32_setresgid16_wrapper | 674 | ENTRY(sys32_setresgid16_wrapper) |
797 | sys32_setresgid16_wrapper: | ||
798 | llgfr %r2,%r2 # __kernel_old_gid_emu31_t | 675 | llgfr %r2,%r2 # __kernel_old_gid_emu31_t |
799 | llgfr %r3,%r3 # __kernel_old_gid_emu31_t | 676 | llgfr %r3,%r3 # __kernel_old_gid_emu31_t |
800 | llgfr %r4,%r4 # __kernel_old_gid_emu31_t | 677 | llgfr %r4,%r4 # __kernel_old_gid_emu31_t |
801 | jg sys32_setresgid16 # branch to system call | 678 | jg sys32_setresgid16 # branch to system call |
802 | 679 | ||
803 | .globl sys32_getresgid16_wrapper | 680 | ENTRY(sys32_getresgid16_wrapper) |
804 | sys32_getresgid16_wrapper: | ||
805 | llgtr %r2,%r2 # __kernel_old_gid_emu31_t * | 681 | llgtr %r2,%r2 # __kernel_old_gid_emu31_t * |
806 | llgtr %r3,%r3 # __kernel_old_gid_emu31_t * | 682 | llgtr %r3,%r3 # __kernel_old_gid_emu31_t * |
807 | llgtr %r4,%r4 # __kernel_old_gid_emu31_t * | 683 | llgtr %r4,%r4 # __kernel_old_gid_emu31_t * |
808 | jg sys32_getresgid16 # branch to system call | 684 | jg sys32_getresgid16 # branch to system call |
809 | 685 | ||
810 | .globl sys32_prctl_wrapper | 686 | ENTRY(sys32_prctl_wrapper) |
811 | sys32_prctl_wrapper: | ||
812 | lgfr %r2,%r2 # int | 687 | lgfr %r2,%r2 # int |
813 | llgfr %r3,%r3 # unsigned long | 688 | llgfr %r3,%r3 # unsigned long |
814 | llgfr %r4,%r4 # unsigned long | 689 | llgfr %r4,%r4 # unsigned long |
@@ -818,51 +693,44 @@ sys32_prctl_wrapper: | |||
818 | 693 | ||
819 | #sys32_rt_sigreturn_wrapper # done in rt_sigreturn_glue | 694 | #sys32_rt_sigreturn_wrapper # done in rt_sigreturn_glue |
820 | 695 | ||
821 | .globl sys32_rt_sigaction_wrapper | 696 | ENTRY(sys32_rt_sigaction_wrapper) |
822 | sys32_rt_sigaction_wrapper: | ||
823 | lgfr %r2,%r2 # int | 697 | lgfr %r2,%r2 # int |
824 | llgtr %r3,%r3 # const struct sigaction_emu31 * | 698 | llgtr %r3,%r3 # const struct sigaction_emu31 * |
825 | llgtr %r4,%r4 # const struct sigaction_emu31 * | 699 | llgtr %r4,%r4 # const struct sigaction_emu31 * |
826 | llgfr %r5,%r5 # size_t | 700 | llgfr %r5,%r5 # size_t |
827 | jg sys32_rt_sigaction # branch to system call | 701 | jg sys32_rt_sigaction # branch to system call |
828 | 702 | ||
829 | .globl sys32_rt_sigprocmask_wrapper | 703 | ENTRY(sys32_rt_sigprocmask_wrapper) |
830 | sys32_rt_sigprocmask_wrapper: | ||
831 | lgfr %r2,%r2 # int | 704 | lgfr %r2,%r2 # int |
832 | llgtr %r3,%r3 # old_sigset_emu31 * | 705 | llgtr %r3,%r3 # old_sigset_emu31 * |
833 | llgtr %r4,%r4 # old_sigset_emu31 * | 706 | llgtr %r4,%r4 # old_sigset_emu31 * |
834 | llgfr %r5,%r5 # size_t | 707 | llgfr %r5,%r5 # size_t |
835 | jg sys32_rt_sigprocmask # branch to system call | 708 | jg sys32_rt_sigprocmask # branch to system call |
836 | 709 | ||
837 | .globl sys32_rt_sigpending_wrapper | 710 | ENTRY(sys32_rt_sigpending_wrapper) |
838 | sys32_rt_sigpending_wrapper: | ||
839 | llgtr %r2,%r2 # sigset_emu31 * | 711 | llgtr %r2,%r2 # sigset_emu31 * |
840 | llgfr %r3,%r3 # size_t | 712 | llgfr %r3,%r3 # size_t |
841 | jg sys32_rt_sigpending # branch to system call | 713 | jg sys32_rt_sigpending # branch to system call |
842 | 714 | ||
843 | .globl compat_sys_rt_sigtimedwait_wrapper | 715 | ENTRY(compat_sys_rt_sigtimedwait_wrapper) |
844 | compat_sys_rt_sigtimedwait_wrapper: | ||
845 | llgtr %r2,%r2 # const sigset_emu31_t * | 716 | llgtr %r2,%r2 # const sigset_emu31_t * |
846 | llgtr %r3,%r3 # siginfo_emu31_t * | 717 | llgtr %r3,%r3 # siginfo_emu31_t * |
847 | llgtr %r4,%r4 # const struct compat_timespec * | 718 | llgtr %r4,%r4 # const struct compat_timespec * |
848 | llgfr %r5,%r5 # size_t | 719 | llgfr %r5,%r5 # size_t |
849 | jg compat_sys_rt_sigtimedwait # branch to system call | 720 | jg compat_sys_rt_sigtimedwait # branch to system call |
850 | 721 | ||
851 | .globl sys32_rt_sigqueueinfo_wrapper | 722 | ENTRY(sys32_rt_sigqueueinfo_wrapper) |
852 | sys32_rt_sigqueueinfo_wrapper: | ||
853 | lgfr %r2,%r2 # int | 723 | lgfr %r2,%r2 # int |
854 | lgfr %r3,%r3 # int | 724 | lgfr %r3,%r3 # int |
855 | llgtr %r4,%r4 # siginfo_emu31_t * | 725 | llgtr %r4,%r4 # siginfo_emu31_t * |
856 | jg sys32_rt_sigqueueinfo # branch to system call | 726 | jg sys32_rt_sigqueueinfo # branch to system call |
857 | 727 | ||
858 | .globl compat_sys_rt_sigsuspend_wrapper | 728 | ENTRY(compat_sys_rt_sigsuspend_wrapper) |
859 | compat_sys_rt_sigsuspend_wrapper: | ||
860 | llgtr %r2,%r2 # compat_sigset_t * | 729 | llgtr %r2,%r2 # compat_sigset_t * |
861 | llgfr %r3,%r3 # compat_size_t | 730 | llgfr %r3,%r3 # compat_size_t |
862 | jg compat_sys_rt_sigsuspend | 731 | jg compat_sys_rt_sigsuspend |
863 | 732 | ||
864 | .globl sys32_pread64_wrapper | 733 | ENTRY(sys32_pread64_wrapper) |
865 | sys32_pread64_wrapper: | ||
866 | llgfr %r2,%r2 # unsigned int | 734 | llgfr %r2,%r2 # unsigned int |
867 | llgtr %r3,%r3 # char * | 735 | llgtr %r3,%r3 # char * |
868 | llgfr %r4,%r4 # size_t | 736 | llgfr %r4,%r4 # size_t |
@@ -870,8 +738,7 @@ sys32_pread64_wrapper: | |||
870 | llgfr %r6,%r6 # u32 | 738 | llgfr %r6,%r6 # u32 |
871 | jg sys32_pread64 # branch to system call | 739 | jg sys32_pread64 # branch to system call |
872 | 740 | ||
873 | .globl sys32_pwrite64_wrapper | 741 | ENTRY(sys32_pwrite64_wrapper) |
874 | sys32_pwrite64_wrapper: | ||
875 | llgfr %r2,%r2 # unsigned int | 742 | llgfr %r2,%r2 # unsigned int |
876 | llgtr %r3,%r3 # const char * | 743 | llgtr %r3,%r3 # const char * |
877 | llgfr %r4,%r4 # size_t | 744 | llgfr %r4,%r4 # size_t |
@@ -879,39 +746,33 @@ sys32_pwrite64_wrapper: | |||
879 | llgfr %r6,%r6 # u32 | 746 | llgfr %r6,%r6 # u32 |
880 | jg sys32_pwrite64 # branch to system call | 747 | jg sys32_pwrite64 # branch to system call |
881 | 748 | ||
882 | .globl sys32_chown16_wrapper | 749 | ENTRY(sys32_chown16_wrapper) |
883 | sys32_chown16_wrapper: | ||
884 | llgtr %r2,%r2 # const char * | 750 | llgtr %r2,%r2 # const char * |
885 | llgfr %r3,%r3 # __kernel_old_uid_emu31_t | 751 | llgfr %r3,%r3 # __kernel_old_uid_emu31_t |
886 | llgfr %r4,%r4 # __kernel_old_gid_emu31_t | 752 | llgfr %r4,%r4 # __kernel_old_gid_emu31_t |
887 | jg sys32_chown16 # branch to system call | 753 | jg sys32_chown16 # branch to system call |
888 | 754 | ||
889 | .globl sys32_getcwd_wrapper | 755 | ENTRY(sys32_getcwd_wrapper) |
890 | sys32_getcwd_wrapper: | ||
891 | llgtr %r2,%r2 # char * | 756 | llgtr %r2,%r2 # char * |
892 | llgfr %r3,%r3 # unsigned long | 757 | llgfr %r3,%r3 # unsigned long |
893 | jg sys_getcwd # branch to system call | 758 | jg sys_getcwd # branch to system call |
894 | 759 | ||
895 | .globl sys32_capget_wrapper | 760 | ENTRY(sys32_capget_wrapper) |
896 | sys32_capget_wrapper: | ||
897 | llgtr %r2,%r2 # cap_user_header_t | 761 | llgtr %r2,%r2 # cap_user_header_t |
898 | llgtr %r3,%r3 # cap_user_data_t | 762 | llgtr %r3,%r3 # cap_user_data_t |
899 | jg sys_capget # branch to system call | 763 | jg sys_capget # branch to system call |
900 | 764 | ||
901 | .globl sys32_capset_wrapper | 765 | ENTRY(sys32_capset_wrapper) |
902 | sys32_capset_wrapper: | ||
903 | llgtr %r2,%r2 # cap_user_header_t | 766 | llgtr %r2,%r2 # cap_user_header_t |
904 | llgtr %r3,%r3 # const cap_user_data_t | 767 | llgtr %r3,%r3 # const cap_user_data_t |
905 | jg sys_capset # branch to system call | 768 | jg sys_capset # branch to system call |
906 | 769 | ||
907 | .globl sys32_sigaltstack_wrapper | 770 | ENTRY(sys32_sigaltstack_wrapper) |
908 | sys32_sigaltstack_wrapper: | ||
909 | llgtr %r2,%r2 # const stack_emu31_t * | 771 | llgtr %r2,%r2 # const stack_emu31_t * |
910 | llgtr %r3,%r3 # stack_emu31_t * | 772 | llgtr %r3,%r3 # stack_emu31_t * |
911 | jg sys32_sigaltstack | 773 | jg sys32_sigaltstack |
912 | 774 | ||
913 | .globl sys32_sendfile_wrapper | 775 | ENTRY(sys32_sendfile_wrapper) |
914 | sys32_sendfile_wrapper: | ||
915 | lgfr %r2,%r2 # int | 776 | lgfr %r2,%r2 # int |
916 | lgfr %r3,%r3 # int | 777 | lgfr %r3,%r3 # int |
917 | llgtr %r4,%r4 # __kernel_off_emu31_t * | 778 | llgtr %r4,%r4 # __kernel_off_emu31_t * |
@@ -920,22 +781,19 @@ sys32_sendfile_wrapper: | |||
920 | 781 | ||
921 | #sys32_vfork_wrapper # done in vfork_glue | 782 | #sys32_vfork_wrapper # done in vfork_glue |
922 | 783 | ||
923 | .globl sys32_truncate64_wrapper | 784 | ENTRY(sys32_truncate64_wrapper) |
924 | sys32_truncate64_wrapper: | ||
925 | llgtr %r2,%r2 # const char * | 785 | llgtr %r2,%r2 # const char * |
926 | llgfr %r3,%r3 # unsigned long | 786 | llgfr %r3,%r3 # unsigned long |
927 | llgfr %r4,%r4 # unsigned long | 787 | llgfr %r4,%r4 # unsigned long |
928 | jg sys32_truncate64 # branch to system call | 788 | jg sys32_truncate64 # branch to system call |
929 | 789 | ||
930 | .globl sys32_ftruncate64_wrapper | 790 | ENTRY(sys32_ftruncate64_wrapper) |
931 | sys32_ftruncate64_wrapper: | ||
932 | llgfr %r2,%r2 # unsigned int | 791 | llgfr %r2,%r2 # unsigned int |
933 | llgfr %r3,%r3 # unsigned long | 792 | llgfr %r3,%r3 # unsigned long |
934 | llgfr %r4,%r4 # unsigned long | 793 | llgfr %r4,%r4 # unsigned long |
935 | jg sys32_ftruncate64 # branch to system call | 794 | jg sys32_ftruncate64 # branch to system call |
936 | 795 | ||
937 | .globl sys32_lchown_wrapper | 796 | ENTRY(sys32_lchown_wrapper) |
938 | sys32_lchown_wrapper: | ||
939 | llgtr %r2,%r2 # const char * | 797 | llgtr %r2,%r2 # const char * |
940 | llgfr %r3,%r3 # uid_t | 798 | llgfr %r3,%r3 # uid_t |
941 | llgfr %r4,%r4 # gid_t | 799 | llgfr %r4,%r4 # gid_t |
@@ -946,156 +804,131 @@ sys32_lchown_wrapper: | |||
946 | #sys32_geteuid_wrapper # void | 804 | #sys32_geteuid_wrapper # void |
947 | #sys32_getegid_wrapper # void | 805 | #sys32_getegid_wrapper # void |
948 | 806 | ||
949 | .globl sys32_setreuid_wrapper | 807 | ENTRY(sys32_setreuid_wrapper) |
950 | sys32_setreuid_wrapper: | ||
951 | llgfr %r2,%r2 # uid_t | 808 | llgfr %r2,%r2 # uid_t |
952 | llgfr %r3,%r3 # uid_t | 809 | llgfr %r3,%r3 # uid_t |
953 | jg sys_setreuid # branch to system call | 810 | jg sys_setreuid # branch to system call |
954 | 811 | ||
955 | .globl sys32_setregid_wrapper | 812 | ENTRY(sys32_setregid_wrapper) |
956 | sys32_setregid_wrapper: | ||
957 | llgfr %r2,%r2 # gid_t | 813 | llgfr %r2,%r2 # gid_t |
958 | llgfr %r3,%r3 # gid_t | 814 | llgfr %r3,%r3 # gid_t |
959 | jg sys_setregid # branch to system call | 815 | jg sys_setregid # branch to system call |
960 | 816 | ||
961 | .globl sys32_getgroups_wrapper | 817 | ENTRY(sys32_getgroups_wrapper) |
962 | sys32_getgroups_wrapper: | ||
963 | lgfr %r2,%r2 # int | 818 | lgfr %r2,%r2 # int |
964 | llgtr %r3,%r3 # gid_t * | 819 | llgtr %r3,%r3 # gid_t * |
965 | jg sys_getgroups # branch to system call | 820 | jg sys_getgroups # branch to system call |
966 | 821 | ||
967 | .globl sys32_setgroups_wrapper | 822 | ENTRY(sys32_setgroups_wrapper) |
968 | sys32_setgroups_wrapper: | ||
969 | lgfr %r2,%r2 # int | 823 | lgfr %r2,%r2 # int |
970 | llgtr %r3,%r3 # gid_t * | 824 | llgtr %r3,%r3 # gid_t * |
971 | jg sys_setgroups # branch to system call | 825 | jg sys_setgroups # branch to system call |
972 | 826 | ||
973 | .globl sys32_fchown_wrapper | 827 | ENTRY(sys32_fchown_wrapper) |
974 | sys32_fchown_wrapper: | ||
975 | llgfr %r2,%r2 # unsigned int | 828 | llgfr %r2,%r2 # unsigned int |
976 | llgfr %r3,%r3 # uid_t | 829 | llgfr %r3,%r3 # uid_t |
977 | llgfr %r4,%r4 # gid_t | 830 | llgfr %r4,%r4 # gid_t |
978 | jg sys_fchown # branch to system call | 831 | jg sys_fchown # branch to system call |
979 | 832 | ||
980 | .globl sys32_setresuid_wrapper | 833 | ENTRY(sys32_setresuid_wrapper) |
981 | sys32_setresuid_wrapper: | ||
982 | llgfr %r2,%r2 # uid_t | 834 | llgfr %r2,%r2 # uid_t |
983 | llgfr %r3,%r3 # uid_t | 835 | llgfr %r3,%r3 # uid_t |
984 | llgfr %r4,%r4 # uid_t | 836 | llgfr %r4,%r4 # uid_t |
985 | jg sys_setresuid # branch to system call | 837 | jg sys_setresuid # branch to system call |
986 | 838 | ||
987 | .globl sys32_getresuid_wrapper | 839 | ENTRY(sys32_getresuid_wrapper) |
988 | sys32_getresuid_wrapper: | ||
989 | llgtr %r2,%r2 # uid_t * | 840 | llgtr %r2,%r2 # uid_t * |
990 | llgtr %r3,%r3 # uid_t * | 841 | llgtr %r3,%r3 # uid_t * |
991 | llgtr %r4,%r4 # uid_t * | 842 | llgtr %r4,%r4 # uid_t * |
992 | jg sys_getresuid # branch to system call | 843 | jg sys_getresuid # branch to system call |
993 | 844 | ||
994 | .globl sys32_setresgid_wrapper | 845 | ENTRY(sys32_setresgid_wrapper) |
995 | sys32_setresgid_wrapper: | ||
996 | llgfr %r2,%r2 # gid_t | 846 | llgfr %r2,%r2 # gid_t |
997 | llgfr %r3,%r3 # gid_t | 847 | llgfr %r3,%r3 # gid_t |
998 | llgfr %r4,%r4 # gid_t | 848 | llgfr %r4,%r4 # gid_t |
999 | jg sys_setresgid # branch to system call | 849 | jg sys_setresgid # branch to system call |
1000 | 850 | ||
1001 | .globl sys32_getresgid_wrapper | 851 | ENTRY(sys32_getresgid_wrapper) |
1002 | sys32_getresgid_wrapper: | ||
1003 | llgtr %r2,%r2 # gid_t * | 852 | llgtr %r2,%r2 # gid_t * |
1004 | llgtr %r3,%r3 # gid_t * | 853 | llgtr %r3,%r3 # gid_t * |
1005 | llgtr %r4,%r4 # gid_t * | 854 | llgtr %r4,%r4 # gid_t * |
1006 | jg sys_getresgid # branch to system call | 855 | jg sys_getresgid # branch to system call |
1007 | 856 | ||
1008 | .globl sys32_chown_wrapper | 857 | ENTRY(sys32_chown_wrapper) |
1009 | sys32_chown_wrapper: | ||
1010 | llgtr %r2,%r2 # const char * | 858 | llgtr %r2,%r2 # const char * |
1011 | llgfr %r3,%r3 # uid_t | 859 | llgfr %r3,%r3 # uid_t |
1012 | llgfr %r4,%r4 # gid_t | 860 | llgfr %r4,%r4 # gid_t |
1013 | jg sys_chown # branch to system call | 861 | jg sys_chown # branch to system call |
1014 | 862 | ||
1015 | .globl sys32_setuid_wrapper | 863 | ENTRY(sys32_setuid_wrapper) |
1016 | sys32_setuid_wrapper: | ||
1017 | llgfr %r2,%r2 # uid_t | 864 | llgfr %r2,%r2 # uid_t |
1018 | jg sys_setuid # branch to system call | 865 | jg sys_setuid # branch to system call |
1019 | 866 | ||
1020 | .globl sys32_setgid_wrapper | 867 | ENTRY(sys32_setgid_wrapper) |
1021 | sys32_setgid_wrapper: | ||
1022 | llgfr %r2,%r2 # gid_t | 868 | llgfr %r2,%r2 # gid_t |
1023 | jg sys_setgid # branch to system call | 869 | jg sys_setgid # branch to system call |
1024 | 870 | ||
1025 | .globl sys32_setfsuid_wrapper | 871 | ENTRY(sys32_setfsuid_wrapper) |
1026 | sys32_setfsuid_wrapper: | ||
1027 | llgfr %r2,%r2 # uid_t | 872 | llgfr %r2,%r2 # uid_t |
1028 | jg sys_setfsuid # branch to system call | 873 | jg sys_setfsuid # branch to system call |
1029 | 874 | ||
1030 | .globl sys32_setfsgid_wrapper | 875 | ENTRY(sys32_setfsgid_wrapper) |
1031 | sys32_setfsgid_wrapper: | ||
1032 | llgfr %r2,%r2 # gid_t | 876 | llgfr %r2,%r2 # gid_t |
1033 | jg sys_setfsgid # branch to system call | 877 | jg sys_setfsgid # branch to system call |
1034 | 878 | ||
1035 | .globl sys32_pivot_root_wrapper | 879 | ENTRY(sys32_pivot_root_wrapper) |
1036 | sys32_pivot_root_wrapper: | ||
1037 | llgtr %r2,%r2 # const char * | 880 | llgtr %r2,%r2 # const char * |
1038 | llgtr %r3,%r3 # const char * | 881 | llgtr %r3,%r3 # const char * |
1039 | jg sys_pivot_root # branch to system call | 882 | jg sys_pivot_root # branch to system call |
1040 | 883 | ||
1041 | .globl sys32_mincore_wrapper | 884 | ENTRY(sys32_mincore_wrapper) |
1042 | sys32_mincore_wrapper: | ||
1043 | llgfr %r2,%r2 # unsigned long | 885 | llgfr %r2,%r2 # unsigned long |
1044 | llgfr %r3,%r3 # size_t | 886 | llgfr %r3,%r3 # size_t |
1045 | llgtr %r4,%r4 # unsigned char * | 887 | llgtr %r4,%r4 # unsigned char * |
1046 | jg sys_mincore # branch to system call | 888 | jg sys_mincore # branch to system call |
1047 | 889 | ||
1048 | .globl sys32_madvise_wrapper | 890 | ENTRY(sys32_madvise_wrapper) |
1049 | sys32_madvise_wrapper: | ||
1050 | llgfr %r2,%r2 # unsigned long | 891 | llgfr %r2,%r2 # unsigned long |
1051 | llgfr %r3,%r3 # size_t | 892 | llgfr %r3,%r3 # size_t |
1052 | lgfr %r4,%r4 # int | 893 | lgfr %r4,%r4 # int |
1053 | jg sys_madvise # branch to system call | 894 | jg sys_madvise # branch to system call |
1054 | 895 | ||
1055 | .globl sys32_getdents64_wrapper | 896 | ENTRY(sys32_getdents64_wrapper) |
1056 | sys32_getdents64_wrapper: | ||
1057 | llgfr %r2,%r2 # unsigned int | 897 | llgfr %r2,%r2 # unsigned int |
1058 | llgtr %r3,%r3 # void * | 898 | llgtr %r3,%r3 # void * |
1059 | llgfr %r4,%r4 # unsigned int | 899 | llgfr %r4,%r4 # unsigned int |
1060 | jg sys_getdents64 # branch to system call | 900 | jg sys_getdents64 # branch to system call |
1061 | 901 | ||
1062 | .globl compat_sys_fcntl64_wrapper | 902 | ENTRY(compat_sys_fcntl64_wrapper) |
1063 | compat_sys_fcntl64_wrapper: | ||
1064 | llgfr %r2,%r2 # unsigned int | 903 | llgfr %r2,%r2 # unsigned int |
1065 | llgfr %r3,%r3 # unsigned int | 904 | llgfr %r3,%r3 # unsigned int |
1066 | llgfr %r4,%r4 # unsigned long | 905 | llgfr %r4,%r4 # unsigned long |
1067 | jg compat_sys_fcntl64 # branch to system call | 906 | jg compat_sys_fcntl64 # branch to system call |
1068 | 907 | ||
1069 | .globl sys32_stat64_wrapper | 908 | ENTRY(sys32_stat64_wrapper) |
1070 | sys32_stat64_wrapper: | ||
1071 | llgtr %r2,%r2 # char * | 909 | llgtr %r2,%r2 # char * |
1072 | llgtr %r3,%r3 # struct stat64 * | 910 | llgtr %r3,%r3 # struct stat64 * |
1073 | jg sys32_stat64 # branch to system call | 911 | jg sys32_stat64 # branch to system call |
1074 | 912 | ||
1075 | .globl sys32_lstat64_wrapper | 913 | ENTRY(sys32_lstat64_wrapper) |
1076 | sys32_lstat64_wrapper: | ||
1077 | llgtr %r2,%r2 # char * | 914 | llgtr %r2,%r2 # char * |
1078 | llgtr %r3,%r3 # struct stat64 * | 915 | llgtr %r3,%r3 # struct stat64 * |
1079 | jg sys32_lstat64 # branch to system call | 916 | jg sys32_lstat64 # branch to system call |
1080 | 917 | ||
1081 | .globl sys32_stime_wrapper | 918 | ENTRY(sys32_stime_wrapper) |
1082 | sys32_stime_wrapper: | ||
1083 | llgtr %r2,%r2 # long * | 919 | llgtr %r2,%r2 # long * |
1084 | jg compat_sys_stime # branch to system call | 920 | jg compat_sys_stime # branch to system call |
1085 | 921 | ||
1086 | .globl sys32_sysctl_wrapper | 922 | ENTRY(sys32_sysctl_wrapper) |
1087 | sys32_sysctl_wrapper: | ||
1088 | llgtr %r2,%r2 # struct compat_sysctl_args * | 923 | llgtr %r2,%r2 # struct compat_sysctl_args * |
1089 | jg compat_sys_sysctl | 924 | jg compat_sys_sysctl |
1090 | 925 | ||
1091 | .globl sys32_fstat64_wrapper | 926 | ENTRY(sys32_fstat64_wrapper) |
1092 | sys32_fstat64_wrapper: | ||
1093 | llgfr %r2,%r2 # unsigned long | 927 | llgfr %r2,%r2 # unsigned long |
1094 | llgtr %r3,%r3 # struct stat64 * | 928 | llgtr %r3,%r3 # struct stat64 * |
1095 | jg sys32_fstat64 # branch to system call | 929 | jg sys32_fstat64 # branch to system call |
1096 | 930 | ||
1097 | .globl compat_sys_futex_wrapper | 931 | ENTRY(compat_sys_futex_wrapper) |
1098 | compat_sys_futex_wrapper: | ||
1099 | llgtr %r2,%r2 # u32 * | 932 | llgtr %r2,%r2 # u32 * |
1100 | lgfr %r3,%r3 # int | 933 | lgfr %r3,%r3 # int |
1101 | lgfr %r4,%r4 # int | 934 | lgfr %r4,%r4 # int |
@@ -1105,8 +938,7 @@ compat_sys_futex_wrapper: | |||
1105 | stg %r0,160(%r15) | 938 | stg %r0,160(%r15) |
1106 | jg compat_sys_futex # branch to system call | 939 | jg compat_sys_futex # branch to system call |
1107 | 940 | ||
1108 | .globl sys32_setxattr_wrapper | 941 | ENTRY(sys32_setxattr_wrapper) |
1109 | sys32_setxattr_wrapper: | ||
1110 | llgtr %r2,%r2 # char * | 942 | llgtr %r2,%r2 # char * |
1111 | llgtr %r3,%r3 # char * | 943 | llgtr %r3,%r3 # char * |
1112 | llgtr %r4,%r4 # void * | 944 | llgtr %r4,%r4 # void * |
@@ -1114,8 +946,7 @@ sys32_setxattr_wrapper: | |||
1114 | lgfr %r6,%r6 # int | 946 | lgfr %r6,%r6 # int |
1115 | jg sys_setxattr | 947 | jg sys_setxattr |
1116 | 948 | ||
1117 | .globl sys32_lsetxattr_wrapper | 949 | ENTRY(sys32_lsetxattr_wrapper) |
1118 | sys32_lsetxattr_wrapper: | ||
1119 | llgtr %r2,%r2 # char * | 950 | llgtr %r2,%r2 # char * |
1120 | llgtr %r3,%r3 # char * | 951 | llgtr %r3,%r3 # char * |
1121 | llgtr %r4,%r4 # void * | 952 | llgtr %r4,%r4 # void * |
@@ -1123,8 +954,7 @@ sys32_lsetxattr_wrapper: | |||
1123 | lgfr %r6,%r6 # int | 954 | lgfr %r6,%r6 # int |
1124 | jg sys_lsetxattr | 955 | jg sys_lsetxattr |
1125 | 956 | ||
1126 | .globl sys32_fsetxattr_wrapper | 957 | ENTRY(sys32_fsetxattr_wrapper) |
1127 | sys32_fsetxattr_wrapper: | ||
1128 | lgfr %r2,%r2 # int | 958 | lgfr %r2,%r2 # int |
1129 | llgtr %r3,%r3 # char * | 959 | llgtr %r3,%r3 # char * |
1130 | llgtr %r4,%r4 # void * | 960 | llgtr %r4,%r4 # void * |
@@ -1132,124 +962,106 @@ sys32_fsetxattr_wrapper: | |||
1132 | lgfr %r6,%r6 # int | 962 | lgfr %r6,%r6 # int |
1133 | jg sys_fsetxattr | 963 | jg sys_fsetxattr |
1134 | 964 | ||
1135 | .globl sys32_getxattr_wrapper | 965 | ENTRY(sys32_getxattr_wrapper) |
1136 | sys32_getxattr_wrapper: | ||
1137 | llgtr %r2,%r2 # char * | 966 | llgtr %r2,%r2 # char * |
1138 | llgtr %r3,%r3 # char * | 967 | llgtr %r3,%r3 # char * |
1139 | llgtr %r4,%r4 # void * | 968 | llgtr %r4,%r4 # void * |
1140 | llgfr %r5,%r5 # size_t | 969 | llgfr %r5,%r5 # size_t |
1141 | jg sys_getxattr | 970 | jg sys_getxattr |
1142 | 971 | ||
1143 | .globl sys32_lgetxattr_wrapper | 972 | ENTRY(sys32_lgetxattr_wrapper) |
1144 | sys32_lgetxattr_wrapper: | ||
1145 | llgtr %r2,%r2 # char * | 973 | llgtr %r2,%r2 # char * |
1146 | llgtr %r3,%r3 # char * | 974 | llgtr %r3,%r3 # char * |
1147 | llgtr %r4,%r4 # void * | 975 | llgtr %r4,%r4 # void * |
1148 | llgfr %r5,%r5 # size_t | 976 | llgfr %r5,%r5 # size_t |
1149 | jg sys_lgetxattr | 977 | jg sys_lgetxattr |
1150 | 978 | ||
1151 | .globl sys32_fgetxattr_wrapper | 979 | ENTRY(sys32_fgetxattr_wrapper) |
1152 | sys32_fgetxattr_wrapper: | ||
1153 | lgfr %r2,%r2 # int | 980 | lgfr %r2,%r2 # int |
1154 | llgtr %r3,%r3 # char * | 981 | llgtr %r3,%r3 # char * |
1155 | llgtr %r4,%r4 # void * | 982 | llgtr %r4,%r4 # void * |
1156 | llgfr %r5,%r5 # size_t | 983 | llgfr %r5,%r5 # size_t |
1157 | jg sys_fgetxattr | 984 | jg sys_fgetxattr |
1158 | 985 | ||
1159 | .globl sys32_listxattr_wrapper | 986 | ENTRY(sys32_listxattr_wrapper) |
1160 | sys32_listxattr_wrapper: | ||
1161 | llgtr %r2,%r2 # char * | 987 | llgtr %r2,%r2 # char * |
1162 | llgtr %r3,%r3 # char * | 988 | llgtr %r3,%r3 # char * |
1163 | llgfr %r4,%r4 # size_t | 989 | llgfr %r4,%r4 # size_t |
1164 | jg sys_listxattr | 990 | jg sys_listxattr |
1165 | 991 | ||
1166 | .globl sys32_llistxattr_wrapper | 992 | ENTRY(sys32_llistxattr_wrapper) |
1167 | sys32_llistxattr_wrapper: | ||
1168 | llgtr %r2,%r2 # char * | 993 | llgtr %r2,%r2 # char * |
1169 | llgtr %r3,%r3 # char * | 994 | llgtr %r3,%r3 # char * |
1170 | llgfr %r4,%r4 # size_t | 995 | llgfr %r4,%r4 # size_t |
1171 | jg sys_llistxattr | 996 | jg sys_llistxattr |
1172 | 997 | ||
1173 | .globl sys32_flistxattr_wrapper | 998 | ENTRY(sys32_flistxattr_wrapper) |
1174 | sys32_flistxattr_wrapper: | ||
1175 | lgfr %r2,%r2 # int | 999 | lgfr %r2,%r2 # int |
1176 | llgtr %r3,%r3 # char * | 1000 | llgtr %r3,%r3 # char * |
1177 | llgfr %r4,%r4 # size_t | 1001 | llgfr %r4,%r4 # size_t |
1178 | jg sys_flistxattr | 1002 | jg sys_flistxattr |
1179 | 1003 | ||
1180 | .globl sys32_removexattr_wrapper | 1004 | ENTRY(sys32_removexattr_wrapper) |
1181 | sys32_removexattr_wrapper: | ||
1182 | llgtr %r2,%r2 # char * | 1005 | llgtr %r2,%r2 # char * |
1183 | llgtr %r3,%r3 # char * | 1006 | llgtr %r3,%r3 # char * |
1184 | jg sys_removexattr | 1007 | jg sys_removexattr |
1185 | 1008 | ||
1186 | .globl sys32_lremovexattr_wrapper | 1009 | ENTRY(sys32_lremovexattr_wrapper) |
1187 | sys32_lremovexattr_wrapper: | ||
1188 | llgtr %r2,%r2 # char * | 1010 | llgtr %r2,%r2 # char * |
1189 | llgtr %r3,%r3 # char * | 1011 | llgtr %r3,%r3 # char * |
1190 | jg sys_lremovexattr | 1012 | jg sys_lremovexattr |
1191 | 1013 | ||
1192 | .globl sys32_fremovexattr_wrapper | 1014 | ENTRY(sys32_fremovexattr_wrapper) |
1193 | sys32_fremovexattr_wrapper: | ||
1194 | lgfr %r2,%r2 # int | 1015 | lgfr %r2,%r2 # int |
1195 | llgtr %r3,%r3 # char * | 1016 | llgtr %r3,%r3 # char * |
1196 | jg sys_fremovexattr | 1017 | jg sys_fremovexattr |
1197 | 1018 | ||
1198 | .globl sys32_sched_setaffinity_wrapper | 1019 | ENTRY(sys32_sched_setaffinity_wrapper) |
1199 | sys32_sched_setaffinity_wrapper: | ||
1200 | lgfr %r2,%r2 # int | 1020 | lgfr %r2,%r2 # int |
1201 | llgfr %r3,%r3 # unsigned int | 1021 | llgfr %r3,%r3 # unsigned int |
1202 | llgtr %r4,%r4 # unsigned long * | 1022 | llgtr %r4,%r4 # unsigned long * |
1203 | jg compat_sys_sched_setaffinity | 1023 | jg compat_sys_sched_setaffinity |
1204 | 1024 | ||
1205 | .globl sys32_sched_getaffinity_wrapper | 1025 | ENTRY(sys32_sched_getaffinity_wrapper) |
1206 | sys32_sched_getaffinity_wrapper: | ||
1207 | lgfr %r2,%r2 # int | 1026 | lgfr %r2,%r2 # int |
1208 | llgfr %r3,%r3 # unsigned int | 1027 | llgfr %r3,%r3 # unsigned int |
1209 | llgtr %r4,%r4 # unsigned long * | 1028 | llgtr %r4,%r4 # unsigned long * |
1210 | jg compat_sys_sched_getaffinity | 1029 | jg compat_sys_sched_getaffinity |
1211 | 1030 | ||
1212 | .globl sys32_exit_group_wrapper | 1031 | ENTRY(sys32_exit_group_wrapper) |
1213 | sys32_exit_group_wrapper: | ||
1214 | lgfr %r2,%r2 # int | 1032 | lgfr %r2,%r2 # int |
1215 | jg sys_exit_group # branch to system call | 1033 | jg sys_exit_group # branch to system call |
1216 | 1034 | ||
1217 | .globl sys32_set_tid_address_wrapper | 1035 | ENTRY(sys32_set_tid_address_wrapper) |
1218 | sys32_set_tid_address_wrapper: | ||
1219 | llgtr %r2,%r2 # int * | 1036 | llgtr %r2,%r2 # int * |
1220 | jg sys_set_tid_address # branch to system call | 1037 | jg sys_set_tid_address # branch to system call |
1221 | 1038 | ||
1222 | .globl sys_epoll_create_wrapper | 1039 | ENTRY(sys_epoll_create_wrapper) |
1223 | sys_epoll_create_wrapper: | ||
1224 | lgfr %r2,%r2 # int | 1040 | lgfr %r2,%r2 # int |
1225 | jg sys_epoll_create # branch to system call | 1041 | jg sys_epoll_create # branch to system call |
1226 | 1042 | ||
1227 | .globl sys_epoll_ctl_wrapper | 1043 | ENTRY(sys_epoll_ctl_wrapper) |
1228 | sys_epoll_ctl_wrapper: | ||
1229 | lgfr %r2,%r2 # int | 1044 | lgfr %r2,%r2 # int |
1230 | lgfr %r3,%r3 # int | 1045 | lgfr %r3,%r3 # int |
1231 | lgfr %r4,%r4 # int | 1046 | lgfr %r4,%r4 # int |
1232 | llgtr %r5,%r5 # struct epoll_event * | 1047 | llgtr %r5,%r5 # struct epoll_event * |
1233 | jg sys_epoll_ctl # branch to system call | 1048 | jg sys_epoll_ctl # branch to system call |
1234 | 1049 | ||
1235 | .globl sys_epoll_wait_wrapper | 1050 | ENTRY(sys_epoll_wait_wrapper) |
1236 | sys_epoll_wait_wrapper: | ||
1237 | lgfr %r2,%r2 # int | 1051 | lgfr %r2,%r2 # int |
1238 | llgtr %r3,%r3 # struct epoll_event * | 1052 | llgtr %r3,%r3 # struct epoll_event * |
1239 | lgfr %r4,%r4 # int | 1053 | lgfr %r4,%r4 # int |
1240 | lgfr %r5,%r5 # int | 1054 | lgfr %r5,%r5 # int |
1241 | jg sys_epoll_wait # branch to system call | 1055 | jg sys_epoll_wait # branch to system call |
1242 | 1056 | ||
1243 | .globl sys32_lookup_dcookie_wrapper | 1057 | ENTRY(sys32_lookup_dcookie_wrapper) |
1244 | sys32_lookup_dcookie_wrapper: | ||
1245 | sllg %r2,%r2,32 # get high word of 64bit dcookie | 1058 | sllg %r2,%r2,32 # get high word of 64bit dcookie |
1246 | or %r2,%r3 # get low word of 64bit dcookie | 1059 | or %r2,%r3 # get low word of 64bit dcookie |
1247 | llgtr %r3,%r4 # char * | 1060 | llgtr %r3,%r4 # char * |
1248 | llgfr %r4,%r5 # size_t | 1061 | llgfr %r4,%r5 # size_t |
1249 | jg sys_lookup_dcookie | 1062 | jg sys_lookup_dcookie |
1250 | 1063 | ||
1251 | .globl sys32_fadvise64_wrapper | 1064 | ENTRY(sys32_fadvise64_wrapper) |
1252 | sys32_fadvise64_wrapper: | ||
1253 | lgfr %r2,%r2 # int | 1065 | lgfr %r2,%r2 # int |
1254 | sllg %r3,%r3,32 # get high word of 64bit loff_t | 1066 | sllg %r3,%r3,32 # get high word of 64bit loff_t |
1255 | or %r3,%r4 # get low word of 64bit loff_t | 1067 | or %r3,%r4 # get low word of 64bit loff_t |
@@ -1257,81 +1069,68 @@ sys32_fadvise64_wrapper: | |||
1257 | lgfr %r5,%r6 # int | 1069 | lgfr %r5,%r6 # int |
1258 | jg sys32_fadvise64 | 1070 | jg sys32_fadvise64 |
1259 | 1071 | ||
1260 | .globl sys32_fadvise64_64_wrapper | 1072 | ENTRY(sys32_fadvise64_64_wrapper) |
1261 | sys32_fadvise64_64_wrapper: | ||
1262 | llgtr %r2,%r2 # struct fadvise64_64_args * | 1073 | llgtr %r2,%r2 # struct fadvise64_64_args * |
1263 | jg sys32_fadvise64_64 | 1074 | jg sys32_fadvise64_64 |
1264 | 1075 | ||
1265 | .globl sys32_clock_settime_wrapper | 1076 | ENTRY(sys32_clock_settime_wrapper) |
1266 | sys32_clock_settime_wrapper: | ||
1267 | lgfr %r2,%r2 # clockid_t (int) | 1077 | lgfr %r2,%r2 # clockid_t (int) |
1268 | llgtr %r3,%r3 # struct compat_timespec * | 1078 | llgtr %r3,%r3 # struct compat_timespec * |
1269 | jg compat_sys_clock_settime | 1079 | jg compat_sys_clock_settime |
1270 | 1080 | ||
1271 | .globl sys32_clock_gettime_wrapper | 1081 | ENTRY(sys32_clock_gettime_wrapper) |
1272 | sys32_clock_gettime_wrapper: | ||
1273 | lgfr %r2,%r2 # clockid_t (int) | 1082 | lgfr %r2,%r2 # clockid_t (int) |
1274 | llgtr %r3,%r3 # struct compat_timespec * | 1083 | llgtr %r3,%r3 # struct compat_timespec * |
1275 | jg compat_sys_clock_gettime | 1084 | jg compat_sys_clock_gettime |
1276 | 1085 | ||
1277 | .globl sys32_clock_getres_wrapper | 1086 | ENTRY(sys32_clock_getres_wrapper) |
1278 | sys32_clock_getres_wrapper: | ||
1279 | lgfr %r2,%r2 # clockid_t (int) | 1087 | lgfr %r2,%r2 # clockid_t (int) |
1280 | llgtr %r3,%r3 # struct compat_timespec * | 1088 | llgtr %r3,%r3 # struct compat_timespec * |
1281 | jg compat_sys_clock_getres | 1089 | jg compat_sys_clock_getres |
1282 | 1090 | ||
1283 | .globl sys32_clock_nanosleep_wrapper | 1091 | ENTRY(sys32_clock_nanosleep_wrapper) |
1284 | sys32_clock_nanosleep_wrapper: | ||
1285 | lgfr %r2,%r2 # clockid_t (int) | 1092 | lgfr %r2,%r2 # clockid_t (int) |
1286 | lgfr %r3,%r3 # int | 1093 | lgfr %r3,%r3 # int |
1287 | llgtr %r4,%r4 # struct compat_timespec * | 1094 | llgtr %r4,%r4 # struct compat_timespec * |
1288 | llgtr %r5,%r5 # struct compat_timespec * | 1095 | llgtr %r5,%r5 # struct compat_timespec * |
1289 | jg compat_sys_clock_nanosleep | 1096 | jg compat_sys_clock_nanosleep |
1290 | 1097 | ||
1291 | .globl sys32_timer_create_wrapper | 1098 | ENTRY(sys32_timer_create_wrapper) |
1292 | sys32_timer_create_wrapper: | ||
1293 | lgfr %r2,%r2 # timer_t (int) | 1099 | lgfr %r2,%r2 # timer_t (int) |
1294 | llgtr %r3,%r3 # struct compat_sigevent * | 1100 | llgtr %r3,%r3 # struct compat_sigevent * |
1295 | llgtr %r4,%r4 # timer_t * | 1101 | llgtr %r4,%r4 # timer_t * |
1296 | jg compat_sys_timer_create | 1102 | jg compat_sys_timer_create |
1297 | 1103 | ||
1298 | .globl sys32_timer_settime_wrapper | 1104 | ENTRY(sys32_timer_settime_wrapper) |
1299 | sys32_timer_settime_wrapper: | ||
1300 | lgfr %r2,%r2 # timer_t (int) | 1105 | lgfr %r2,%r2 # timer_t (int) |
1301 | lgfr %r3,%r3 # int | 1106 | lgfr %r3,%r3 # int |
1302 | llgtr %r4,%r4 # struct compat_itimerspec * | 1107 | llgtr %r4,%r4 # struct compat_itimerspec * |
1303 | llgtr %r5,%r5 # struct compat_itimerspec * | 1108 | llgtr %r5,%r5 # struct compat_itimerspec * |
1304 | jg compat_sys_timer_settime | 1109 | jg compat_sys_timer_settime |
1305 | 1110 | ||
1306 | .globl sys32_timer_gettime_wrapper | 1111 | ENTRY(sys32_timer_gettime_wrapper) |
1307 | sys32_timer_gettime_wrapper: | ||
1308 | lgfr %r2,%r2 # timer_t (int) | 1112 | lgfr %r2,%r2 # timer_t (int) |
1309 | llgtr %r3,%r3 # struct compat_itimerspec * | 1113 | llgtr %r3,%r3 # struct compat_itimerspec * |
1310 | jg compat_sys_timer_gettime | 1114 | jg compat_sys_timer_gettime |
1311 | 1115 | ||
1312 | .globl sys32_timer_getoverrun_wrapper | 1116 | ENTRY(sys32_timer_getoverrun_wrapper) |
1313 | sys32_timer_getoverrun_wrapper: | ||
1314 | lgfr %r2,%r2 # timer_t (int) | 1117 | lgfr %r2,%r2 # timer_t (int) |
1315 | jg sys_timer_getoverrun | 1118 | jg sys_timer_getoverrun |
1316 | 1119 | ||
1317 | .globl sys32_timer_delete_wrapper | 1120 | ENTRY(sys32_timer_delete_wrapper) |
1318 | sys32_timer_delete_wrapper: | ||
1319 | lgfr %r2,%r2 # timer_t (int) | 1121 | lgfr %r2,%r2 # timer_t (int) |
1320 | jg sys_timer_delete | 1122 | jg sys_timer_delete |
1321 | 1123 | ||
1322 | .globl sys32_io_setup_wrapper | 1124 | ENTRY(sys32_io_setup_wrapper) |
1323 | sys32_io_setup_wrapper: | ||
1324 | llgfr %r2,%r2 # unsigned int | 1125 | llgfr %r2,%r2 # unsigned int |
1325 | llgtr %r3,%r3 # u32 * | 1126 | llgtr %r3,%r3 # u32 * |
1326 | jg compat_sys_io_setup | 1127 | jg compat_sys_io_setup |
1327 | 1128 | ||
1328 | .globl sys32_io_destroy_wrapper | 1129 | ENTRY(sys32_io_destroy_wrapper) |
1329 | sys32_io_destroy_wrapper: | ||
1330 | llgfr %r2,%r2 # (aio_context_t) u32 | 1130 | llgfr %r2,%r2 # (aio_context_t) u32 |
1331 | jg sys_io_destroy | 1131 | jg sys_io_destroy |
1332 | 1132 | ||
1333 | .globl sys32_io_getevents_wrapper | 1133 | ENTRY(sys32_io_getevents_wrapper) |
1334 | sys32_io_getevents_wrapper: | ||
1335 | llgfr %r2,%r2 # (aio_context_t) u32 | 1134 | llgfr %r2,%r2 # (aio_context_t) u32 |
1336 | lgfr %r3,%r3 # long | 1135 | lgfr %r3,%r3 # long |
1337 | lgfr %r4,%r4 # long | 1136 | lgfr %r4,%r4 # long |
@@ -1339,49 +1138,42 @@ sys32_io_getevents_wrapper: | |||
1339 | llgtr %r6,%r6 # struct compat_timespec * | 1138 | llgtr %r6,%r6 # struct compat_timespec * |
1340 | jg compat_sys_io_getevents | 1139 | jg compat_sys_io_getevents |
1341 | 1140 | ||
1342 | .globl sys32_io_submit_wrapper | 1141 | ENTRY(sys32_io_submit_wrapper) |
1343 | sys32_io_submit_wrapper: | ||
1344 | llgfr %r2,%r2 # (aio_context_t) u32 | 1142 | llgfr %r2,%r2 # (aio_context_t) u32 |
1345 | lgfr %r3,%r3 # long | 1143 | lgfr %r3,%r3 # long |
1346 | llgtr %r4,%r4 # struct iocb ** | 1144 | llgtr %r4,%r4 # struct iocb ** |
1347 | jg compat_sys_io_submit | 1145 | jg compat_sys_io_submit |
1348 | 1146 | ||
1349 | .globl sys32_io_cancel_wrapper | 1147 | ENTRY(sys32_io_cancel_wrapper) |
1350 | sys32_io_cancel_wrapper: | ||
1351 | llgfr %r2,%r2 # (aio_context_t) u32 | 1148 | llgfr %r2,%r2 # (aio_context_t) u32 |
1352 | llgtr %r3,%r3 # struct iocb * | 1149 | llgtr %r3,%r3 # struct iocb * |
1353 | llgtr %r4,%r4 # struct io_event * | 1150 | llgtr %r4,%r4 # struct io_event * |
1354 | jg sys_io_cancel | 1151 | jg sys_io_cancel |
1355 | 1152 | ||
1356 | .globl compat_sys_statfs64_wrapper | 1153 | ENTRY(compat_sys_statfs64_wrapper) |
1357 | compat_sys_statfs64_wrapper: | ||
1358 | llgtr %r2,%r2 # const char * | 1154 | llgtr %r2,%r2 # const char * |
1359 | llgfr %r3,%r3 # compat_size_t | 1155 | llgfr %r3,%r3 # compat_size_t |
1360 | llgtr %r4,%r4 # struct compat_statfs64 * | 1156 | llgtr %r4,%r4 # struct compat_statfs64 * |
1361 | jg compat_sys_statfs64 | 1157 | jg compat_sys_statfs64 |
1362 | 1158 | ||
1363 | .globl compat_sys_fstatfs64_wrapper | 1159 | ENTRY(compat_sys_fstatfs64_wrapper) |
1364 | compat_sys_fstatfs64_wrapper: | ||
1365 | llgfr %r2,%r2 # unsigned int fd | 1160 | llgfr %r2,%r2 # unsigned int fd |
1366 | llgfr %r3,%r3 # compat_size_t | 1161 | llgfr %r3,%r3 # compat_size_t |
1367 | llgtr %r4,%r4 # struct compat_statfs64 * | 1162 | llgtr %r4,%r4 # struct compat_statfs64 * |
1368 | jg compat_sys_fstatfs64 | 1163 | jg compat_sys_fstatfs64 |
1369 | 1164 | ||
1370 | .globl compat_sys_mq_open_wrapper | 1165 | ENTRY(compat_sys_mq_open_wrapper) |
1371 | compat_sys_mq_open_wrapper: | ||
1372 | llgtr %r2,%r2 # const char * | 1166 | llgtr %r2,%r2 # const char * |
1373 | lgfr %r3,%r3 # int | 1167 | lgfr %r3,%r3 # int |
1374 | llgfr %r4,%r4 # mode_t | 1168 | llgfr %r4,%r4 # mode_t |
1375 | llgtr %r5,%r5 # struct compat_mq_attr * | 1169 | llgtr %r5,%r5 # struct compat_mq_attr * |
1376 | jg compat_sys_mq_open | 1170 | jg compat_sys_mq_open |
1377 | 1171 | ||
1378 | .globl sys32_mq_unlink_wrapper | 1172 | ENTRY(sys32_mq_unlink_wrapper) |
1379 | sys32_mq_unlink_wrapper: | ||
1380 | llgtr %r2,%r2 # const char * | 1173 | llgtr %r2,%r2 # const char * |
1381 | jg sys_mq_unlink | 1174 | jg sys_mq_unlink |
1382 | 1175 | ||
1383 | .globl compat_sys_mq_timedsend_wrapper | 1176 | ENTRY(compat_sys_mq_timedsend_wrapper) |
1384 | compat_sys_mq_timedsend_wrapper: | ||
1385 | lgfr %r2,%r2 # mqd_t | 1177 | lgfr %r2,%r2 # mqd_t |
1386 | llgtr %r3,%r3 # const char * | 1178 | llgtr %r3,%r3 # const char * |
1387 | llgfr %r4,%r4 # size_t | 1179 | llgfr %r4,%r4 # size_t |
@@ -1389,8 +1181,7 @@ compat_sys_mq_timedsend_wrapper: | |||
1389 | llgtr %r6,%r6 # const struct compat_timespec * | 1181 | llgtr %r6,%r6 # const struct compat_timespec * |
1390 | jg compat_sys_mq_timedsend | 1182 | jg compat_sys_mq_timedsend |
1391 | 1183 | ||
1392 | .globl compat_sys_mq_timedreceive_wrapper | 1184 | ENTRY(compat_sys_mq_timedreceive_wrapper) |
1393 | compat_sys_mq_timedreceive_wrapper: | ||
1394 | lgfr %r2,%r2 # mqd_t | 1185 | lgfr %r2,%r2 # mqd_t |
1395 | llgtr %r3,%r3 # char * | 1186 | llgtr %r3,%r3 # char * |
1396 | llgfr %r4,%r4 # size_t | 1187 | llgfr %r4,%r4 # size_t |
@@ -1398,21 +1189,18 @@ compat_sys_mq_timedreceive_wrapper: | |||
1398 | llgtr %r6,%r6 # const struct compat_timespec * | 1189 | llgtr %r6,%r6 # const struct compat_timespec * |
1399 | jg compat_sys_mq_timedreceive | 1190 | jg compat_sys_mq_timedreceive |
1400 | 1191 | ||
1401 | .globl compat_sys_mq_notify_wrapper | 1192 | ENTRY(compat_sys_mq_notify_wrapper) |
1402 | compat_sys_mq_notify_wrapper: | ||
1403 | lgfr %r2,%r2 # mqd_t | 1193 | lgfr %r2,%r2 # mqd_t |
1404 | llgtr %r3,%r3 # struct compat_sigevent * | 1194 | llgtr %r3,%r3 # struct compat_sigevent * |
1405 | jg compat_sys_mq_notify | 1195 | jg compat_sys_mq_notify |
1406 | 1196 | ||
1407 | .globl compat_sys_mq_getsetattr_wrapper | 1197 | ENTRY(compat_sys_mq_getsetattr_wrapper) |
1408 | compat_sys_mq_getsetattr_wrapper: | ||
1409 | lgfr %r2,%r2 # mqd_t | 1198 | lgfr %r2,%r2 # mqd_t |
1410 | llgtr %r3,%r3 # struct compat_mq_attr * | 1199 | llgtr %r3,%r3 # struct compat_mq_attr * |
1411 | llgtr %r4,%r4 # struct compat_mq_attr * | 1200 | llgtr %r4,%r4 # struct compat_mq_attr * |
1412 | jg compat_sys_mq_getsetattr | 1201 | jg compat_sys_mq_getsetattr |
1413 | 1202 | ||
1414 | .globl compat_sys_add_key_wrapper | 1203 | ENTRY(compat_sys_add_key_wrapper) |
1415 | compat_sys_add_key_wrapper: | ||
1416 | llgtr %r2,%r2 # const char * | 1204 | llgtr %r2,%r2 # const char * |
1417 | llgtr %r3,%r3 # const char * | 1205 | llgtr %r3,%r3 # const char * |
1418 | llgtr %r4,%r4 # const void * | 1206 | llgtr %r4,%r4 # const void * |
@@ -1420,16 +1208,14 @@ compat_sys_add_key_wrapper: | |||
1420 | llgfr %r6,%r6 # (key_serial_t) u32 | 1208 | llgfr %r6,%r6 # (key_serial_t) u32 |
1421 | jg sys_add_key | 1209 | jg sys_add_key |
1422 | 1210 | ||
1423 | .globl compat_sys_request_key_wrapper | 1211 | ENTRY(compat_sys_request_key_wrapper) |
1424 | compat_sys_request_key_wrapper: | ||
1425 | llgtr %r2,%r2 # const char * | 1212 | llgtr %r2,%r2 # const char * |
1426 | llgtr %r3,%r3 # const char * | 1213 | llgtr %r3,%r3 # const char * |
1427 | llgtr %r4,%r4 # const void * | 1214 | llgtr %r4,%r4 # const void * |
1428 | llgfr %r5,%r5 # (key_serial_t) u32 | 1215 | llgfr %r5,%r5 # (key_serial_t) u32 |
1429 | jg sys_request_key | 1216 | jg sys_request_key |
1430 | 1217 | ||
1431 | .globl sys32_remap_file_pages_wrapper | 1218 | ENTRY(sys32_remap_file_pages_wrapper) |
1432 | sys32_remap_file_pages_wrapper: | ||
1433 | llgfr %r2,%r2 # unsigned long | 1219 | llgfr %r2,%r2 # unsigned long |
1434 | llgfr %r3,%r3 # unsigned long | 1220 | llgfr %r3,%r3 # unsigned long |
1435 | llgfr %r4,%r4 # unsigned long | 1221 | llgfr %r4,%r4 # unsigned long |
@@ -1437,8 +1223,7 @@ sys32_remap_file_pages_wrapper: | |||
1437 | llgfr %r6,%r6 # unsigned long | 1223 | llgfr %r6,%r6 # unsigned long |
1438 | jg sys_remap_file_pages | 1224 | jg sys_remap_file_pages |
1439 | 1225 | ||
1440 | .globl compat_sys_waitid_wrapper | 1226 | ENTRY(compat_sys_waitid_wrapper) |
1441 | compat_sys_waitid_wrapper: | ||
1442 | lgfr %r2,%r2 # int | 1227 | lgfr %r2,%r2 # int |
1443 | lgfr %r3,%r3 # pid_t | 1228 | lgfr %r3,%r3 # pid_t |
1444 | llgtr %r4,%r4 # siginfo_emu31_t * | 1229 | llgtr %r4,%r4 # siginfo_emu31_t * |
@@ -1446,65 +1231,56 @@ compat_sys_waitid_wrapper: | |||
1446 | llgtr %r6,%r6 # struct rusage_emu31 * | 1231 | llgtr %r6,%r6 # struct rusage_emu31 * |
1447 | jg compat_sys_waitid | 1232 | jg compat_sys_waitid |
1448 | 1233 | ||
1449 | .globl compat_sys_kexec_load_wrapper | 1234 | ENTRY(compat_sys_kexec_load_wrapper) |
1450 | compat_sys_kexec_load_wrapper: | ||
1451 | llgfr %r2,%r2 # unsigned long | 1235 | llgfr %r2,%r2 # unsigned long |
1452 | llgfr %r3,%r3 # unsigned long | 1236 | llgfr %r3,%r3 # unsigned long |
1453 | llgtr %r4,%r4 # struct kexec_segment * | 1237 | llgtr %r4,%r4 # struct kexec_segment * |
1454 | llgfr %r5,%r5 # unsigned long | 1238 | llgfr %r5,%r5 # unsigned long |
1455 | jg compat_sys_kexec_load | 1239 | jg compat_sys_kexec_load |
1456 | 1240 | ||
1457 | .globl sys_ioprio_set_wrapper | 1241 | ENTRY(sys_ioprio_set_wrapper) |
1458 | sys_ioprio_set_wrapper: | ||
1459 | lgfr %r2,%r2 # int | 1242 | lgfr %r2,%r2 # int |
1460 | lgfr %r3,%r3 # int | 1243 | lgfr %r3,%r3 # int |
1461 | lgfr %r4,%r4 # int | 1244 | lgfr %r4,%r4 # int |
1462 | jg sys_ioprio_set | 1245 | jg sys_ioprio_set |
1463 | 1246 | ||
1464 | .globl sys_ioprio_get_wrapper | 1247 | ENTRY(sys_ioprio_get_wrapper) |
1465 | sys_ioprio_get_wrapper: | ||
1466 | lgfr %r2,%r2 # int | 1248 | lgfr %r2,%r2 # int |
1467 | lgfr %r3,%r3 # int | 1249 | lgfr %r3,%r3 # int |
1468 | jg sys_ioprio_get | 1250 | jg sys_ioprio_get |
1469 | 1251 | ||
1470 | .globl sys_inotify_add_watch_wrapper | 1252 | ENTRY(sys_inotify_add_watch_wrapper) |
1471 | sys_inotify_add_watch_wrapper: | ||
1472 | lgfr %r2,%r2 # int | 1253 | lgfr %r2,%r2 # int |
1473 | llgtr %r3,%r3 # const char * | 1254 | llgtr %r3,%r3 # const char * |
1474 | llgfr %r4,%r4 # u32 | 1255 | llgfr %r4,%r4 # u32 |
1475 | jg sys_inotify_add_watch | 1256 | jg sys_inotify_add_watch |
1476 | 1257 | ||
1477 | .globl sys_inotify_rm_watch_wrapper | 1258 | ENTRY(sys_inotify_rm_watch_wrapper) |
1478 | sys_inotify_rm_watch_wrapper: | ||
1479 | lgfr %r2,%r2 # int | 1259 | lgfr %r2,%r2 # int |
1480 | llgfr %r3,%r3 # u32 | 1260 | llgfr %r3,%r3 # u32 |
1481 | jg sys_inotify_rm_watch | 1261 | jg sys_inotify_rm_watch |
1482 | 1262 | ||
1483 | .globl compat_sys_openat_wrapper | 1263 | ENTRY(compat_sys_openat_wrapper) |
1484 | compat_sys_openat_wrapper: | ||
1485 | llgfr %r2,%r2 # unsigned int | 1264 | llgfr %r2,%r2 # unsigned int |
1486 | llgtr %r3,%r3 # const char * | 1265 | llgtr %r3,%r3 # const char * |
1487 | lgfr %r4,%r4 # int | 1266 | lgfr %r4,%r4 # int |
1488 | lgfr %r5,%r5 # int | 1267 | lgfr %r5,%r5 # int |
1489 | jg compat_sys_openat | 1268 | jg compat_sys_openat |
1490 | 1269 | ||
1491 | .globl sys_mkdirat_wrapper | 1270 | ENTRY(sys_mkdirat_wrapper) |
1492 | sys_mkdirat_wrapper: | ||
1493 | lgfr %r2,%r2 # int | 1271 | lgfr %r2,%r2 # int |
1494 | llgtr %r3,%r3 # const char * | 1272 | llgtr %r3,%r3 # const char * |
1495 | lgfr %r4,%r4 # int | 1273 | lgfr %r4,%r4 # int |
1496 | jg sys_mkdirat | 1274 | jg sys_mkdirat |
1497 | 1275 | ||
1498 | .globl sys_mknodat_wrapper | 1276 | ENTRY(sys_mknodat_wrapper) |
1499 | sys_mknodat_wrapper: | ||
1500 | lgfr %r2,%r2 # int | 1277 | lgfr %r2,%r2 # int |
1501 | llgtr %r3,%r3 # const char * | 1278 | llgtr %r3,%r3 # const char * |
1502 | lgfr %r4,%r4 # int | 1279 | lgfr %r4,%r4 # int |
1503 | llgfr %r5,%r5 # unsigned int | 1280 | llgfr %r5,%r5 # unsigned int |
1504 | jg sys_mknodat | 1281 | jg sys_mknodat |
1505 | 1282 | ||
1506 | .globl sys_fchownat_wrapper | 1283 | ENTRY(sys_fchownat_wrapper) |
1507 | sys_fchownat_wrapper: | ||
1508 | lgfr %r2,%r2 # int | 1284 | lgfr %r2,%r2 # int |
1509 | llgtr %r3,%r3 # const char * | 1285 | llgtr %r3,%r3 # const char * |
1510 | llgfr %r4,%r4 # uid_t | 1286 | llgfr %r4,%r4 # uid_t |
@@ -1512,38 +1288,33 @@ sys_fchownat_wrapper: | |||
1512 | lgfr %r6,%r6 # int | 1288 | lgfr %r6,%r6 # int |
1513 | jg sys_fchownat | 1289 | jg sys_fchownat |
1514 | 1290 | ||
1515 | .globl compat_sys_futimesat_wrapper | 1291 | ENTRY(compat_sys_futimesat_wrapper) |
1516 | compat_sys_futimesat_wrapper: | ||
1517 | llgfr %r2,%r2 # unsigned int | 1292 | llgfr %r2,%r2 # unsigned int |
1518 | llgtr %r3,%r3 # char * | 1293 | llgtr %r3,%r3 # char * |
1519 | llgtr %r4,%r4 # struct timeval * | 1294 | llgtr %r4,%r4 # struct timeval * |
1520 | jg compat_sys_futimesat | 1295 | jg compat_sys_futimesat |
1521 | 1296 | ||
1522 | .globl sys32_fstatat64_wrapper | 1297 | ENTRY(sys32_fstatat64_wrapper) |
1523 | sys32_fstatat64_wrapper: | ||
1524 | llgfr %r2,%r2 # unsigned int | 1298 | llgfr %r2,%r2 # unsigned int |
1525 | llgtr %r3,%r3 # char * | 1299 | llgtr %r3,%r3 # char * |
1526 | llgtr %r4,%r4 # struct stat64 * | 1300 | llgtr %r4,%r4 # struct stat64 * |
1527 | lgfr %r5,%r5 # int | 1301 | lgfr %r5,%r5 # int |
1528 | jg sys32_fstatat64 | 1302 | jg sys32_fstatat64 |
1529 | 1303 | ||
1530 | .globl sys_unlinkat_wrapper | 1304 | ENTRY(sys_unlinkat_wrapper) |
1531 | sys_unlinkat_wrapper: | ||
1532 | lgfr %r2,%r2 # int | 1305 | lgfr %r2,%r2 # int |
1533 | llgtr %r3,%r3 # const char * | 1306 | llgtr %r3,%r3 # const char * |
1534 | lgfr %r4,%r4 # int | 1307 | lgfr %r4,%r4 # int |
1535 | jg sys_unlinkat | 1308 | jg sys_unlinkat |
1536 | 1309 | ||
1537 | .globl sys_renameat_wrapper | 1310 | ENTRY(sys_renameat_wrapper) |
1538 | sys_renameat_wrapper: | ||
1539 | lgfr %r2,%r2 # int | 1311 | lgfr %r2,%r2 # int |
1540 | llgtr %r3,%r3 # const char * | 1312 | llgtr %r3,%r3 # const char * |
1541 | lgfr %r4,%r4 # int | 1313 | lgfr %r4,%r4 # int |
1542 | llgtr %r5,%r5 # const char * | 1314 | llgtr %r5,%r5 # const char * |
1543 | jg sys_renameat | 1315 | jg sys_renameat |
1544 | 1316 | ||
1545 | .globl sys_linkat_wrapper | 1317 | ENTRY(sys_linkat_wrapper) |
1546 | sys_linkat_wrapper: | ||
1547 | lgfr %r2,%r2 # int | 1318 | lgfr %r2,%r2 # int |
1548 | llgtr %r3,%r3 # const char * | 1319 | llgtr %r3,%r3 # const char * |
1549 | lgfr %r4,%r4 # int | 1320 | lgfr %r4,%r4 # int |
@@ -1551,37 +1322,32 @@ sys_linkat_wrapper: | |||
1551 | lgfr %r6,%r6 # int | 1322 | lgfr %r6,%r6 # int |
1552 | jg sys_linkat | 1323 | jg sys_linkat |
1553 | 1324 | ||
1554 | .globl sys_symlinkat_wrapper | 1325 | ENTRY(sys_symlinkat_wrapper) |
1555 | sys_symlinkat_wrapper: | ||
1556 | llgtr %r2,%r2 # const char * | 1326 | llgtr %r2,%r2 # const char * |
1557 | lgfr %r3,%r3 # int | 1327 | lgfr %r3,%r3 # int |
1558 | llgtr %r4,%r4 # const char * | 1328 | llgtr %r4,%r4 # const char * |
1559 | jg sys_symlinkat | 1329 | jg sys_symlinkat |
1560 | 1330 | ||
1561 | .globl sys_readlinkat_wrapper | 1331 | ENTRY(sys_readlinkat_wrapper) |
1562 | sys_readlinkat_wrapper: | ||
1563 | lgfr %r2,%r2 # int | 1332 | lgfr %r2,%r2 # int |
1564 | llgtr %r3,%r3 # const char * | 1333 | llgtr %r3,%r3 # const char * |
1565 | llgtr %r4,%r4 # char * | 1334 | llgtr %r4,%r4 # char * |
1566 | lgfr %r5,%r5 # int | 1335 | lgfr %r5,%r5 # int |
1567 | jg sys_readlinkat | 1336 | jg sys_readlinkat |
1568 | 1337 | ||
1569 | .globl sys_fchmodat_wrapper | 1338 | ENTRY(sys_fchmodat_wrapper) |
1570 | sys_fchmodat_wrapper: | ||
1571 | lgfr %r2,%r2 # int | 1339 | lgfr %r2,%r2 # int |
1572 | llgtr %r3,%r3 # const char * | 1340 | llgtr %r3,%r3 # const char * |
1573 | llgfr %r4,%r4 # mode_t | 1341 | llgfr %r4,%r4 # mode_t |
1574 | jg sys_fchmodat | 1342 | jg sys_fchmodat |
1575 | 1343 | ||
1576 | .globl sys_faccessat_wrapper | 1344 | ENTRY(sys_faccessat_wrapper) |
1577 | sys_faccessat_wrapper: | ||
1578 | lgfr %r2,%r2 # int | 1345 | lgfr %r2,%r2 # int |
1579 | llgtr %r3,%r3 # const char * | 1346 | llgtr %r3,%r3 # const char * |
1580 | lgfr %r4,%r4 # int | 1347 | lgfr %r4,%r4 # int |
1581 | jg sys_faccessat | 1348 | jg sys_faccessat |
1582 | 1349 | ||
1583 | .globl compat_sys_pselect6_wrapper | 1350 | ENTRY(compat_sys_pselect6_wrapper) |
1584 | compat_sys_pselect6_wrapper: | ||
1585 | lgfr %r2,%r2 # int | 1351 | lgfr %r2,%r2 # int |
1586 | llgtr %r3,%r3 # fd_set * | 1352 | llgtr %r3,%r3 # fd_set * |
1587 | llgtr %r4,%r4 # fd_set * | 1353 | llgtr %r4,%r4 # fd_set * |
@@ -1591,8 +1357,7 @@ compat_sys_pselect6_wrapper: | |||
1591 | stg %r0,160(%r15) | 1357 | stg %r0,160(%r15) |
1592 | jg compat_sys_pselect6 | 1358 | jg compat_sys_pselect6 |
1593 | 1359 | ||
1594 | .globl compat_sys_ppoll_wrapper | 1360 | ENTRY(compat_sys_ppoll_wrapper) |
1595 | compat_sys_ppoll_wrapper: | ||
1596 | llgtr %r2,%r2 # struct pollfd * | 1361 | llgtr %r2,%r2 # struct pollfd * |
1597 | llgfr %r3,%r3 # unsigned int | 1362 | llgfr %r3,%r3 # unsigned int |
1598 | llgtr %r4,%r4 # struct timespec * | 1363 | llgtr %r4,%r4 # struct timespec * |
@@ -1600,26 +1365,22 @@ compat_sys_ppoll_wrapper: | |||
1600 | llgfr %r6,%r6 # size_t | 1365 | llgfr %r6,%r6 # size_t |
1601 | jg compat_sys_ppoll | 1366 | jg compat_sys_ppoll |
1602 | 1367 | ||
1603 | .globl sys_unshare_wrapper | 1368 | ENTRY(sys_unshare_wrapper) |
1604 | sys_unshare_wrapper: | ||
1605 | llgfr %r2,%r2 # unsigned long | 1369 | llgfr %r2,%r2 # unsigned long |
1606 | jg sys_unshare | 1370 | jg sys_unshare |
1607 | 1371 | ||
1608 | .globl compat_sys_set_robust_list_wrapper | 1372 | ENTRY(compat_sys_set_robust_list_wrapper) |
1609 | compat_sys_set_robust_list_wrapper: | ||
1610 | llgtr %r2,%r2 # struct compat_robust_list_head * | 1373 | llgtr %r2,%r2 # struct compat_robust_list_head * |
1611 | llgfr %r3,%r3 # size_t | 1374 | llgfr %r3,%r3 # size_t |
1612 | jg compat_sys_set_robust_list | 1375 | jg compat_sys_set_robust_list |
1613 | 1376 | ||
1614 | .globl compat_sys_get_robust_list_wrapper | 1377 | ENTRY(compat_sys_get_robust_list_wrapper) |
1615 | compat_sys_get_robust_list_wrapper: | ||
1616 | lgfr %r2,%r2 # int | 1378 | lgfr %r2,%r2 # int |
1617 | llgtr %r3,%r3 # compat_uptr_t_t * | 1379 | llgtr %r3,%r3 # compat_uptr_t_t * |
1618 | llgtr %r4,%r4 # compat_size_t * | 1380 | llgtr %r4,%r4 # compat_size_t * |
1619 | jg compat_sys_get_robust_list | 1381 | jg compat_sys_get_robust_list |
1620 | 1382 | ||
1621 | .globl sys_splice_wrapper | 1383 | ENTRY(sys_splice_wrapper) |
1622 | sys_splice_wrapper: | ||
1623 | lgfr %r2,%r2 # int | 1384 | lgfr %r2,%r2 # int |
1624 | llgtr %r3,%r3 # loff_t * | 1385 | llgtr %r3,%r3 # loff_t * |
1625 | lgfr %r4,%r4 # int | 1386 | lgfr %r4,%r4 # int |
@@ -1629,8 +1390,7 @@ sys_splice_wrapper: | |||
1629 | stg %r0,160(%r15) | 1390 | stg %r0,160(%r15) |
1630 | jg sys_splice | 1391 | jg sys_splice |
1631 | 1392 | ||
1632 | .globl sys_sync_file_range_wrapper | 1393 | ENTRY(sys_sync_file_range_wrapper) |
1633 | sys_sync_file_range_wrapper: | ||
1634 | lgfr %r2,%r2 # int | 1394 | lgfr %r2,%r2 # int |
1635 | sllg %r3,%r3,32 # get high word of 64bit loff_t | 1395 | sllg %r3,%r3,32 # get high word of 64bit loff_t |
1636 | or %r3,%r4 # get low word of 64bit loff_t | 1396 | or %r3,%r4 # get low word of 64bit loff_t |
@@ -1639,31 +1399,27 @@ sys_sync_file_range_wrapper: | |||
1639 | llgf %r5,164(%r15) # unsigned int | 1399 | llgf %r5,164(%r15) # unsigned int |
1640 | jg sys_sync_file_range | 1400 | jg sys_sync_file_range |
1641 | 1401 | ||
1642 | .globl sys_tee_wrapper | 1402 | ENTRY(sys_tee_wrapper) |
1643 | sys_tee_wrapper: | ||
1644 | lgfr %r2,%r2 # int | 1403 | lgfr %r2,%r2 # int |
1645 | lgfr %r3,%r3 # int | 1404 | lgfr %r3,%r3 # int |
1646 | llgfr %r4,%r4 # size_t | 1405 | llgfr %r4,%r4 # size_t |
1647 | llgfr %r5,%r5 # unsigned int | 1406 | llgfr %r5,%r5 # unsigned int |
1648 | jg sys_tee | 1407 | jg sys_tee |
1649 | 1408 | ||
1650 | .globl compat_sys_vmsplice_wrapper | 1409 | ENTRY(compat_sys_vmsplice_wrapper) |
1651 | compat_sys_vmsplice_wrapper: | ||
1652 | lgfr %r2,%r2 # int | 1410 | lgfr %r2,%r2 # int |
1653 | llgtr %r3,%r3 # compat_iovec * | 1411 | llgtr %r3,%r3 # compat_iovec * |
1654 | llgfr %r4,%r4 # unsigned int | 1412 | llgfr %r4,%r4 # unsigned int |
1655 | llgfr %r5,%r5 # unsigned int | 1413 | llgfr %r5,%r5 # unsigned int |
1656 | jg compat_sys_vmsplice | 1414 | jg compat_sys_vmsplice |
1657 | 1415 | ||
1658 | .globl sys_getcpu_wrapper | 1416 | ENTRY(sys_getcpu_wrapper) |
1659 | sys_getcpu_wrapper: | ||
1660 | llgtr %r2,%r2 # unsigned * | 1417 | llgtr %r2,%r2 # unsigned * |
1661 | llgtr %r3,%r3 # unsigned * | 1418 | llgtr %r3,%r3 # unsigned * |
1662 | llgtr %r4,%r4 # struct getcpu_cache * | 1419 | llgtr %r4,%r4 # struct getcpu_cache * |
1663 | jg sys_getcpu | 1420 | jg sys_getcpu |
1664 | 1421 | ||
1665 | .globl compat_sys_epoll_pwait_wrapper | 1422 | ENTRY(compat_sys_epoll_pwait_wrapper) |
1666 | compat_sys_epoll_pwait_wrapper: | ||
1667 | lgfr %r2,%r2 # int | 1423 | lgfr %r2,%r2 # int |
1668 | llgtr %r3,%r3 # struct compat_epoll_event * | 1424 | llgtr %r3,%r3 # struct compat_epoll_event * |
1669 | lgfr %r4,%r4 # int | 1425 | lgfr %r4,%r4 # int |
@@ -1673,34 +1429,29 @@ compat_sys_epoll_pwait_wrapper: | |||
1673 | stg %r0,160(%r15) | 1429 | stg %r0,160(%r15) |
1674 | jg compat_sys_epoll_pwait | 1430 | jg compat_sys_epoll_pwait |
1675 | 1431 | ||
1676 | .globl compat_sys_utimes_wrapper | 1432 | ENTRY(compat_sys_utimes_wrapper) |
1677 | compat_sys_utimes_wrapper: | ||
1678 | llgtr %r2,%r2 # char * | 1433 | llgtr %r2,%r2 # char * |
1679 | llgtr %r3,%r3 # struct compat_timeval * | 1434 | llgtr %r3,%r3 # struct compat_timeval * |
1680 | jg compat_sys_utimes | 1435 | jg compat_sys_utimes |
1681 | 1436 | ||
1682 | .globl compat_sys_utimensat_wrapper | 1437 | ENTRY(compat_sys_utimensat_wrapper) |
1683 | compat_sys_utimensat_wrapper: | ||
1684 | llgfr %r2,%r2 # unsigned int | 1438 | llgfr %r2,%r2 # unsigned int |
1685 | llgtr %r3,%r3 # char * | 1439 | llgtr %r3,%r3 # char * |
1686 | llgtr %r4,%r4 # struct compat_timespec * | 1440 | llgtr %r4,%r4 # struct compat_timespec * |
1687 | lgfr %r5,%r5 # int | 1441 | lgfr %r5,%r5 # int |
1688 | jg compat_sys_utimensat | 1442 | jg compat_sys_utimensat |
1689 | 1443 | ||
1690 | .globl compat_sys_signalfd_wrapper | 1444 | ENTRY(compat_sys_signalfd_wrapper) |
1691 | compat_sys_signalfd_wrapper: | ||
1692 | lgfr %r2,%r2 # int | 1445 | lgfr %r2,%r2 # int |
1693 | llgtr %r3,%r3 # compat_sigset_t * | 1446 | llgtr %r3,%r3 # compat_sigset_t * |
1694 | llgfr %r4,%r4 # compat_size_t | 1447 | llgfr %r4,%r4 # compat_size_t |
1695 | jg compat_sys_signalfd | 1448 | jg compat_sys_signalfd |
1696 | 1449 | ||
1697 | .globl sys_eventfd_wrapper | 1450 | ENTRY(sys_eventfd_wrapper) |
1698 | sys_eventfd_wrapper: | ||
1699 | llgfr %r2,%r2 # unsigned int | 1451 | llgfr %r2,%r2 # unsigned int |
1700 | jg sys_eventfd | 1452 | jg sys_eventfd |
1701 | 1453 | ||
1702 | .globl sys_fallocate_wrapper | 1454 | ENTRY(sys_fallocate_wrapper) |
1703 | sys_fallocate_wrapper: | ||
1704 | lgfr %r2,%r2 # int | 1455 | lgfr %r2,%r2 # int |
1705 | lgfr %r3,%r3 # int | 1456 | lgfr %r3,%r3 # int |
1706 | sllg %r4,%r4,32 # get high word of 64bit loff_t | 1457 | sllg %r4,%r4,32 # get high word of 64bit loff_t |
@@ -1709,94 +1460,80 @@ sys_fallocate_wrapper: | |||
1709 | l %r5,164(%r15) # get low word of 64bit loff_t | 1460 | l %r5,164(%r15) # get low word of 64bit loff_t |
1710 | jg sys_fallocate | 1461 | jg sys_fallocate |
1711 | 1462 | ||
1712 | .globl sys_timerfd_create_wrapper | 1463 | ENTRY(sys_timerfd_create_wrapper) |
1713 | sys_timerfd_create_wrapper: | ||
1714 | lgfr %r2,%r2 # int | 1464 | lgfr %r2,%r2 # int |
1715 | lgfr %r3,%r3 # int | 1465 | lgfr %r3,%r3 # int |
1716 | jg sys_timerfd_create | 1466 | jg sys_timerfd_create |
1717 | 1467 | ||
1718 | .globl compat_sys_timerfd_settime_wrapper | 1468 | ENTRY(compat_sys_timerfd_settime_wrapper) |
1719 | compat_sys_timerfd_settime_wrapper: | ||
1720 | lgfr %r2,%r2 # int | 1469 | lgfr %r2,%r2 # int |
1721 | lgfr %r3,%r3 # int | 1470 | lgfr %r3,%r3 # int |
1722 | llgtr %r4,%r4 # struct compat_itimerspec * | 1471 | llgtr %r4,%r4 # struct compat_itimerspec * |
1723 | llgtr %r5,%r5 # struct compat_itimerspec * | 1472 | llgtr %r5,%r5 # struct compat_itimerspec * |
1724 | jg compat_sys_timerfd_settime | 1473 | jg compat_sys_timerfd_settime |
1725 | 1474 | ||
1726 | .globl compat_sys_timerfd_gettime_wrapper | 1475 | ENTRY(compat_sys_timerfd_gettime_wrapper) |
1727 | compat_sys_timerfd_gettime_wrapper: | ||
1728 | lgfr %r2,%r2 # int | 1476 | lgfr %r2,%r2 # int |
1729 | llgtr %r3,%r3 # struct compat_itimerspec * | 1477 | llgtr %r3,%r3 # struct compat_itimerspec * |
1730 | jg compat_sys_timerfd_gettime | 1478 | jg compat_sys_timerfd_gettime |
1731 | 1479 | ||
1732 | .globl compat_sys_signalfd4_wrapper | 1480 | ENTRY(compat_sys_signalfd4_wrapper) |
1733 | compat_sys_signalfd4_wrapper: | ||
1734 | lgfr %r2,%r2 # int | 1481 | lgfr %r2,%r2 # int |
1735 | llgtr %r3,%r3 # compat_sigset_t * | 1482 | llgtr %r3,%r3 # compat_sigset_t * |
1736 | llgfr %r4,%r4 # compat_size_t | 1483 | llgfr %r4,%r4 # compat_size_t |
1737 | lgfr %r5,%r5 # int | 1484 | lgfr %r5,%r5 # int |
1738 | jg compat_sys_signalfd4 | 1485 | jg compat_sys_signalfd4 |
1739 | 1486 | ||
1740 | .globl sys_eventfd2_wrapper | 1487 | ENTRY(sys_eventfd2_wrapper) |
1741 | sys_eventfd2_wrapper: | ||
1742 | llgfr %r2,%r2 # unsigned int | 1488 | llgfr %r2,%r2 # unsigned int |
1743 | lgfr %r3,%r3 # int | 1489 | lgfr %r3,%r3 # int |
1744 | jg sys_eventfd2 | 1490 | jg sys_eventfd2 |
1745 | 1491 | ||
1746 | .globl sys_inotify_init1_wrapper | 1492 | ENTRY(sys_inotify_init1_wrapper) |
1747 | sys_inotify_init1_wrapper: | ||
1748 | lgfr %r2,%r2 # int | 1493 | lgfr %r2,%r2 # int |
1749 | jg sys_inotify_init1 | 1494 | jg sys_inotify_init1 |
1750 | 1495 | ||
1751 | .globl sys_pipe2_wrapper | 1496 | ENTRY(sys_pipe2_wrapper) |
1752 | sys_pipe2_wrapper: | ||
1753 | llgtr %r2,%r2 # u32 * | 1497 | llgtr %r2,%r2 # u32 * |
1754 | lgfr %r3,%r3 # int | 1498 | lgfr %r3,%r3 # int |
1755 | jg sys_pipe2 # branch to system call | 1499 | jg sys_pipe2 # branch to system call |
1756 | 1500 | ||
1757 | .globl sys_dup3_wrapper | 1501 | ENTRY(sys_dup3_wrapper) |
1758 | sys_dup3_wrapper: | ||
1759 | llgfr %r2,%r2 # unsigned int | 1502 | llgfr %r2,%r2 # unsigned int |
1760 | llgfr %r3,%r3 # unsigned int | 1503 | llgfr %r3,%r3 # unsigned int |
1761 | lgfr %r4,%r4 # int | 1504 | lgfr %r4,%r4 # int |
1762 | jg sys_dup3 # branch to system call | 1505 | jg sys_dup3 # branch to system call |
1763 | 1506 | ||
1764 | .globl sys_epoll_create1_wrapper | 1507 | ENTRY(sys_epoll_create1_wrapper) |
1765 | sys_epoll_create1_wrapper: | ||
1766 | lgfr %r2,%r2 # int | 1508 | lgfr %r2,%r2 # int |
1767 | jg sys_epoll_create1 # branch to system call | 1509 | jg sys_epoll_create1 # branch to system call |
1768 | 1510 | ||
1769 | .globl sys32_readahead_wrapper | 1511 | ENTRY(sys32_readahead_wrapper) |
1770 | sys32_readahead_wrapper: | ||
1771 | lgfr %r2,%r2 # int | 1512 | lgfr %r2,%r2 # int |
1772 | llgfr %r3,%r3 # u32 | 1513 | llgfr %r3,%r3 # u32 |
1773 | llgfr %r4,%r4 # u32 | 1514 | llgfr %r4,%r4 # u32 |
1774 | lgfr %r5,%r5 # s32 | 1515 | lgfr %r5,%r5 # s32 |
1775 | jg sys32_readahead # branch to system call | 1516 | jg sys32_readahead # branch to system call |
1776 | 1517 | ||
1777 | .globl sys32_sendfile64_wrapper | 1518 | ENTRY(sys32_sendfile64_wrapper) |
1778 | sys32_sendfile64_wrapper: | ||
1779 | lgfr %r2,%r2 # int | 1519 | lgfr %r2,%r2 # int |
1780 | lgfr %r3,%r3 # int | 1520 | lgfr %r3,%r3 # int |
1781 | llgtr %r4,%r4 # compat_loff_t * | 1521 | llgtr %r4,%r4 # compat_loff_t * |
1782 | lgfr %r5,%r5 # s32 | 1522 | lgfr %r5,%r5 # s32 |
1783 | jg sys32_sendfile64 # branch to system call | 1523 | jg sys32_sendfile64 # branch to system call |
1784 | 1524 | ||
1785 | .globl sys_tkill_wrapper | 1525 | ENTRY(sys_tkill_wrapper) |
1786 | sys_tkill_wrapper: | ||
1787 | lgfr %r2,%r2 # pid_t | 1526 | lgfr %r2,%r2 # pid_t |
1788 | lgfr %r3,%r3 # int | 1527 | lgfr %r3,%r3 # int |
1789 | jg sys_tkill # branch to system call | 1528 | jg sys_tkill # branch to system call |
1790 | 1529 | ||
1791 | .globl sys_tgkill_wrapper | 1530 | ENTRY(sys_tgkill_wrapper) |
1792 | sys_tgkill_wrapper: | ||
1793 | lgfr %r2,%r2 # pid_t | 1531 | lgfr %r2,%r2 # pid_t |
1794 | lgfr %r3,%r3 # pid_t | 1532 | lgfr %r3,%r3 # pid_t |
1795 | lgfr %r4,%r4 # int | 1533 | lgfr %r4,%r4 # int |
1796 | jg sys_tgkill # branch to system call | 1534 | jg sys_tgkill # branch to system call |
1797 | 1535 | ||
1798 | .globl compat_sys_keyctl_wrapper | 1536 | ENTRY(compat_sys_keyctl_wrapper) |
1799 | compat_sys_keyctl_wrapper: | ||
1800 | llgfr %r2,%r2 # u32 | 1537 | llgfr %r2,%r2 # u32 |
1801 | llgfr %r3,%r3 # u32 | 1538 | llgfr %r3,%r3 # u32 |
1802 | llgfr %r4,%r4 # u32 | 1539 | llgfr %r4,%r4 # u32 |
@@ -1804,8 +1541,7 @@ compat_sys_keyctl_wrapper: | |||
1804 | llgfr %r6,%r6 # u32 | 1541 | llgfr %r6,%r6 # u32 |
1805 | jg compat_sys_keyctl # branch to system call | 1542 | jg compat_sys_keyctl # branch to system call |
1806 | 1543 | ||
1807 | .globl compat_sys_preadv_wrapper | 1544 | ENTRY(compat_sys_preadv_wrapper) |
1808 | compat_sys_preadv_wrapper: | ||
1809 | llgfr %r2,%r2 # unsigned long | 1545 | llgfr %r2,%r2 # unsigned long |
1810 | llgtr %r3,%r3 # compat_iovec * | 1546 | llgtr %r3,%r3 # compat_iovec * |
1811 | llgfr %r4,%r4 # unsigned long | 1547 | llgfr %r4,%r4 # unsigned long |
@@ -1813,8 +1549,7 @@ compat_sys_preadv_wrapper: | |||
1813 | llgfr %r6,%r6 # u32 | 1549 | llgfr %r6,%r6 # u32 |
1814 | jg compat_sys_preadv # branch to system call | 1550 | jg compat_sys_preadv # branch to system call |
1815 | 1551 | ||
1816 | .globl compat_sys_pwritev_wrapper | 1552 | ENTRY(compat_sys_pwritev_wrapper) |
1817 | compat_sys_pwritev_wrapper: | ||
1818 | llgfr %r2,%r2 # unsigned long | 1553 | llgfr %r2,%r2 # unsigned long |
1819 | llgtr %r3,%r3 # compat_iovec * | 1554 | llgtr %r3,%r3 # compat_iovec * |
1820 | llgfr %r4,%r4 # unsigned long | 1555 | llgfr %r4,%r4 # unsigned long |
@@ -1822,16 +1557,14 @@ compat_sys_pwritev_wrapper: | |||
1822 | llgfr %r6,%r6 # u32 | 1557 | llgfr %r6,%r6 # u32 |
1823 | jg compat_sys_pwritev # branch to system call | 1558 | jg compat_sys_pwritev # branch to system call |
1824 | 1559 | ||
1825 | .globl compat_sys_rt_tgsigqueueinfo_wrapper | 1560 | ENTRY(compat_sys_rt_tgsigqueueinfo_wrapper) |
1826 | compat_sys_rt_tgsigqueueinfo_wrapper: | ||
1827 | lgfr %r2,%r2 # compat_pid_t | 1561 | lgfr %r2,%r2 # compat_pid_t |
1828 | lgfr %r3,%r3 # compat_pid_t | 1562 | lgfr %r3,%r3 # compat_pid_t |
1829 | lgfr %r4,%r4 # int | 1563 | lgfr %r4,%r4 # int |
1830 | llgtr %r5,%r5 # struct compat_siginfo * | 1564 | llgtr %r5,%r5 # struct compat_siginfo * |
1831 | jg compat_sys_rt_tgsigqueueinfo_wrapper # branch to system call | 1565 | jg compat_sys_rt_tgsigqueueinfo_wrapper # branch to system call |
1832 | 1566 | ||
1833 | .globl sys_perf_event_open_wrapper | 1567 | ENTRY(sys_perf_event_open_wrapper) |
1834 | sys_perf_event_open_wrapper: | ||
1835 | llgtr %r2,%r2 # const struct perf_event_attr * | 1568 | llgtr %r2,%r2 # const struct perf_event_attr * |
1836 | lgfr %r3,%r3 # pid_t | 1569 | lgfr %r3,%r3 # pid_t |
1837 | lgfr %r4,%r4 # int | 1570 | lgfr %r4,%r4 # int |
@@ -1839,29 +1572,25 @@ sys_perf_event_open_wrapper: | |||
1839 | llgfr %r6,%r6 # unsigned long | 1572 | llgfr %r6,%r6 # unsigned long |
1840 | jg sys_perf_event_open # branch to system call | 1573 | jg sys_perf_event_open # branch to system call |
1841 | 1574 | ||
1842 | .globl sys_clone_wrapper | 1575 | ENTRY(sys_clone_wrapper) |
1843 | sys_clone_wrapper: | ||
1844 | llgfr %r2,%r2 # unsigned long | 1576 | llgfr %r2,%r2 # unsigned long |
1845 | llgfr %r3,%r3 # unsigned long | 1577 | llgfr %r3,%r3 # unsigned long |
1846 | llgtr %r4,%r4 # int * | 1578 | llgtr %r4,%r4 # int * |
1847 | llgtr %r5,%r5 # int * | 1579 | llgtr %r5,%r5 # int * |
1848 | jg sys_clone # branch to system call | 1580 | jg sys_clone # branch to system call |
1849 | 1581 | ||
1850 | .globl sys32_execve_wrapper | 1582 | ENTRY(sys32_execve_wrapper) |
1851 | sys32_execve_wrapper: | ||
1852 | llgtr %r2,%r2 # char * | 1583 | llgtr %r2,%r2 # char * |
1853 | llgtr %r3,%r3 # compat_uptr_t * | 1584 | llgtr %r3,%r3 # compat_uptr_t * |
1854 | llgtr %r4,%r4 # compat_uptr_t * | 1585 | llgtr %r4,%r4 # compat_uptr_t * |
1855 | jg sys32_execve # branch to system call | 1586 | jg sys32_execve # branch to system call |
1856 | 1587 | ||
1857 | .globl sys_fanotify_init_wrapper | 1588 | ENTRY(sys_fanotify_init_wrapper) |
1858 | sys_fanotify_init_wrapper: | ||
1859 | llgfr %r2,%r2 # unsigned int | 1589 | llgfr %r2,%r2 # unsigned int |
1860 | llgfr %r3,%r3 # unsigned int | 1590 | llgfr %r3,%r3 # unsigned int |
1861 | jg sys_fanotify_init # branch to system call | 1591 | jg sys_fanotify_init # branch to system call |
1862 | 1592 | ||
1863 | .globl sys_fanotify_mark_wrapper | 1593 | ENTRY(sys_fanotify_mark_wrapper) |
1864 | sys_fanotify_mark_wrapper: | ||
1865 | lgfr %r2,%r2 # int | 1594 | lgfr %r2,%r2 # int |
1866 | llgfr %r3,%r3 # unsigned int | 1595 | llgfr %r3,%r3 # unsigned int |
1867 | sllg %r4,%r4,32 # get high word of 64bit mask | 1596 | sllg %r4,%r4,32 # get high word of 64bit mask |
@@ -1870,16 +1599,14 @@ sys_fanotify_mark_wrapper: | |||
1870 | llgt %r6,164(%r15) # char * | 1599 | llgt %r6,164(%r15) # char * |
1871 | jg sys_fanotify_mark # branch to system call | 1600 | jg sys_fanotify_mark # branch to system call |
1872 | 1601 | ||
1873 | .globl sys_prlimit64_wrapper | 1602 | ENTRY(sys_prlimit64_wrapper) |
1874 | sys_prlimit64_wrapper: | ||
1875 | lgfr %r2,%r2 # pid_t | 1603 | lgfr %r2,%r2 # pid_t |
1876 | llgfr %r3,%r3 # unsigned int | 1604 | llgfr %r3,%r3 # unsigned int |
1877 | llgtr %r4,%r4 # const struct rlimit64 __user * | 1605 | llgtr %r4,%r4 # const struct rlimit64 __user * |
1878 | llgtr %r5,%r5 # struct rlimit64 __user * | 1606 | llgtr %r5,%r5 # struct rlimit64 __user * |
1879 | jg sys_prlimit64 # branch to system call | 1607 | jg sys_prlimit64 # branch to system call |
1880 | 1608 | ||
1881 | .globl sys_name_to_handle_at_wrapper | 1609 | ENTRY(sys_name_to_handle_at_wrapper) |
1882 | sys_name_to_handle_at_wrapper: | ||
1883 | lgfr %r2,%r2 # int | 1610 | lgfr %r2,%r2 # int |
1884 | llgtr %r3,%r3 # const char __user * | 1611 | llgtr %r3,%r3 # const char __user * |
1885 | llgtr %r4,%r4 # struct file_handle __user * | 1612 | llgtr %r4,%r4 # struct file_handle __user * |
@@ -1887,21 +1614,18 @@ sys_name_to_handle_at_wrapper: | |||
1887 | lgfr %r6,%r6 # int | 1614 | lgfr %r6,%r6 # int |
1888 | jg sys_name_to_handle_at | 1615 | jg sys_name_to_handle_at |
1889 | 1616 | ||
1890 | .globl compat_sys_open_by_handle_at_wrapper | 1617 | ENTRY(compat_sys_open_by_handle_at_wrapper) |
1891 | compat_sys_open_by_handle_at_wrapper: | ||
1892 | lgfr %r2,%r2 # int | 1618 | lgfr %r2,%r2 # int |
1893 | llgtr %r3,%r3 # struct file_handle __user * | 1619 | llgtr %r3,%r3 # struct file_handle __user * |
1894 | lgfr %r4,%r4 # int | 1620 | lgfr %r4,%r4 # int |
1895 | jg compat_sys_open_by_handle_at | 1621 | jg compat_sys_open_by_handle_at |
1896 | 1622 | ||
1897 | .globl compat_sys_clock_adjtime_wrapper | 1623 | ENTRY(compat_sys_clock_adjtime_wrapper) |
1898 | compat_sys_clock_adjtime_wrapper: | ||
1899 | lgfr %r2,%r2 # clockid_t (int) | 1624 | lgfr %r2,%r2 # clockid_t (int) |
1900 | llgtr %r3,%r3 # struct compat_timex __user * | 1625 | llgtr %r3,%r3 # struct compat_timex __user * |
1901 | jg compat_sys_clock_adjtime | 1626 | jg compat_sys_clock_adjtime |
1902 | 1627 | ||
1903 | .globl sys_syncfs_wrapper | 1628 | ENTRY(sys_syncfs_wrapper) |
1904 | sys_syncfs_wrapper: | ||
1905 | lgfr %r2,%r2 # int | 1629 | lgfr %r2,%r2 # int |
1906 | jg sys_syncfs | 1630 | jg sys_syncfs |
1907 | 1631 | ||
diff --git a/arch/s390/kernel/entry.S b/arch/s390/kernel/entry.S index 0476174dfff5..3eab7cfab07c 100644 --- a/arch/s390/kernel/entry.S +++ b/arch/s390/kernel/entry.S | |||
@@ -9,8 +9,8 @@ | |||
9 | * Heiko Carstens <heiko.carstens@de.ibm.com> | 9 | * Heiko Carstens <heiko.carstens@de.ibm.com> |
10 | */ | 10 | */ |
11 | 11 | ||
12 | #include <linux/linkage.h> | ||
13 | #include <linux/init.h> | 12 | #include <linux/init.h> |
13 | #include <linux/linkage.h> | ||
14 | #include <asm/cache.h> | 14 | #include <asm/cache.h> |
15 | #include <asm/errno.h> | 15 | #include <asm/errno.h> |
16 | #include <asm/ptrace.h> | 16 | #include <asm/ptrace.h> |
@@ -197,8 +197,7 @@ STACK_SIZE = 1 << STACK_SHIFT | |||
197 | * Returns: | 197 | * Returns: |
198 | * gpr2 = prev | 198 | * gpr2 = prev |
199 | */ | 199 | */ |
200 | .globl __switch_to | 200 | ENTRY(__switch_to) |
201 | __switch_to: | ||
202 | basr %r1,0 | 201 | basr %r1,0 |
203 | 0: l %r4,__THREAD_info(%r2) # get thread_info of prev | 202 | 0: l %r4,__THREAD_info(%r2) # get thread_info of prev |
204 | l %r5,__THREAD_info(%r3) # get thread_info of next | 203 | l %r5,__THREAD_info(%r3) # get thread_info of next |
@@ -224,8 +223,7 @@ __critical_start: | |||
224 | * are executed with interrupts enabled. | 223 | * are executed with interrupts enabled. |
225 | */ | 224 | */ |
226 | 225 | ||
227 | .globl system_call | 226 | ENTRY(system_call) |
228 | system_call: | ||
229 | stpt __LC_SYNC_ENTER_TIMER | 227 | stpt __LC_SYNC_ENTER_TIMER |
230 | sysc_saveall: | 228 | sysc_saveall: |
231 | SAVE_ALL_SVC __LC_SVC_OLD_PSW,__LC_SAVE_AREA | 229 | SAVE_ALL_SVC __LC_SVC_OLD_PSW,__LC_SAVE_AREA |
@@ -388,8 +386,7 @@ sysc_tracenogo: | |||
388 | # | 386 | # |
389 | # a new process exits the kernel with ret_from_fork | 387 | # a new process exits the kernel with ret_from_fork |
390 | # | 388 | # |
391 | .globl ret_from_fork | 389 | ENTRY(ret_from_fork) |
392 | ret_from_fork: | ||
393 | l %r13,__LC_SVC_NEW_PSW+4 | 390 | l %r13,__LC_SVC_NEW_PSW+4 |
394 | l %r12,__LC_THREAD_INFO # load pointer to thread_info struct | 391 | l %r12,__LC_THREAD_INFO # load pointer to thread_info struct |
395 | tm SP_PSW+1(%r15),0x01 # forking a kernel thread ? | 392 | tm SP_PSW+1(%r15),0x01 # forking a kernel thread ? |
@@ -405,8 +402,7 @@ ret_from_fork: | |||
405 | # kernel_execve function needs to deal with pt_regs that is not | 402 | # kernel_execve function needs to deal with pt_regs that is not |
406 | # at the usual place | 403 | # at the usual place |
407 | # | 404 | # |
408 | .globl kernel_execve | 405 | ENTRY(kernel_execve) |
409 | kernel_execve: | ||
410 | stm %r12,%r15,48(%r15) | 406 | stm %r12,%r15,48(%r15) |
411 | lr %r14,%r15 | 407 | lr %r14,%r15 |
412 | l %r13,__LC_SVC_NEW_PSW+4 | 408 | l %r13,__LC_SVC_NEW_PSW+4 |
@@ -438,8 +434,7 @@ kernel_execve: | |||
438 | * Program check handler routine | 434 | * Program check handler routine |
439 | */ | 435 | */ |
440 | 436 | ||
441 | .globl pgm_check_handler | 437 | ENTRY(pgm_check_handler) |
442 | pgm_check_handler: | ||
443 | /* | 438 | /* |
444 | * First we need to check for a special case: | 439 | * First we need to check for a special case: |
445 | * Single stepping an instruction that disables the PER event mask will | 440 | * Single stepping an instruction that disables the PER event mask will |
@@ -565,8 +560,7 @@ kernel_per: | |||
565 | * IO interrupt handler routine | 560 | * IO interrupt handler routine |
566 | */ | 561 | */ |
567 | 562 | ||
568 | .globl io_int_handler | 563 | ENTRY(io_int_handler) |
569 | io_int_handler: | ||
570 | stck __LC_INT_CLOCK | 564 | stck __LC_INT_CLOCK |
571 | stpt __LC_ASYNC_ENTER_TIMER | 565 | stpt __LC_ASYNC_ENTER_TIMER |
572 | SAVE_ALL_ASYNC __LC_IO_OLD_PSW,__LC_SAVE_AREA+16 | 566 | SAVE_ALL_ASYNC __LC_IO_OLD_PSW,__LC_SAVE_AREA+16 |
@@ -703,8 +697,7 @@ io_notify_resume: | |||
703 | * External interrupt handler routine | 697 | * External interrupt handler routine |
704 | */ | 698 | */ |
705 | 699 | ||
706 | .globl ext_int_handler | 700 | ENTRY(ext_int_handler) |
707 | ext_int_handler: | ||
708 | stck __LC_INT_CLOCK | 701 | stck __LC_INT_CLOCK |
709 | stpt __LC_ASYNC_ENTER_TIMER | 702 | stpt __LC_ASYNC_ENTER_TIMER |
710 | SAVE_ALL_ASYNC __LC_EXT_OLD_PSW,__LC_SAVE_AREA+16 | 703 | SAVE_ALL_ASYNC __LC_EXT_OLD_PSW,__LC_SAVE_AREA+16 |
@@ -731,8 +724,7 @@ __critical_end: | |||
731 | * Machine check handler routines | 724 | * Machine check handler routines |
732 | */ | 725 | */ |
733 | 726 | ||
734 | .globl mcck_int_handler | 727 | ENTRY(mcck_int_handler) |
735 | mcck_int_handler: | ||
736 | stck __LC_MCCK_CLOCK | 728 | stck __LC_MCCK_CLOCK |
737 | spt __LC_CPU_TIMER_SAVE_AREA # revalidate cpu timer | 729 | spt __LC_CPU_TIMER_SAVE_AREA # revalidate cpu timer |
738 | lm %r0,%r15,__LC_GPREGS_SAVE_AREA # revalidate gprs | 730 | lm %r0,%r15,__LC_GPREGS_SAVE_AREA # revalidate gprs |
@@ -818,8 +810,7 @@ mcck_return: | |||
818 | */ | 810 | */ |
819 | #ifdef CONFIG_SMP | 811 | #ifdef CONFIG_SMP |
820 | __CPUINIT | 812 | __CPUINIT |
821 | .globl restart_int_handler | 813 | ENTRY(restart_int_handler) |
822 | restart_int_handler: | ||
823 | basr %r1,0 | 814 | basr %r1,0 |
824 | restart_base: | 815 | restart_base: |
825 | spt restart_vtime-restart_base(%r1) | 816 | spt restart_vtime-restart_base(%r1) |
@@ -848,8 +839,7 @@ restart_vtime: | |||
848 | /* | 839 | /* |
849 | * If we do not run with SMP enabled, let the new CPU crash ... | 840 | * If we do not run with SMP enabled, let the new CPU crash ... |
850 | */ | 841 | */ |
851 | .globl restart_int_handler | 842 | ENTRY(restart_int_handler) |
852 | restart_int_handler: | ||
853 | basr %r1,0 | 843 | basr %r1,0 |
854 | restart_base: | 844 | restart_base: |
855 | lpsw restart_crash-restart_base(%r1) | 845 | lpsw restart_crash-restart_base(%r1) |
diff --git a/arch/s390/kernel/entry.h b/arch/s390/kernel/entry.h index 17a6f83a2d67..66729eb7bbc5 100644 --- a/arch/s390/kernel/entry.h +++ b/arch/s390/kernel/entry.h | |||
@@ -5,10 +5,9 @@ | |||
5 | #include <linux/signal.h> | 5 | #include <linux/signal.h> |
6 | #include <asm/ptrace.h> | 6 | #include <asm/ptrace.h> |
7 | 7 | ||
8 | typedef void pgm_check_handler_t(struct pt_regs *, long, unsigned long); | 8 | void do_protection_exception(struct pt_regs *, long, unsigned long); |
9 | extern pgm_check_handler_t *pgm_check_table[128]; | 9 | void do_dat_exception(struct pt_regs *, long, unsigned long); |
10 | pgm_check_handler_t do_protection_exception; | 10 | void do_asce_exception(struct pt_regs *, long, unsigned long); |
11 | pgm_check_handler_t do_dat_exception; | ||
12 | 11 | ||
13 | extern int sysctl_userprocess_debug; | 12 | extern int sysctl_userprocess_debug; |
14 | 13 | ||
diff --git a/arch/s390/kernel/entry64.S b/arch/s390/kernel/entry64.S index d61967e2eab0..7a0fd426ca92 100644 --- a/arch/s390/kernel/entry64.S +++ b/arch/s390/kernel/entry64.S | |||
@@ -9,8 +9,8 @@ | |||
9 | * Heiko Carstens <heiko.carstens@de.ibm.com> | 9 | * Heiko Carstens <heiko.carstens@de.ibm.com> |
10 | */ | 10 | */ |
11 | 11 | ||
12 | #include <linux/linkage.h> | ||
13 | #include <linux/init.h> | 12 | #include <linux/init.h> |
13 | #include <linux/linkage.h> | ||
14 | #include <asm/cache.h> | 14 | #include <asm/cache.h> |
15 | #include <asm/errno.h> | 15 | #include <asm/errno.h> |
16 | #include <asm/ptrace.h> | 16 | #include <asm/ptrace.h> |
@@ -56,15 +56,28 @@ _TIF_WORK_INT = (_TIF_SIGPENDING | _TIF_NOTIFY_RESUME | _TIF_NEED_RESCHED | \ | |||
56 | _TIF_MCCK_PENDING) | 56 | _TIF_MCCK_PENDING) |
57 | _TIF_SYSCALL = (_TIF_SYSCALL_TRACE>>8 | _TIF_SYSCALL_AUDIT>>8 | \ | 57 | _TIF_SYSCALL = (_TIF_SYSCALL_TRACE>>8 | _TIF_SYSCALL_AUDIT>>8 | \ |
58 | _TIF_SECCOMP>>8 | _TIF_SYSCALL_TRACEPOINT>>8) | 58 | _TIF_SECCOMP>>8 | _TIF_SYSCALL_TRACEPOINT>>8) |
59 | _TIF_EXIT_SIE = (_TIF_SIGPENDING | _TIF_NEED_RESCHED | _TIF_MCCK_PENDING) | ||
59 | 60 | ||
60 | #define BASED(name) name-system_call(%r13) | 61 | #define BASED(name) name-system_call(%r13) |
61 | 62 | ||
63 | .macro SPP newpp | ||
64 | #if defined(CONFIG_KVM) || defined(CONFIG_KVM_MODULE) | ||
65 | tm __LC_MACHINE_FLAGS+6,0x20 # MACHINE_FLAG_SPP | ||
66 | jz .+8 | ||
67 | .insn s,0xb2800000,\newpp | ||
68 | #endif | ||
69 | .endm | ||
70 | |||
62 | .macro HANDLE_SIE_INTERCEPT | 71 | .macro HANDLE_SIE_INTERCEPT |
63 | #if defined(CONFIG_KVM) || defined(CONFIG_KVM_MODULE) | 72 | #if defined(CONFIG_KVM) || defined(CONFIG_KVM_MODULE) |
64 | lg %r3,__LC_SIE_HOOK | 73 | tm __TI_flags+6(%r12),_TIF_SIE>>8 |
65 | ltgr %r3,%r3 | ||
66 | jz 0f | 74 | jz 0f |
67 | basr %r14,%r3 | 75 | SPP __LC_CMF_HPP # set host id |
76 | clc SP_PSW+8(8,%r15),BASED(.Lsie_loop) | ||
77 | jl 0f | ||
78 | clc SP_PSW+8(8,%r15),BASED(.Lsie_done) | ||
79 | jhe 0f | ||
80 | mvc SP_PSW+8(8,%r15),BASED(.Lsie_loop) | ||
68 | 0: | 81 | 0: |
69 | #endif | 82 | #endif |
70 | .endm | 83 | .endm |
@@ -206,8 +219,7 @@ _TIF_SYSCALL = (_TIF_SYSCALL_TRACE>>8 | _TIF_SYSCALL_AUDIT>>8 | \ | |||
206 | * Returns: | 219 | * Returns: |
207 | * gpr2 = prev | 220 | * gpr2 = prev |
208 | */ | 221 | */ |
209 | .globl __switch_to | 222 | ENTRY(__switch_to) |
210 | __switch_to: | ||
211 | lg %r4,__THREAD_info(%r2) # get thread_info of prev | 223 | lg %r4,__THREAD_info(%r2) # get thread_info of prev |
212 | lg %r5,__THREAD_info(%r3) # get thread_info of next | 224 | lg %r5,__THREAD_info(%r3) # get thread_info of next |
213 | tm __TI_flags+7(%r4),_TIF_MCCK_PENDING # machine check pending? | 225 | tm __TI_flags+7(%r4),_TIF_MCCK_PENDING # machine check pending? |
@@ -232,8 +244,7 @@ __critical_start: | |||
232 | * are executed with interrupts enabled. | 244 | * are executed with interrupts enabled. |
233 | */ | 245 | */ |
234 | 246 | ||
235 | .globl system_call | 247 | ENTRY(system_call) |
236 | system_call: | ||
237 | stpt __LC_SYNC_ENTER_TIMER | 248 | stpt __LC_SYNC_ENTER_TIMER |
238 | sysc_saveall: | 249 | sysc_saveall: |
239 | SAVE_ALL_SVC __LC_SVC_OLD_PSW,__LC_SAVE_AREA | 250 | SAVE_ALL_SVC __LC_SVC_OLD_PSW,__LC_SAVE_AREA |
@@ -395,8 +406,7 @@ sysc_tracenogo: | |||
395 | # | 406 | # |
396 | # a new process exits the kernel with ret_from_fork | 407 | # a new process exits the kernel with ret_from_fork |
397 | # | 408 | # |
398 | .globl ret_from_fork | 409 | ENTRY(ret_from_fork) |
399 | ret_from_fork: | ||
400 | lg %r13,__LC_SVC_NEW_PSW+8 | 410 | lg %r13,__LC_SVC_NEW_PSW+8 |
401 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct | 411 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct |
402 | tm SP_PSW+1(%r15),0x01 # forking a kernel thread ? | 412 | tm SP_PSW+1(%r15),0x01 # forking a kernel thread ? |
@@ -411,8 +421,7 @@ ret_from_fork: | |||
411 | # kernel_execve function needs to deal with pt_regs that is not | 421 | # kernel_execve function needs to deal with pt_regs that is not |
412 | # at the usual place | 422 | # at the usual place |
413 | # | 423 | # |
414 | .globl kernel_execve | 424 | ENTRY(kernel_execve) |
415 | kernel_execve: | ||
416 | stmg %r12,%r15,96(%r15) | 425 | stmg %r12,%r15,96(%r15) |
417 | lgr %r14,%r15 | 426 | lgr %r14,%r15 |
418 | aghi %r15,-SP_SIZE | 427 | aghi %r15,-SP_SIZE |
@@ -442,8 +451,7 @@ kernel_execve: | |||
442 | * Program check handler routine | 451 | * Program check handler routine |
443 | */ | 452 | */ |
444 | 453 | ||
445 | .globl pgm_check_handler | 454 | ENTRY(pgm_check_handler) |
446 | pgm_check_handler: | ||
447 | /* | 455 | /* |
448 | * First we need to check for a special case: | 456 | * First we need to check for a special case: |
449 | * Single stepping an instruction that disables the PER event mask will | 457 | * Single stepping an instruction that disables the PER event mask will |
@@ -465,6 +473,7 @@ pgm_check_handler: | |||
465 | xc SP_ILC(4,%r15),SP_ILC(%r15) | 473 | xc SP_ILC(4,%r15),SP_ILC(%r15) |
466 | mvc SP_PSW(16,%r15),__LC_PGM_OLD_PSW | 474 | mvc SP_PSW(16,%r15),__LC_PGM_OLD_PSW |
467 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct | 475 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct |
476 | HANDLE_SIE_INTERCEPT | ||
468 | tm SP_PSW+1(%r15),0x01 # interrupting from user ? | 477 | tm SP_PSW+1(%r15),0x01 # interrupting from user ? |
469 | jz pgm_no_vtime | 478 | jz pgm_no_vtime |
470 | UPDATE_VTIME __LC_EXIT_TIMER,__LC_SYNC_ENTER_TIMER,__LC_USER_TIMER | 479 | UPDATE_VTIME __LC_EXIT_TIMER,__LC_SYNC_ENTER_TIMER,__LC_USER_TIMER |
@@ -472,7 +481,6 @@ pgm_check_handler: | |||
472 | mvc __LC_LAST_UPDATE_TIMER(8),__LC_SYNC_ENTER_TIMER | 481 | mvc __LC_LAST_UPDATE_TIMER(8),__LC_SYNC_ENTER_TIMER |
473 | LAST_BREAK | 482 | LAST_BREAK |
474 | pgm_no_vtime: | 483 | pgm_no_vtime: |
475 | HANDLE_SIE_INTERCEPT | ||
476 | stg %r11,SP_ARGS(%r15) | 484 | stg %r11,SP_ARGS(%r15) |
477 | lgf %r3,__LC_PGM_ILC # load program interruption code | 485 | lgf %r3,__LC_PGM_ILC # load program interruption code |
478 | lg %r4,__LC_TRANS_EXC_CODE | 486 | lg %r4,__LC_TRANS_EXC_CODE |
@@ -507,6 +515,7 @@ pgm_per_std: | |||
507 | CREATE_STACK_FRAME __LC_SAVE_AREA | 515 | CREATE_STACK_FRAME __LC_SAVE_AREA |
508 | mvc SP_PSW(16,%r15),__LC_PGM_OLD_PSW | 516 | mvc SP_PSW(16,%r15),__LC_PGM_OLD_PSW |
509 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct | 517 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct |
518 | HANDLE_SIE_INTERCEPT | ||
510 | tm SP_PSW+1(%r15),0x01 # interrupting from user ? | 519 | tm SP_PSW+1(%r15),0x01 # interrupting from user ? |
511 | jz pgm_no_vtime2 | 520 | jz pgm_no_vtime2 |
512 | UPDATE_VTIME __LC_EXIT_TIMER,__LC_SYNC_ENTER_TIMER,__LC_USER_TIMER | 521 | UPDATE_VTIME __LC_EXIT_TIMER,__LC_SYNC_ENTER_TIMER,__LC_USER_TIMER |
@@ -514,7 +523,6 @@ pgm_per_std: | |||
514 | mvc __LC_LAST_UPDATE_TIMER(8),__LC_SYNC_ENTER_TIMER | 523 | mvc __LC_LAST_UPDATE_TIMER(8),__LC_SYNC_ENTER_TIMER |
515 | LAST_BREAK | 524 | LAST_BREAK |
516 | pgm_no_vtime2: | 525 | pgm_no_vtime2: |
517 | HANDLE_SIE_INTERCEPT | ||
518 | lg %r1,__TI_task(%r12) | 526 | lg %r1,__TI_task(%r12) |
519 | tm SP_PSW+1(%r15),0x01 # kernel per event ? | 527 | tm SP_PSW+1(%r15),0x01 # kernel per event ? |
520 | jz kernel_per | 528 | jz kernel_per |
@@ -571,14 +579,14 @@ kernel_per: | |||
571 | /* | 579 | /* |
572 | * IO interrupt handler routine | 580 | * IO interrupt handler routine |
573 | */ | 581 | */ |
574 | .globl io_int_handler | 582 | ENTRY(io_int_handler) |
575 | io_int_handler: | ||
576 | stck __LC_INT_CLOCK | 583 | stck __LC_INT_CLOCK |
577 | stpt __LC_ASYNC_ENTER_TIMER | 584 | stpt __LC_ASYNC_ENTER_TIMER |
578 | SAVE_ALL_ASYNC __LC_IO_OLD_PSW,__LC_SAVE_AREA+40 | 585 | SAVE_ALL_ASYNC __LC_IO_OLD_PSW,__LC_SAVE_AREA+40 |
579 | CREATE_STACK_FRAME __LC_SAVE_AREA+40 | 586 | CREATE_STACK_FRAME __LC_SAVE_AREA+40 |
580 | mvc SP_PSW(16,%r15),0(%r12) # move user PSW to stack | 587 | mvc SP_PSW(16,%r15),0(%r12) # move user PSW to stack |
581 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct | 588 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct |
589 | HANDLE_SIE_INTERCEPT | ||
582 | tm SP_PSW+1(%r15),0x01 # interrupting from user ? | 590 | tm SP_PSW+1(%r15),0x01 # interrupting from user ? |
583 | jz io_no_vtime | 591 | jz io_no_vtime |
584 | UPDATE_VTIME __LC_EXIT_TIMER,__LC_ASYNC_ENTER_TIMER,__LC_USER_TIMER | 592 | UPDATE_VTIME __LC_EXIT_TIMER,__LC_ASYNC_ENTER_TIMER,__LC_USER_TIMER |
@@ -586,7 +594,6 @@ io_int_handler: | |||
586 | mvc __LC_LAST_UPDATE_TIMER(8),__LC_ASYNC_ENTER_TIMER | 594 | mvc __LC_LAST_UPDATE_TIMER(8),__LC_ASYNC_ENTER_TIMER |
587 | LAST_BREAK | 595 | LAST_BREAK |
588 | io_no_vtime: | 596 | io_no_vtime: |
589 | HANDLE_SIE_INTERCEPT | ||
590 | TRACE_IRQS_OFF | 597 | TRACE_IRQS_OFF |
591 | la %r2,SP_PTREGS(%r15) # address of register-save area | 598 | la %r2,SP_PTREGS(%r15) # address of register-save area |
592 | brasl %r14,do_IRQ # call standard irq handler | 599 | brasl %r14,do_IRQ # call standard irq handler |
@@ -706,14 +713,14 @@ io_notify_resume: | |||
706 | /* | 713 | /* |
707 | * External interrupt handler routine | 714 | * External interrupt handler routine |
708 | */ | 715 | */ |
709 | .globl ext_int_handler | 716 | ENTRY(ext_int_handler) |
710 | ext_int_handler: | ||
711 | stck __LC_INT_CLOCK | 717 | stck __LC_INT_CLOCK |
712 | stpt __LC_ASYNC_ENTER_TIMER | 718 | stpt __LC_ASYNC_ENTER_TIMER |
713 | SAVE_ALL_ASYNC __LC_EXT_OLD_PSW,__LC_SAVE_AREA+40 | 719 | SAVE_ALL_ASYNC __LC_EXT_OLD_PSW,__LC_SAVE_AREA+40 |
714 | CREATE_STACK_FRAME __LC_SAVE_AREA+40 | 720 | CREATE_STACK_FRAME __LC_SAVE_AREA+40 |
715 | mvc SP_PSW(16,%r15),0(%r12) # move user PSW to stack | 721 | mvc SP_PSW(16,%r15),0(%r12) # move user PSW to stack |
716 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct | 722 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct |
723 | HANDLE_SIE_INTERCEPT | ||
717 | tm SP_PSW+1(%r15),0x01 # interrupting from user ? | 724 | tm SP_PSW+1(%r15),0x01 # interrupting from user ? |
718 | jz ext_no_vtime | 725 | jz ext_no_vtime |
719 | UPDATE_VTIME __LC_EXIT_TIMER,__LC_ASYNC_ENTER_TIMER,__LC_USER_TIMER | 726 | UPDATE_VTIME __LC_EXIT_TIMER,__LC_ASYNC_ENTER_TIMER,__LC_USER_TIMER |
@@ -721,7 +728,6 @@ ext_int_handler: | |||
721 | mvc __LC_LAST_UPDATE_TIMER(8),__LC_ASYNC_ENTER_TIMER | 728 | mvc __LC_LAST_UPDATE_TIMER(8),__LC_ASYNC_ENTER_TIMER |
722 | LAST_BREAK | 729 | LAST_BREAK |
723 | ext_no_vtime: | 730 | ext_no_vtime: |
724 | HANDLE_SIE_INTERCEPT | ||
725 | TRACE_IRQS_OFF | 731 | TRACE_IRQS_OFF |
726 | lghi %r1,4096 | 732 | lghi %r1,4096 |
727 | la %r2,SP_PTREGS(%r15) # address of register-save area | 733 | la %r2,SP_PTREGS(%r15) # address of register-save area |
@@ -736,8 +742,7 @@ __critical_end: | |||
736 | /* | 742 | /* |
737 | * Machine check handler routines | 743 | * Machine check handler routines |
738 | */ | 744 | */ |
739 | .globl mcck_int_handler | 745 | ENTRY(mcck_int_handler) |
740 | mcck_int_handler: | ||
741 | stck __LC_MCCK_CLOCK | 746 | stck __LC_MCCK_CLOCK |
742 | la %r1,4095 # revalidate r1 | 747 | la %r1,4095 # revalidate r1 |
743 | spt __LC_CPU_TIMER_SAVE_AREA-4095(%r1) # revalidate cpu timer | 748 | spt __LC_CPU_TIMER_SAVE_AREA-4095(%r1) # revalidate cpu timer |
@@ -785,6 +790,7 @@ mcck_int_main: | |||
785 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct | 790 | lg %r12,__LC_THREAD_INFO # load pointer to thread_info struct |
786 | tm __LC_MCCK_CODE+2,0x08 # mwp of old psw valid? | 791 | tm __LC_MCCK_CODE+2,0x08 # mwp of old psw valid? |
787 | jno mcck_no_vtime # no -> no timer update | 792 | jno mcck_no_vtime # no -> no timer update |
793 | HANDLE_SIE_INTERCEPT | ||
788 | tm SP_PSW+1(%r15),0x01 # interrupting from user ? | 794 | tm SP_PSW+1(%r15),0x01 # interrupting from user ? |
789 | jz mcck_no_vtime | 795 | jz mcck_no_vtime |
790 | UPDATE_VTIME __LC_EXIT_TIMER,__LC_MCCK_ENTER_TIMER,__LC_USER_TIMER | 796 | UPDATE_VTIME __LC_EXIT_TIMER,__LC_MCCK_ENTER_TIMER,__LC_USER_TIMER |
@@ -804,7 +810,6 @@ mcck_no_vtime: | |||
804 | stosm __SF_EMPTY(%r15),0x04 # turn dat on | 810 | stosm __SF_EMPTY(%r15),0x04 # turn dat on |
805 | tm __TI_flags+7(%r12),_TIF_MCCK_PENDING | 811 | tm __TI_flags+7(%r12),_TIF_MCCK_PENDING |
806 | jno mcck_return | 812 | jno mcck_return |
807 | HANDLE_SIE_INTERCEPT | ||
808 | TRACE_IRQS_OFF | 813 | TRACE_IRQS_OFF |
809 | brasl %r14,s390_handle_mcck | 814 | brasl %r14,s390_handle_mcck |
810 | TRACE_IRQS_ON | 815 | TRACE_IRQS_ON |
@@ -823,8 +828,7 @@ mcck_done: | |||
823 | */ | 828 | */ |
824 | #ifdef CONFIG_SMP | 829 | #ifdef CONFIG_SMP |
825 | __CPUINIT | 830 | __CPUINIT |
826 | .globl restart_int_handler | 831 | ENTRY(restart_int_handler) |
827 | restart_int_handler: | ||
828 | basr %r1,0 | 832 | basr %r1,0 |
829 | restart_base: | 833 | restart_base: |
830 | spt restart_vtime-restart_base(%r1) | 834 | spt restart_vtime-restart_base(%r1) |
@@ -851,8 +855,7 @@ restart_vtime: | |||
851 | /* | 855 | /* |
852 | * If we do not run with SMP enabled, let the new CPU crash ... | 856 | * If we do not run with SMP enabled, let the new CPU crash ... |
853 | */ | 857 | */ |
854 | .globl restart_int_handler | 858 | ENTRY(restart_int_handler) |
855 | restart_int_handler: | ||
856 | basr %r1,0 | 859 | basr %r1,0 |
857 | restart_base: | 860 | restart_base: |
858 | lpswe restart_crash-restart_base(%r1) | 861 | lpswe restart_crash-restart_base(%r1) |
@@ -1036,6 +1039,56 @@ cleanup_io_restore_insn: | |||
1036 | .Lcritical_end: | 1039 | .Lcritical_end: |
1037 | .quad __critical_end | 1040 | .quad __critical_end |
1038 | 1041 | ||
1042 | #if defined(CONFIG_KVM) || defined(CONFIG_KVM_MODULE) | ||
1043 | /* | ||
1044 | * sie64a calling convention: | ||
1045 | * %r2 pointer to sie control block | ||
1046 | * %r3 guest register save area | ||
1047 | */ | ||
1048 | ENTRY(sie64a) | ||
1049 | stmg %r6,%r14,__SF_GPRS(%r15) # save kernel registers | ||
1050 | stg %r2,__SF_EMPTY(%r15) # save control block pointer | ||
1051 | stg %r3,__SF_EMPTY+8(%r15) # save guest register save area | ||
1052 | lmg %r0,%r13,0(%r3) # load guest gprs 0-13 | ||
1053 | lg %r14,__LC_THREAD_INFO # pointer thread_info struct | ||
1054 | oi __TI_flags+6(%r14),_TIF_SIE>>8 | ||
1055 | sie_loop: | ||
1056 | lg %r14,__LC_THREAD_INFO # pointer thread_info struct | ||
1057 | tm __TI_flags+7(%r14),_TIF_EXIT_SIE | ||
1058 | jnz sie_exit | ||
1059 | lg %r14,__SF_EMPTY(%r15) # get control block pointer | ||
1060 | SPP __SF_EMPTY(%r15) # set guest id | ||
1061 | sie 0(%r14) | ||
1062 | sie_done: | ||
1063 | SPP __LC_CMF_HPP # set host id | ||
1064 | lg %r14,__LC_THREAD_INFO # pointer thread_info struct | ||
1065 | sie_exit: | ||
1066 | ni __TI_flags+6(%r14),255-(_TIF_SIE>>8) | ||
1067 | lg %r14,__SF_EMPTY+8(%r15) # load guest register save area | ||
1068 | stmg %r0,%r13,0(%r14) # save guest gprs 0-13 | ||
1069 | lmg %r6,%r14,__SF_GPRS(%r15) # restore kernel registers | ||
1070 | lghi %r2,0 | ||
1071 | br %r14 | ||
1072 | sie_fault: | ||
1073 | lg %r14,__LC_THREAD_INFO # pointer thread_info struct | ||
1074 | ni __TI_flags+6(%r14),255-(_TIF_SIE>>8) | ||
1075 | lg %r14,__SF_EMPTY+8(%r15) # load guest register save area | ||
1076 | stmg %r0,%r13,0(%r14) # save guest gprs 0-13 | ||
1077 | lmg %r6,%r14,__SF_GPRS(%r15) # restore kernel registers | ||
1078 | lghi %r2,-EFAULT | ||
1079 | br %r14 | ||
1080 | |||
1081 | .align 8 | ||
1082 | .Lsie_loop: | ||
1083 | .quad sie_loop | ||
1084 | .Lsie_done: | ||
1085 | .quad sie_done | ||
1086 | |||
1087 | .section __ex_table,"a" | ||
1088 | .quad sie_loop,sie_fault | ||
1089 | .previous | ||
1090 | #endif | ||
1091 | |||
1039 | .section .rodata, "a" | 1092 | .section .rodata, "a" |
1040 | #define SYSCALL(esa,esame,emu) .long esame | 1093 | #define SYSCALL(esa,esame,emu) .long esame |
1041 | .globl sys_call_table | 1094 | .globl sys_call_table |
diff --git a/arch/s390/kernel/head.S b/arch/s390/kernel/head.S index fb317bf2c378..2d781bab37bb 100644 --- a/arch/s390/kernel/head.S +++ b/arch/s390/kernel/head.S | |||
@@ -22,6 +22,7 @@ | |||
22 | */ | 22 | */ |
23 | 23 | ||
24 | #include <linux/init.h> | 24 | #include <linux/init.h> |
25 | #include <linux/linkage.h> | ||
25 | #include <asm/asm-offsets.h> | 26 | #include <asm/asm-offsets.h> |
26 | #include <asm/thread_info.h> | 27 | #include <asm/thread_info.h> |
27 | #include <asm/page.h> | 28 | #include <asm/page.h> |
@@ -383,8 +384,7 @@ iplstart: | |||
383 | # doesn't need a builtin ipl record. | 384 | # doesn't need a builtin ipl record. |
384 | # | 385 | # |
385 | .org 0x800 | 386 | .org 0x800 |
386 | .globl start | 387 | ENTRY(start) |
387 | start: | ||
388 | stm %r0,%r15,0x07b0 # store registers | 388 | stm %r0,%r15,0x07b0 # store registers |
389 | basr %r12,%r0 | 389 | basr %r12,%r0 |
390 | .base: | 390 | .base: |
@@ -448,8 +448,7 @@ start: | |||
448 | # or linload or SALIPL | 448 | # or linload or SALIPL |
449 | # | 449 | # |
450 | .org 0x10000 | 450 | .org 0x10000 |
451 | .globl startup | 451 | ENTRY(startup) |
452 | startup: | ||
453 | basr %r13,0 # get base | 452 | basr %r13,0 # get base |
454 | .LPG0: | 453 | .LPG0: |
455 | xc 0x200(256),0x200 # partially clear lowcore | 454 | xc 0x200(256),0x200 # partially clear lowcore |
diff --git a/arch/s390/kernel/head31.S b/arch/s390/kernel/head31.S index b8f8dc126102..f21954b44dc1 100644 --- a/arch/s390/kernel/head31.S +++ b/arch/s390/kernel/head31.S | |||
@@ -11,13 +11,13 @@ | |||
11 | */ | 11 | */ |
12 | 12 | ||
13 | #include <linux/init.h> | 13 | #include <linux/init.h> |
14 | #include <linux/linkage.h> | ||
14 | #include <asm/asm-offsets.h> | 15 | #include <asm/asm-offsets.h> |
15 | #include <asm/thread_info.h> | 16 | #include <asm/thread_info.h> |
16 | #include <asm/page.h> | 17 | #include <asm/page.h> |
17 | 18 | ||
18 | __HEAD | 19 | __HEAD |
19 | .globl startup_continue | 20 | ENTRY(startup_continue) |
20 | startup_continue: | ||
21 | basr %r13,0 # get base | 21 | basr %r13,0 # get base |
22 | .LPG1: | 22 | .LPG1: |
23 | 23 | ||
@@ -45,7 +45,7 @@ startup_continue: | |||
45 | # virtual and never return ... | 45 | # virtual and never return ... |
46 | .align 8 | 46 | .align 8 |
47 | .Lentry:.long 0x00080000,0x80000000 + _stext | 47 | .Lentry:.long 0x00080000,0x80000000 + _stext |
48 | .Lctl: .long 0x04b50002 # cr0: various things | 48 | .Lctl: .long 0x04b50000 # cr0: various things |
49 | .long 0 # cr1: primary space segment table | 49 | .long 0 # cr1: primary space segment table |
50 | .long .Lduct # cr2: dispatchable unit control table | 50 | .long .Lduct # cr2: dispatchable unit control table |
51 | .long 0 # cr3: instruction authorization | 51 | .long 0 # cr3: instruction authorization |
@@ -78,8 +78,7 @@ startup_continue: | |||
78 | .Lbase_cc: | 78 | .Lbase_cc: |
79 | .long sched_clock_base_cc | 79 | .long sched_clock_base_cc |
80 | 80 | ||
81 | .globl _ehead | 81 | ENTRY(_ehead) |
82 | _ehead: | ||
83 | 82 | ||
84 | #ifdef CONFIG_SHARED_KERNEL | 83 | #ifdef CONFIG_SHARED_KERNEL |
85 | .org 0x100000 - 0x11000 # head.o ends at 0x11000 | 84 | .org 0x100000 - 0x11000 # head.o ends at 0x11000 |
@@ -88,8 +87,8 @@ _ehead: | |||
88 | # | 87 | # |
89 | # startup-code, running in absolute addressing mode | 88 | # startup-code, running in absolute addressing mode |
90 | # | 89 | # |
91 | .globl _stext | 90 | ENTRY(_stext) |
92 | _stext: basr %r13,0 # get base | 91 | basr %r13,0 # get base |
93 | .LPG3: | 92 | .LPG3: |
94 | # check control registers | 93 | # check control registers |
95 | stctl %c0,%c15,0(%r15) | 94 | stctl %c0,%c15,0(%r15) |
diff --git a/arch/s390/kernel/head64.S b/arch/s390/kernel/head64.S index cdef68717416..ae5d492b069e 100644 --- a/arch/s390/kernel/head64.S +++ b/arch/s390/kernel/head64.S | |||
@@ -11,13 +11,13 @@ | |||
11 | */ | 11 | */ |
12 | 12 | ||
13 | #include <linux/init.h> | 13 | #include <linux/init.h> |
14 | #include <linux/linkage.h> | ||
14 | #include <asm/asm-offsets.h> | 15 | #include <asm/asm-offsets.h> |
15 | #include <asm/thread_info.h> | 16 | #include <asm/thread_info.h> |
16 | #include <asm/page.h> | 17 | #include <asm/page.h> |
17 | 18 | ||
18 | __HEAD | 19 | __HEAD |
19 | .globl startup_continue | 20 | ENTRY(startup_continue) |
20 | startup_continue: | ||
21 | larl %r1,sched_clock_base_cc | 21 | larl %r1,sched_clock_base_cc |
22 | mvc 0(8,%r1),__LC_LAST_UPDATE_CLOCK | 22 | mvc 0(8,%r1),__LC_LAST_UPDATE_CLOCK |
23 | larl %r13,.LPG1 # get base | 23 | larl %r13,.LPG1 # get base |
@@ -46,7 +46,7 @@ startup_continue: | |||
46 | .align 16 | 46 | .align 16 |
47 | .LPG1: | 47 | .LPG1: |
48 | .Lentry:.quad 0x0000000180000000,_stext | 48 | .Lentry:.quad 0x0000000180000000,_stext |
49 | .Lctl: .quad 0x04350002 # cr0: various things | 49 | .Lctl: .quad 0x04040000 # cr0: AFP registers & secondary space |
50 | .quad 0 # cr1: primary space segment table | 50 | .quad 0 # cr1: primary space segment table |
51 | .quad .Lduct # cr2: dispatchable unit control table | 51 | .quad .Lduct # cr2: dispatchable unit control table |
52 | .quad 0 # cr3: instruction authorization | 52 | .quad 0 # cr3: instruction authorization |
@@ -76,8 +76,7 @@ startup_continue: | |||
76 | .long 0x80000000,0,0,0 # invalid access-list entries | 76 | .long 0x80000000,0,0,0 # invalid access-list entries |
77 | .endr | 77 | .endr |
78 | 78 | ||
79 | .globl _ehead | 79 | ENTRY(_ehead) |
80 | _ehead: | ||
81 | 80 | ||
82 | #ifdef CONFIG_SHARED_KERNEL | 81 | #ifdef CONFIG_SHARED_KERNEL |
83 | .org 0x100000 - 0x11000 # head.o ends at 0x11000 | 82 | .org 0x100000 - 0x11000 # head.o ends at 0x11000 |
@@ -86,8 +85,8 @@ _ehead: | |||
86 | # | 85 | # |
87 | # startup-code, running in absolute addressing mode | 86 | # startup-code, running in absolute addressing mode |
88 | # | 87 | # |
89 | .globl _stext | 88 | ENTRY(_stext) |
90 | _stext: basr %r13,0 # get base | 89 | basr %r13,0 # get base |
91 | .LPG3: | 90 | .LPG3: |
92 | # check control registers | 91 | # check control registers |
93 | stctg %c0,%c15,0(%r15) | 92 | stctg %c0,%c15,0(%r15) |
diff --git a/arch/s390/kernel/irq.c b/arch/s390/kernel/irq.c index e3264f6a9720..1f4050d45f78 100644 --- a/arch/s390/kernel/irq.c +++ b/arch/s390/kernel/irq.c | |||
@@ -88,15 +88,6 @@ int show_interrupts(struct seq_file *p, void *v) | |||
88 | } | 88 | } |
89 | 89 | ||
90 | /* | 90 | /* |
91 | * For compatibilty only. S/390 specific setup of interrupts et al. is done | ||
92 | * much later in init_channel_subsystem(). | ||
93 | */ | ||
94 | void __init init_IRQ(void) | ||
95 | { | ||
96 | /* nothing... */ | ||
97 | } | ||
98 | |||
99 | /* | ||
100 | * Switch to the asynchronous interrupt stack for softirq execution. | 91 | * Switch to the asynchronous interrupt stack for softirq execution. |
101 | */ | 92 | */ |
102 | asmlinkage void do_softirq(void) | 93 | asmlinkage void do_softirq(void) |
@@ -144,28 +135,45 @@ void init_irq_proc(void) | |||
144 | #endif | 135 | #endif |
145 | 136 | ||
146 | /* | 137 | /* |
147 | * ext_int_hash[index] is the start of the list for all external interrupts | 138 | * ext_int_hash[index] is the list head for all external interrupts that hash |
148 | * that hash to this index. With the current set of external interrupts | 139 | * to this index. |
149 | * (0x1202 external call, 0x1004 cpu timer, 0x2401 hwc console, 0x4000 | ||
150 | * iucv and 0x2603 pfault) this is always the first element. | ||
151 | */ | 140 | */ |
141 | static struct list_head ext_int_hash[256]; | ||
152 | 142 | ||
153 | struct ext_int_info { | 143 | struct ext_int_info { |
154 | struct ext_int_info *next; | ||
155 | ext_int_handler_t handler; | 144 | ext_int_handler_t handler; |
156 | u16 code; | 145 | u16 code; |
146 | struct list_head entry; | ||
147 | struct rcu_head rcu; | ||
157 | }; | 148 | }; |
158 | 149 | ||
159 | static struct ext_int_info *ext_int_hash[256]; | 150 | /* ext_int_hash_lock protects the handler lists for external interrupts */ |
151 | DEFINE_SPINLOCK(ext_int_hash_lock); | ||
152 | |||
153 | static void __init init_external_interrupts(void) | ||
154 | { | ||
155 | int idx; | ||
156 | |||
157 | for (idx = 0; idx < ARRAY_SIZE(ext_int_hash); idx++) | ||
158 | INIT_LIST_HEAD(&ext_int_hash[idx]); | ||
159 | } | ||
160 | 160 | ||
161 | static inline int ext_hash(u16 code) | 161 | static inline int ext_hash(u16 code) |
162 | { | 162 | { |
163 | return (code + (code >> 9)) & 0xff; | 163 | return (code + (code >> 9)) & 0xff; |
164 | } | 164 | } |
165 | 165 | ||
166 | static void ext_int_hash_update(struct rcu_head *head) | ||
167 | { | ||
168 | struct ext_int_info *p = container_of(head, struct ext_int_info, rcu); | ||
169 | |||
170 | kfree(p); | ||
171 | } | ||
172 | |||
166 | int register_external_interrupt(u16 code, ext_int_handler_t handler) | 173 | int register_external_interrupt(u16 code, ext_int_handler_t handler) |
167 | { | 174 | { |
168 | struct ext_int_info *p; | 175 | struct ext_int_info *p; |
176 | unsigned long flags; | ||
169 | int index; | 177 | int index; |
170 | 178 | ||
171 | p = kmalloc(sizeof(*p), GFP_ATOMIC); | 179 | p = kmalloc(sizeof(*p), GFP_ATOMIC); |
@@ -174,33 +182,27 @@ int register_external_interrupt(u16 code, ext_int_handler_t handler) | |||
174 | p->code = code; | 182 | p->code = code; |
175 | p->handler = handler; | 183 | p->handler = handler; |
176 | index = ext_hash(code); | 184 | index = ext_hash(code); |
177 | p->next = ext_int_hash[index]; | 185 | |
178 | ext_int_hash[index] = p; | 186 | spin_lock_irqsave(&ext_int_hash_lock, flags); |
187 | list_add_rcu(&p->entry, &ext_int_hash[index]); | ||
188 | spin_unlock_irqrestore(&ext_int_hash_lock, flags); | ||
179 | return 0; | 189 | return 0; |
180 | } | 190 | } |
181 | EXPORT_SYMBOL(register_external_interrupt); | 191 | EXPORT_SYMBOL(register_external_interrupt); |
182 | 192 | ||
183 | int unregister_external_interrupt(u16 code, ext_int_handler_t handler) | 193 | int unregister_external_interrupt(u16 code, ext_int_handler_t handler) |
184 | { | 194 | { |
185 | struct ext_int_info *p, *q; | 195 | struct ext_int_info *p; |
186 | int index; | 196 | unsigned long flags; |
197 | int index = ext_hash(code); | ||
187 | 198 | ||
188 | index = ext_hash(code); | 199 | spin_lock_irqsave(&ext_int_hash_lock, flags); |
189 | q = NULL; | 200 | list_for_each_entry_rcu(p, &ext_int_hash[index], entry) |
190 | p = ext_int_hash[index]; | 201 | if (p->code == code && p->handler == handler) { |
191 | while (p) { | 202 | list_del_rcu(&p->entry); |
192 | if (p->code == code && p->handler == handler) | 203 | call_rcu(&p->rcu, ext_int_hash_update); |
193 | break; | 204 | } |
194 | q = p; | 205 | spin_unlock_irqrestore(&ext_int_hash_lock, flags); |
195 | p = p->next; | ||
196 | } | ||
197 | if (!p) | ||
198 | return -ENOENT; | ||
199 | if (q) | ||
200 | q->next = p->next; | ||
201 | else | ||
202 | ext_int_hash[index] = p->next; | ||
203 | kfree(p); | ||
204 | return 0; | 206 | return 0; |
205 | } | 207 | } |
206 | EXPORT_SYMBOL(unregister_external_interrupt); | 208 | EXPORT_SYMBOL(unregister_external_interrupt); |
@@ -224,15 +226,22 @@ void __irq_entry do_extint(struct pt_regs *regs, unsigned int ext_int_code, | |||
224 | kstat_cpu(smp_processor_id()).irqs[EXTERNAL_INTERRUPT]++; | 226 | kstat_cpu(smp_processor_id()).irqs[EXTERNAL_INTERRUPT]++; |
225 | if (code != 0x1004) | 227 | if (code != 0x1004) |
226 | __get_cpu_var(s390_idle).nohz_delay = 1; | 228 | __get_cpu_var(s390_idle).nohz_delay = 1; |
229 | |||
227 | index = ext_hash(code); | 230 | index = ext_hash(code); |
228 | for (p = ext_int_hash[index]; p; p = p->next) { | 231 | rcu_read_lock(); |
232 | list_for_each_entry_rcu(p, &ext_int_hash[index], entry) | ||
229 | if (likely(p->code == code)) | 233 | if (likely(p->code == code)) |
230 | p->handler(ext_int_code, param32, param64); | 234 | p->handler(ext_int_code, param32, param64); |
231 | } | 235 | rcu_read_unlock(); |
232 | irq_exit(); | 236 | irq_exit(); |
233 | set_irq_regs(old_regs); | 237 | set_irq_regs(old_regs); |
234 | } | 238 | } |
235 | 239 | ||
240 | void __init init_IRQ(void) | ||
241 | { | ||
242 | init_external_interrupts(); | ||
243 | } | ||
244 | |||
236 | static DEFINE_SPINLOCK(sc_irq_lock); | 245 | static DEFINE_SPINLOCK(sc_irq_lock); |
237 | static int sc_irq_refcount; | 246 | static int sc_irq_refcount; |
238 | 247 | ||
diff --git a/arch/s390/kernel/mcount.S b/arch/s390/kernel/mcount.S index 1e6a55795628..7e2c38ba1373 100644 --- a/arch/s390/kernel/mcount.S +++ b/arch/s390/kernel/mcount.S | |||
@@ -5,21 +5,19 @@ | |||
5 | * | 5 | * |
6 | */ | 6 | */ |
7 | 7 | ||
8 | #include <linux/linkage.h> | ||
8 | #include <asm/asm-offsets.h> | 9 | #include <asm/asm-offsets.h> |
9 | 10 | ||
10 | .section .kprobes.text, "ax" | 11 | .section .kprobes.text, "ax" |
11 | 12 | ||
12 | .globl ftrace_stub | 13 | ENTRY(ftrace_stub) |
13 | ftrace_stub: | ||
14 | br %r14 | 14 | br %r14 |
15 | 15 | ||
16 | .globl _mcount | 16 | ENTRY(_mcount) |
17 | _mcount: | ||
18 | #ifdef CONFIG_DYNAMIC_FTRACE | 17 | #ifdef CONFIG_DYNAMIC_FTRACE |
19 | br %r14 | 18 | br %r14 |
20 | 19 | ||
21 | .globl ftrace_caller | 20 | ENTRY(ftrace_caller) |
22 | ftrace_caller: | ||
23 | #endif | 21 | #endif |
24 | stm %r2,%r5,16(%r15) | 22 | stm %r2,%r5,16(%r15) |
25 | bras %r1,2f | 23 | bras %r1,2f |
@@ -41,8 +39,7 @@ ftrace_caller: | |||
41 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | 39 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER |
42 | l %r2,100(%r15) | 40 | l %r2,100(%r15) |
43 | l %r3,152(%r15) | 41 | l %r3,152(%r15) |
44 | .globl ftrace_graph_caller | 42 | ENTRY(ftrace_graph_caller) |
45 | ftrace_graph_caller: | ||
46 | # The bras instruction gets runtime patched to call prepare_ftrace_return. | 43 | # The bras instruction gets runtime patched to call prepare_ftrace_return. |
47 | # See ftrace_enable_ftrace_graph_caller. The patched instruction is: | 44 | # See ftrace_enable_ftrace_graph_caller. The patched instruction is: |
48 | # bras %r14,prepare_ftrace_return | 45 | # bras %r14,prepare_ftrace_return |
@@ -56,8 +53,7 @@ ftrace_graph_caller: | |||
56 | 53 | ||
57 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | 54 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER |
58 | 55 | ||
59 | .globl return_to_handler | 56 | ENTRY(return_to_handler) |
60 | return_to_handler: | ||
61 | stm %r2,%r5,16(%r15) | 57 | stm %r2,%r5,16(%r15) |
62 | st %r14,56(%r15) | 58 | st %r14,56(%r15) |
63 | lr %r0,%r15 | 59 | lr %r0,%r15 |
diff --git a/arch/s390/kernel/mcount64.S b/arch/s390/kernel/mcount64.S index e73667286ac0..f70cadec68fc 100644 --- a/arch/s390/kernel/mcount64.S +++ b/arch/s390/kernel/mcount64.S | |||
@@ -5,21 +5,19 @@ | |||
5 | * | 5 | * |
6 | */ | 6 | */ |
7 | 7 | ||
8 | #include <linux/linkage.h> | ||
8 | #include <asm/asm-offsets.h> | 9 | #include <asm/asm-offsets.h> |
9 | 10 | ||
10 | .section .kprobes.text, "ax" | 11 | .section .kprobes.text, "ax" |
11 | 12 | ||
12 | .globl ftrace_stub | 13 | ENTRY(ftrace_stub) |
13 | ftrace_stub: | ||
14 | br %r14 | 14 | br %r14 |
15 | 15 | ||
16 | .globl _mcount | 16 | ENTRY(_mcount) |
17 | _mcount: | ||
18 | #ifdef CONFIG_DYNAMIC_FTRACE | 17 | #ifdef CONFIG_DYNAMIC_FTRACE |
19 | br %r14 | 18 | br %r14 |
20 | 19 | ||
21 | .globl ftrace_caller | 20 | ENTRY(ftrace_caller) |
22 | ftrace_caller: | ||
23 | #endif | 21 | #endif |
24 | larl %r1,function_trace_stop | 22 | larl %r1,function_trace_stop |
25 | icm %r1,0xf,0(%r1) | 23 | icm %r1,0xf,0(%r1) |
@@ -37,8 +35,7 @@ ftrace_caller: | |||
37 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | 35 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER |
38 | lg %r2,168(%r15) | 36 | lg %r2,168(%r15) |
39 | lg %r3,272(%r15) | 37 | lg %r3,272(%r15) |
40 | .globl ftrace_graph_caller | 38 | ENTRY(ftrace_graph_caller) |
41 | ftrace_graph_caller: | ||
42 | # The bras instruction gets runtime patched to call prepare_ftrace_return. | 39 | # The bras instruction gets runtime patched to call prepare_ftrace_return. |
43 | # See ftrace_enable_ftrace_graph_caller. The patched instruction is: | 40 | # See ftrace_enable_ftrace_graph_caller. The patched instruction is: |
44 | # bras %r14,prepare_ftrace_return | 41 | # bras %r14,prepare_ftrace_return |
@@ -52,8 +49,7 @@ ftrace_graph_caller: | |||
52 | 49 | ||
53 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | 50 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER |
54 | 51 | ||
55 | .globl return_to_handler | 52 | ENTRY(return_to_handler) |
56 | return_to_handler: | ||
57 | stmg %r2,%r5,32(%r15) | 53 | stmg %r2,%r5,32(%r15) |
58 | lgr %r1,%r15 | 54 | lgr %r1,%r15 |
59 | aghi %r15,-160 | 55 | aghi %r15,-160 |
diff --git a/arch/s390/kernel/reipl.S b/arch/s390/kernel/reipl.S index cb899d9f8505..303d961c3bb5 100644 --- a/arch/s390/kernel/reipl.S +++ b/arch/s390/kernel/reipl.S | |||
@@ -6,14 +6,15 @@ | |||
6 | * Author(s): Holger Smolinski (Holger.Smolinski@de.ibm.com) | 6 | * Author(s): Holger Smolinski (Holger.Smolinski@de.ibm.com) |
7 | */ | 7 | */ |
8 | 8 | ||
9 | #include <linux/linkage.h> | ||
9 | #include <asm/asm-offsets.h> | 10 | #include <asm/asm-offsets.h> |
10 | 11 | ||
11 | # | 12 | # |
12 | # do_reipl_asm | 13 | # do_reipl_asm |
13 | # Parameter: r2 = schid of reipl device | 14 | # Parameter: r2 = schid of reipl device |
14 | # | 15 | # |
15 | .globl do_reipl_asm | 16 | ENTRY(do_reipl_asm) |
16 | do_reipl_asm: basr %r13,0 | 17 | basr %r13,0 |
17 | .Lpg0: lpsw .Lnewpsw-.Lpg0(%r13) | 18 | .Lpg0: lpsw .Lnewpsw-.Lpg0(%r13) |
18 | .Lpg1: # do store status of all registers | 19 | .Lpg1: # do store status of all registers |
19 | 20 | ||
diff --git a/arch/s390/kernel/reipl64.S b/arch/s390/kernel/reipl64.S index 9eabbc90795d..78eb7cfbd3d1 100644 --- a/arch/s390/kernel/reipl64.S +++ b/arch/s390/kernel/reipl64.S | |||
@@ -4,6 +4,7 @@ | |||
4 | * Denis Joseph Barrow, | 4 | * Denis Joseph Barrow, |
5 | */ | 5 | */ |
6 | 6 | ||
7 | #include <linux/linkage.h> | ||
7 | #include <asm/asm-offsets.h> | 8 | #include <asm/asm-offsets.h> |
8 | 9 | ||
9 | # | 10 | # |
@@ -11,8 +12,8 @@ | |||
11 | # Parameter: r2 = schid of reipl device | 12 | # Parameter: r2 = schid of reipl device |
12 | # | 13 | # |
13 | 14 | ||
14 | .globl do_reipl_asm | 15 | ENTRY(do_reipl_asm) |
15 | do_reipl_asm: basr %r13,0 | 16 | basr %r13,0 |
16 | .Lpg0: lpswe .Lnewpsw-.Lpg0(%r13) | 17 | .Lpg0: lpswe .Lnewpsw-.Lpg0(%r13) |
17 | .Lpg1: # do store status of all registers | 18 | .Lpg1: # do store status of all registers |
18 | 19 | ||
diff --git a/arch/s390/kernel/relocate_kernel.S b/arch/s390/kernel/relocate_kernel.S index 3b456b80bcee..c91d70aede91 100644 --- a/arch/s390/kernel/relocate_kernel.S +++ b/arch/s390/kernel/relocate_kernel.S | |||
@@ -8,6 +8,8 @@ | |||
8 | * | 8 | * |
9 | */ | 9 | */ |
10 | 10 | ||
11 | #include <linux/linkage.h> | ||
12 | |||
11 | /* | 13 | /* |
12 | * moves the new kernel to its destination... | 14 | * moves the new kernel to its destination... |
13 | * %r2 = pointer to first kimage_entry_t | 15 | * %r2 = pointer to first kimage_entry_t |
@@ -22,8 +24,7 @@ | |||
22 | */ | 24 | */ |
23 | 25 | ||
24 | .text | 26 | .text |
25 | .globl relocate_kernel | 27 | ENTRY(relocate_kernel) |
26 | relocate_kernel: | ||
27 | basr %r13,0 # base address | 28 | basr %r13,0 # base address |
28 | .base: | 29 | .base: |
29 | stnsm sys_msk-.base(%r13),0xfb # disable DAT | 30 | stnsm sys_msk-.base(%r13),0xfb # disable DAT |
@@ -112,6 +113,7 @@ | |||
112 | .byte 0 | 113 | .byte 0 |
113 | .align 8 | 114 | .align 8 |
114 | relocate_kernel_end: | 115 | relocate_kernel_end: |
116 | .align 8 | ||
115 | .globl relocate_kernel_len | 117 | .globl relocate_kernel_len |
116 | relocate_kernel_len: | 118 | relocate_kernel_len: |
117 | .quad relocate_kernel_end - relocate_kernel | 119 | .quad relocate_kernel_end - relocate_kernel |
diff --git a/arch/s390/kernel/relocate_kernel64.S b/arch/s390/kernel/relocate_kernel64.S index 1f9ea2067b59..7c3ce589a7f0 100644 --- a/arch/s390/kernel/relocate_kernel64.S +++ b/arch/s390/kernel/relocate_kernel64.S | |||
@@ -8,6 +8,8 @@ | |||
8 | * | 8 | * |
9 | */ | 9 | */ |
10 | 10 | ||
11 | #include <linux/linkage.h> | ||
12 | |||
11 | /* | 13 | /* |
12 | * moves the new kernel to its destination... | 14 | * moves the new kernel to its destination... |
13 | * %r2 = pointer to first kimage_entry_t | 15 | * %r2 = pointer to first kimage_entry_t |
@@ -23,8 +25,7 @@ | |||
23 | */ | 25 | */ |
24 | 26 | ||
25 | .text | 27 | .text |
26 | .globl relocate_kernel | 28 | ENTRY(relocate_kernel) |
27 | relocate_kernel: | ||
28 | basr %r13,0 # base address | 29 | basr %r13,0 # base address |
29 | .base: | 30 | .base: |
30 | stnsm sys_msk-.base(%r13),0xfb # disable DAT | 31 | stnsm sys_msk-.base(%r13),0xfb # disable DAT |
@@ -115,6 +116,7 @@ | |||
115 | .byte 0 | 116 | .byte 0 |
116 | .align 8 | 117 | .align 8 |
117 | relocate_kernel_end: | 118 | relocate_kernel_end: |
119 | .align 8 | ||
118 | .globl relocate_kernel_len | 120 | .globl relocate_kernel_len |
119 | relocate_kernel_len: | 121 | relocate_kernel_len: |
120 | .quad relocate_kernel_end - relocate_kernel | 122 | .quad relocate_kernel_end - relocate_kernel |
diff --git a/arch/s390/kernel/s390_ksyms.c b/arch/s390/kernel/s390_ksyms.c index 656fcbb9bd83..57b536649b00 100644 --- a/arch/s390/kernel/s390_ksyms.c +++ b/arch/s390/kernel/s390_ksyms.c | |||
@@ -1,6 +1,10 @@ | |||
1 | #include <linux/module.h> | 1 | #include <linux/module.h> |
2 | #include <linux/kvm_host.h> | ||
2 | #include <asm/ftrace.h> | 3 | #include <asm/ftrace.h> |
3 | 4 | ||
4 | #ifdef CONFIG_FUNCTION_TRACER | 5 | #ifdef CONFIG_FUNCTION_TRACER |
5 | EXPORT_SYMBOL(_mcount); | 6 | EXPORT_SYMBOL(_mcount); |
6 | #endif | 7 | #endif |
8 | #if defined(CONFIG_KVM) || defined(CONFIG_KVM_MODULE) | ||
9 | EXPORT_SYMBOL(sie64a); | ||
10 | #endif | ||
diff --git a/arch/s390/kernel/sclp.S b/arch/s390/kernel/sclp.S index 2e82fdd89320..95792d846bb6 100644 --- a/arch/s390/kernel/sclp.S +++ b/arch/s390/kernel/sclp.S | |||
@@ -8,6 +8,8 @@ | |||
8 | * | 8 | * |
9 | */ | 9 | */ |
10 | 10 | ||
11 | #include <linux/linkage.h> | ||
12 | |||
11 | LC_EXT_NEW_PSW = 0x58 # addr of ext int handler | 13 | LC_EXT_NEW_PSW = 0x58 # addr of ext int handler |
12 | LC_EXT_NEW_PSW_64 = 0x1b0 # addr of ext int handler 64 bit | 14 | LC_EXT_NEW_PSW_64 = 0x1b0 # addr of ext int handler 64 bit |
13 | LC_EXT_INT_PARAM = 0x80 # addr of ext int parameter | 15 | LC_EXT_INT_PARAM = 0x80 # addr of ext int parameter |
@@ -260,8 +262,7 @@ _sclp_print: | |||
260 | # R2 = 0 on success, 1 on failure | 262 | # R2 = 0 on success, 1 on failure |
261 | # | 263 | # |
262 | 264 | ||
263 | .globl _sclp_print_early | 265 | ENTRY(_sclp_print_early) |
264 | _sclp_print_early: | ||
265 | stm %r6,%r15,24(%r15) # save registers | 266 | stm %r6,%r15,24(%r15) # save registers |
266 | ahi %r15,-96 # create stack frame | 267 | ahi %r15,-96 # create stack frame |
267 | #ifdef CONFIG_64BIT | 268 | #ifdef CONFIG_64BIT |
diff --git a/arch/s390/kernel/smp.c b/arch/s390/kernel/smp.c index 1d55c95f617c..a6d85c0a7f20 100644 --- a/arch/s390/kernel/smp.c +++ b/arch/s390/kernel/smp.c | |||
@@ -654,7 +654,8 @@ int __cpu_disable(void) | |||
654 | /* disable all external interrupts */ | 654 | /* disable all external interrupts */ |
655 | cr_parms.orvals[0] = 0; | 655 | cr_parms.orvals[0] = 0; |
656 | cr_parms.andvals[0] = ~(1 << 15 | 1 << 14 | 1 << 13 | 1 << 11 | | 656 | cr_parms.andvals[0] = ~(1 << 15 | 1 << 14 | 1 << 13 | 1 << 11 | |
657 | 1 << 10 | 1 << 9 | 1 << 6 | 1 << 4); | 657 | 1 << 10 | 1 << 9 | 1 << 6 | 1 << 5 | |
658 | 1 << 4); | ||
658 | /* disable all I/O interrupts */ | 659 | /* disable all I/O interrupts */ |
659 | cr_parms.orvals[6] = 0; | 660 | cr_parms.orvals[6] = 0; |
660 | cr_parms.andvals[6] = ~(1 << 31 | 1 << 30 | 1 << 29 | 1 << 28 | | 661 | cr_parms.andvals[6] = ~(1 << 31 | 1 << 30 | 1 << 29 | 1 << 28 | |
diff --git a/arch/s390/kernel/switch_cpu.S b/arch/s390/kernel/switch_cpu.S index 20530dd2eab1..bfe070bc7659 100644 --- a/arch/s390/kernel/switch_cpu.S +++ b/arch/s390/kernel/switch_cpu.S | |||
@@ -5,6 +5,7 @@ | |||
5 | * | 5 | * |
6 | */ | 6 | */ |
7 | 7 | ||
8 | #include <linux/linkage.h> | ||
8 | #include <asm/asm-offsets.h> | 9 | #include <asm/asm-offsets.h> |
9 | #include <asm/ptrace.h> | 10 | #include <asm/ptrace.h> |
10 | 11 | ||
@@ -16,9 +17,7 @@ | |||
16 | # %r6 - destination cpu | 17 | # %r6 - destination cpu |
17 | 18 | ||
18 | .section .text | 19 | .section .text |
19 | .align 4 | 20 | ENTRY(smp_switch_to_cpu) |
20 | .globl smp_switch_to_cpu | ||
21 | smp_switch_to_cpu: | ||
22 | stm %r6,%r15,__SF_GPRS(%r15) | 21 | stm %r6,%r15,__SF_GPRS(%r15) |
23 | lr %r1,%r15 | 22 | lr %r1,%r15 |
24 | ahi %r15,-STACK_FRAME_OVERHEAD | 23 | ahi %r15,-STACK_FRAME_OVERHEAD |
@@ -33,8 +32,7 @@ smp_switch_to_cpu: | |||
33 | brc 2,2b /* busy, try again */ | 32 | brc 2,2b /* busy, try again */ |
34 | 3: j 3b | 33 | 3: j 3b |
35 | 34 | ||
36 | .globl smp_restart_cpu | 35 | ENTRY(smp_restart_cpu) |
37 | smp_restart_cpu: | ||
38 | basr %r13,0 | 36 | basr %r13,0 |
39 | 0: la %r1,.gprregs_addr-0b(%r13) | 37 | 0: la %r1,.gprregs_addr-0b(%r13) |
40 | l %r1,0(%r1) | 38 | l %r1,0(%r1) |
diff --git a/arch/s390/kernel/switch_cpu64.S b/arch/s390/kernel/switch_cpu64.S index 5be3f43898f9..fcc42d799e41 100644 --- a/arch/s390/kernel/switch_cpu64.S +++ b/arch/s390/kernel/switch_cpu64.S | |||
@@ -5,6 +5,7 @@ | |||
5 | * | 5 | * |
6 | */ | 6 | */ |
7 | 7 | ||
8 | #include <linux/linkage.h> | ||
8 | #include <asm/asm-offsets.h> | 9 | #include <asm/asm-offsets.h> |
9 | #include <asm/ptrace.h> | 10 | #include <asm/ptrace.h> |
10 | 11 | ||
@@ -16,9 +17,7 @@ | |||
16 | # %r6 - destination cpu | 17 | # %r6 - destination cpu |
17 | 18 | ||
18 | .section .text | 19 | .section .text |
19 | .align 4 | 20 | ENTRY(smp_switch_to_cpu) |
20 | .globl smp_switch_to_cpu | ||
21 | smp_switch_to_cpu: | ||
22 | stmg %r6,%r15,__SF_GPRS(%r15) | 21 | stmg %r6,%r15,__SF_GPRS(%r15) |
23 | lgr %r1,%r15 | 22 | lgr %r1,%r15 |
24 | aghi %r15,-STACK_FRAME_OVERHEAD | 23 | aghi %r15,-STACK_FRAME_OVERHEAD |
@@ -31,8 +30,7 @@ smp_switch_to_cpu: | |||
31 | brc 2,2b /* busy, try again */ | 30 | brc 2,2b /* busy, try again */ |
32 | 3: j 3b | 31 | 3: j 3b |
33 | 32 | ||
34 | .globl smp_restart_cpu | 33 | ENTRY(smp_restart_cpu) |
35 | smp_restart_cpu: | ||
36 | larl %r1,.gprregs | 34 | larl %r1,.gprregs |
37 | lmg %r0,%r15,0(%r1) | 35 | lmg %r0,%r15,0(%r1) |
38 | 1: sigp %r0,%r5,__SIGP_SENSE /* Wait for calling CPU */ | 36 | 1: sigp %r0,%r5,__SIGP_SENSE /* Wait for calling CPU */ |
diff --git a/arch/s390/kernel/swsusp_asm64.S b/arch/s390/kernel/swsusp_asm64.S index 1f066e46e83e..51bcdb50a230 100644 --- a/arch/s390/kernel/swsusp_asm64.S +++ b/arch/s390/kernel/swsusp_asm64.S | |||
@@ -7,6 +7,7 @@ | |||
7 | * Michael Holzheu <holzheu@linux.vnet.ibm.com> | 7 | * Michael Holzheu <holzheu@linux.vnet.ibm.com> |
8 | */ | 8 | */ |
9 | 9 | ||
10 | #include <linux/linkage.h> | ||
10 | #include <asm/page.h> | 11 | #include <asm/page.h> |
11 | #include <asm/ptrace.h> | 12 | #include <asm/ptrace.h> |
12 | #include <asm/thread_info.h> | 13 | #include <asm/thread_info.h> |
@@ -22,9 +23,7 @@ | |||
22 | * This function runs with disabled interrupts. | 23 | * This function runs with disabled interrupts. |
23 | */ | 24 | */ |
24 | .section .text | 25 | .section .text |
25 | .align 4 | 26 | ENTRY(swsusp_arch_suspend) |
26 | .globl swsusp_arch_suspend | ||
27 | swsusp_arch_suspend: | ||
28 | stmg %r6,%r15,__SF_GPRS(%r15) | 27 | stmg %r6,%r15,__SF_GPRS(%r15) |
29 | lgr %r1,%r15 | 28 | lgr %r1,%r15 |
30 | aghi %r15,-STACK_FRAME_OVERHEAD | 29 | aghi %r15,-STACK_FRAME_OVERHEAD |
@@ -112,8 +111,7 @@ swsusp_arch_suspend: | |||
112 | * Then we return to the function that called swsusp_arch_suspend(). | 111 | * Then we return to the function that called swsusp_arch_suspend(). |
113 | * swsusp_arch_resume() runs with disabled interrupts. | 112 | * swsusp_arch_resume() runs with disabled interrupts. |
114 | */ | 113 | */ |
115 | .globl swsusp_arch_resume | 114 | ENTRY(swsusp_arch_resume) |
116 | swsusp_arch_resume: | ||
117 | stmg %r6,%r15,__SF_GPRS(%r15) | 115 | stmg %r6,%r15,__SF_GPRS(%r15) |
118 | lgr %r1,%r15 | 116 | lgr %r1,%r15 |
119 | aghi %r15,-STACK_FRAME_OVERHEAD | 117 | aghi %r15,-STACK_FRAME_OVERHEAD |
diff --git a/arch/s390/kernel/traps.c b/arch/s390/kernel/traps.c index a63d34c3611e..e9372c77cced 100644 --- a/arch/s390/kernel/traps.c +++ b/arch/s390/kernel/traps.c | |||
@@ -18,7 +18,7 @@ | |||
18 | #include <linux/kernel.h> | 18 | #include <linux/kernel.h> |
19 | #include <linux/string.h> | 19 | #include <linux/string.h> |
20 | #include <linux/errno.h> | 20 | #include <linux/errno.h> |
21 | #include <linux/tracehook.h> | 21 | #include <linux/ptrace.h> |
22 | #include <linux/timer.h> | 22 | #include <linux/timer.h> |
23 | #include <linux/mm.h> | 23 | #include <linux/mm.h> |
24 | #include <linux/smp.h> | 24 | #include <linux/smp.h> |
@@ -43,14 +43,10 @@ | |||
43 | #include <asm/debug.h> | 43 | #include <asm/debug.h> |
44 | #include "entry.h" | 44 | #include "entry.h" |
45 | 45 | ||
46 | pgm_check_handler_t *pgm_check_table[128]; | 46 | void (*pgm_check_table[128])(struct pt_regs *, long, unsigned long); |
47 | 47 | ||
48 | int show_unhandled_signals; | 48 | int show_unhandled_signals; |
49 | 49 | ||
50 | extern pgm_check_handler_t do_protection_exception; | ||
51 | extern pgm_check_handler_t do_dat_exception; | ||
52 | extern pgm_check_handler_t do_asce_exception; | ||
53 | |||
54 | #define stack_pointer ({ void **sp; asm("la %0,0(15)" : "=&d" (sp)); sp; }) | 50 | #define stack_pointer ({ void **sp; asm("la %0,0(15)" : "=&d" (sp)); sp; }) |
55 | 51 | ||
56 | #ifndef CONFIG_64BIT | 52 | #ifndef CONFIG_64BIT |
@@ -329,10 +325,17 @@ static inline void __user *get_psw_address(struct pt_regs *regs, | |||
329 | 325 | ||
330 | void __kprobes do_per_trap(struct pt_regs *regs) | 326 | void __kprobes do_per_trap(struct pt_regs *regs) |
331 | { | 327 | { |
328 | siginfo_t info; | ||
329 | |||
332 | if (notify_die(DIE_SSTEP, "sstep", regs, 0, 0, SIGTRAP) == NOTIFY_STOP) | 330 | if (notify_die(DIE_SSTEP, "sstep", regs, 0, 0, SIGTRAP) == NOTIFY_STOP) |
333 | return; | 331 | return; |
334 | if (current->ptrace) | 332 | if (!current->ptrace) |
335 | force_sig(SIGTRAP, current); | 333 | return; |
334 | info.si_signo = SIGTRAP; | ||
335 | info.si_errno = 0; | ||
336 | info.si_code = TRAP_HWBKPT; | ||
337 | info.si_addr = (void *) current->thread.per_event.address; | ||
338 | force_sig_info(SIGTRAP, &info, current); | ||
336 | } | 339 | } |
337 | 340 | ||
338 | static void default_trap_handler(struct pt_regs *regs, long pgm_int_code, | 341 | static void default_trap_handler(struct pt_regs *regs, long pgm_int_code, |
@@ -425,9 +428,13 @@ static void __kprobes illegal_op(struct pt_regs *regs, long pgm_int_code, | |||
425 | if (get_user(*((__u16 *) opcode), (__u16 __user *) location)) | 428 | if (get_user(*((__u16 *) opcode), (__u16 __user *) location)) |
426 | return; | 429 | return; |
427 | if (*((__u16 *) opcode) == S390_BREAKPOINT_U16) { | 430 | if (*((__u16 *) opcode) == S390_BREAKPOINT_U16) { |
428 | if (current->ptrace) | 431 | if (current->ptrace) { |
429 | force_sig(SIGTRAP, current); | 432 | info.si_signo = SIGTRAP; |
430 | else | 433 | info.si_errno = 0; |
434 | info.si_code = TRAP_BRKPT; | ||
435 | info.si_addr = location; | ||
436 | force_sig_info(SIGTRAP, &info, current); | ||
437 | } else | ||
431 | signal = SIGILL; | 438 | signal = SIGILL; |
432 | #ifdef CONFIG_MATHEMU | 439 | #ifdef CONFIG_MATHEMU |
433 | } else if (opcode[0] == 0xb3) { | 440 | } else if (opcode[0] == 0xb3) { |
@@ -489,9 +496,8 @@ static void __kprobes illegal_op(struct pt_regs *regs, long pgm_int_code, | |||
489 | 496 | ||
490 | 497 | ||
491 | #ifdef CONFIG_MATHEMU | 498 | #ifdef CONFIG_MATHEMU |
492 | asmlinkage void specification_exception(struct pt_regs *regs, | 499 | void specification_exception(struct pt_regs *regs, long pgm_int_code, |
493 | long pgm_int_code, | 500 | unsigned long trans_exc_code) |
494 | unsigned long trans_exc_code) | ||
495 | { | 501 | { |
496 | __u8 opcode[6]; | 502 | __u8 opcode[6]; |
497 | __u16 __user *location = NULL; | 503 | __u16 __user *location = NULL; |
@@ -648,7 +654,7 @@ static void space_switch_exception(struct pt_regs *regs, long pgm_int_code, | |||
648 | do_trap(pgm_int_code, SIGILL, "space switch event", regs, &info); | 654 | do_trap(pgm_int_code, SIGILL, "space switch event", regs, &info); |
649 | } | 655 | } |
650 | 656 | ||
651 | asmlinkage void __kprobes kernel_stack_overflow(struct pt_regs * regs) | 657 | void __kprobes kernel_stack_overflow(struct pt_regs * regs) |
652 | { | 658 | { |
653 | bust_spinlocks(1); | 659 | bust_spinlocks(1); |
654 | printk("Kernel stack overflow.\n"); | 660 | printk("Kernel stack overflow.\n"); |
diff --git a/arch/s390/kvm/Makefile b/arch/s390/kvm/Makefile index 860d26514c08..3975722bb19d 100644 --- a/arch/s390/kvm/Makefile +++ b/arch/s390/kvm/Makefile | |||
@@ -10,5 +10,5 @@ common-objs = $(addprefix ../../../virt/kvm/, kvm_main.o) | |||
10 | 10 | ||
11 | ccflags-y := -Ivirt/kvm -Iarch/s390/kvm | 11 | ccflags-y := -Ivirt/kvm -Iarch/s390/kvm |
12 | 12 | ||
13 | kvm-objs := $(common-objs) kvm-s390.o sie64a.o intercept.o interrupt.o priv.o sigp.o diag.o | 13 | kvm-objs := $(common-objs) kvm-s390.o intercept.o interrupt.o priv.o sigp.o diag.o |
14 | obj-$(CONFIG_KVM) += kvm.o | 14 | obj-$(CONFIG_KVM) += kvm.o |
diff --git a/arch/s390/kvm/gaccess.h b/arch/s390/kvm/gaccess.h index 03c716a0f01f..c86f6ae43f76 100644 --- a/arch/s390/kvm/gaccess.h +++ b/arch/s390/kvm/gaccess.h | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * gaccess.h - access guest memory | 2 | * access.h - access guest memory |
3 | * | 3 | * |
4 | * Copyright IBM Corp. 2008,2009 | 4 | * Copyright IBM Corp. 2008,2009 |
5 | * | 5 | * |
@@ -22,20 +22,13 @@ static inline void __user *__guestaddr_to_user(struct kvm_vcpu *vcpu, | |||
22 | unsigned long guestaddr) | 22 | unsigned long guestaddr) |
23 | { | 23 | { |
24 | unsigned long prefix = vcpu->arch.sie_block->prefix; | 24 | unsigned long prefix = vcpu->arch.sie_block->prefix; |
25 | unsigned long origin = vcpu->arch.sie_block->gmsor; | ||
26 | unsigned long memsize = kvm_s390_vcpu_get_memsize(vcpu); | ||
27 | 25 | ||
28 | if (guestaddr < 2 * PAGE_SIZE) | 26 | if (guestaddr < 2 * PAGE_SIZE) |
29 | guestaddr += prefix; | 27 | guestaddr += prefix; |
30 | else if ((guestaddr >= prefix) && (guestaddr < prefix + 2 * PAGE_SIZE)) | 28 | else if ((guestaddr >= prefix) && (guestaddr < prefix + 2 * PAGE_SIZE)) |
31 | guestaddr -= prefix; | 29 | guestaddr -= prefix; |
32 | 30 | ||
33 | if (guestaddr > memsize) | 31 | return (void __user *) gmap_fault(guestaddr, vcpu->arch.gmap); |
34 | return (void __user __force *) ERR_PTR(-EFAULT); | ||
35 | |||
36 | guestaddr += origin; | ||
37 | |||
38 | return (void __user *) guestaddr; | ||
39 | } | 32 | } |
40 | 33 | ||
41 | static inline int get_guest_u64(struct kvm_vcpu *vcpu, unsigned long guestaddr, | 34 | static inline int get_guest_u64(struct kvm_vcpu *vcpu, unsigned long guestaddr, |
@@ -141,11 +134,11 @@ static inline int put_guest_u8(struct kvm_vcpu *vcpu, unsigned long guestaddr, | |||
141 | 134 | ||
142 | static inline int __copy_to_guest_slow(struct kvm_vcpu *vcpu, | 135 | static inline int __copy_to_guest_slow(struct kvm_vcpu *vcpu, |
143 | unsigned long guestdest, | 136 | unsigned long guestdest, |
144 | const void *from, unsigned long n) | 137 | void *from, unsigned long n) |
145 | { | 138 | { |
146 | int rc; | 139 | int rc; |
147 | unsigned long i; | 140 | unsigned long i; |
148 | const u8 *data = from; | 141 | u8 *data = from; |
149 | 142 | ||
150 | for (i = 0; i < n; i++) { | 143 | for (i = 0; i < n; i++) { |
151 | rc = put_guest_u8(vcpu, guestdest++, *(data++)); | 144 | rc = put_guest_u8(vcpu, guestdest++, *(data++)); |
@@ -155,12 +148,95 @@ static inline int __copy_to_guest_slow(struct kvm_vcpu *vcpu, | |||
155 | return 0; | 148 | return 0; |
156 | } | 149 | } |
157 | 150 | ||
151 | static inline int __copy_to_guest_fast(struct kvm_vcpu *vcpu, | ||
152 | unsigned long guestdest, | ||
153 | void *from, unsigned long n) | ||
154 | { | ||
155 | int r; | ||
156 | void __user *uptr; | ||
157 | unsigned long size; | ||
158 | |||
159 | if (guestdest + n < guestdest) | ||
160 | return -EFAULT; | ||
161 | |||
162 | /* simple case: all within one segment table entry? */ | ||
163 | if ((guestdest & PMD_MASK) == ((guestdest+n) & PMD_MASK)) { | ||
164 | uptr = (void __user *) gmap_fault(guestdest, vcpu->arch.gmap); | ||
165 | |||
166 | if (IS_ERR((void __force *) uptr)) | ||
167 | return PTR_ERR((void __force *) uptr); | ||
168 | |||
169 | r = copy_to_user(uptr, from, n); | ||
170 | |||
171 | if (r) | ||
172 | r = -EFAULT; | ||
173 | |||
174 | goto out; | ||
175 | } | ||
176 | |||
177 | /* copy first segment */ | ||
178 | uptr = (void __user *)gmap_fault(guestdest, vcpu->arch.gmap); | ||
179 | |||
180 | if (IS_ERR((void __force *) uptr)) | ||
181 | return PTR_ERR((void __force *) uptr); | ||
182 | |||
183 | size = PMD_SIZE - (guestdest & ~PMD_MASK); | ||
184 | |||
185 | r = copy_to_user(uptr, from, size); | ||
186 | |||
187 | if (r) { | ||
188 | r = -EFAULT; | ||
189 | goto out; | ||
190 | } | ||
191 | from += size; | ||
192 | n -= size; | ||
193 | guestdest += size; | ||
194 | |||
195 | /* copy full segments */ | ||
196 | while (n >= PMD_SIZE) { | ||
197 | uptr = (void __user *)gmap_fault(guestdest, vcpu->arch.gmap); | ||
198 | |||
199 | if (IS_ERR((void __force *) uptr)) | ||
200 | return PTR_ERR((void __force *) uptr); | ||
201 | |||
202 | r = copy_to_user(uptr, from, PMD_SIZE); | ||
203 | |||
204 | if (r) { | ||
205 | r = -EFAULT; | ||
206 | goto out; | ||
207 | } | ||
208 | from += PMD_SIZE; | ||
209 | n -= PMD_SIZE; | ||
210 | guestdest += PMD_SIZE; | ||
211 | } | ||
212 | |||
213 | /* copy the tail segment */ | ||
214 | if (n) { | ||
215 | uptr = (void __user *)gmap_fault(guestdest, vcpu->arch.gmap); | ||
216 | |||
217 | if (IS_ERR((void __force *) uptr)) | ||
218 | return PTR_ERR((void __force *) uptr); | ||
219 | |||
220 | r = copy_to_user(uptr, from, n); | ||
221 | |||
222 | if (r) | ||
223 | r = -EFAULT; | ||
224 | } | ||
225 | out: | ||
226 | return r; | ||
227 | } | ||
228 | |||
229 | static inline int copy_to_guest_absolute(struct kvm_vcpu *vcpu, | ||
230 | unsigned long guestdest, | ||
231 | void *from, unsigned long n) | ||
232 | { | ||
233 | return __copy_to_guest_fast(vcpu, guestdest, from, n); | ||
234 | } | ||
235 | |||
158 | static inline int copy_to_guest(struct kvm_vcpu *vcpu, unsigned long guestdest, | 236 | static inline int copy_to_guest(struct kvm_vcpu *vcpu, unsigned long guestdest, |
159 | const void *from, unsigned long n) | 237 | void *from, unsigned long n) |
160 | { | 238 | { |
161 | unsigned long prefix = vcpu->arch.sie_block->prefix; | 239 | unsigned long prefix = vcpu->arch.sie_block->prefix; |
162 | unsigned long origin = vcpu->arch.sie_block->gmsor; | ||
163 | unsigned long memsize = kvm_s390_vcpu_get_memsize(vcpu); | ||
164 | 240 | ||
165 | if ((guestdest < 2 * PAGE_SIZE) && (guestdest + n > 2 * PAGE_SIZE)) | 241 | if ((guestdest < 2 * PAGE_SIZE) && (guestdest + n > 2 * PAGE_SIZE)) |
166 | goto slowpath; | 242 | goto slowpath; |
@@ -177,15 +253,7 @@ static inline int copy_to_guest(struct kvm_vcpu *vcpu, unsigned long guestdest, | |||
177 | else if ((guestdest >= prefix) && (guestdest < prefix + 2 * PAGE_SIZE)) | 253 | else if ((guestdest >= prefix) && (guestdest < prefix + 2 * PAGE_SIZE)) |
178 | guestdest -= prefix; | 254 | guestdest -= prefix; |
179 | 255 | ||
180 | if (guestdest + n > memsize) | 256 | return __copy_to_guest_fast(vcpu, guestdest, from, n); |
181 | return -EFAULT; | ||
182 | |||
183 | if (guestdest + n < guestdest) | ||
184 | return -EFAULT; | ||
185 | |||
186 | guestdest += origin; | ||
187 | |||
188 | return copy_to_user((void __user *) guestdest, from, n); | ||
189 | slowpath: | 257 | slowpath: |
190 | return __copy_to_guest_slow(vcpu, guestdest, from, n); | 258 | return __copy_to_guest_slow(vcpu, guestdest, from, n); |
191 | } | 259 | } |
@@ -206,74 +274,113 @@ static inline int __copy_from_guest_slow(struct kvm_vcpu *vcpu, void *to, | |||
206 | return 0; | 274 | return 0; |
207 | } | 275 | } |
208 | 276 | ||
209 | static inline int copy_from_guest(struct kvm_vcpu *vcpu, void *to, | 277 | static inline int __copy_from_guest_fast(struct kvm_vcpu *vcpu, void *to, |
210 | unsigned long guestsrc, unsigned long n) | 278 | unsigned long guestsrc, |
279 | unsigned long n) | ||
211 | { | 280 | { |
212 | unsigned long prefix = vcpu->arch.sie_block->prefix; | 281 | int r; |
213 | unsigned long origin = vcpu->arch.sie_block->gmsor; | 282 | void __user *uptr; |
214 | unsigned long memsize = kvm_s390_vcpu_get_memsize(vcpu); | 283 | unsigned long size; |
215 | 284 | ||
216 | if ((guestsrc < 2 * PAGE_SIZE) && (guestsrc + n > 2 * PAGE_SIZE)) | 285 | if (guestsrc + n < guestsrc) |
217 | goto slowpath; | 286 | return -EFAULT; |
218 | 287 | ||
219 | if ((guestsrc < prefix) && (guestsrc + n > prefix)) | 288 | /* simple case: all within one segment table entry? */ |
220 | goto slowpath; | 289 | if ((guestsrc & PMD_MASK) == ((guestsrc+n) & PMD_MASK)) { |
290 | uptr = (void __user *) gmap_fault(guestsrc, vcpu->arch.gmap); | ||
221 | 291 | ||
222 | if ((guestsrc < prefix + 2 * PAGE_SIZE) | 292 | if (IS_ERR((void __force *) uptr)) |
223 | && (guestsrc + n > prefix + 2 * PAGE_SIZE)) | 293 | return PTR_ERR((void __force *) uptr); |
224 | goto slowpath; | ||
225 | 294 | ||
226 | if (guestsrc < 2 * PAGE_SIZE) | 295 | r = copy_from_user(to, uptr, n); |
227 | guestsrc += prefix; | ||
228 | else if ((guestsrc >= prefix) && (guestsrc < prefix + 2 * PAGE_SIZE)) | ||
229 | guestsrc -= prefix; | ||
230 | 296 | ||
231 | if (guestsrc + n > memsize) | 297 | if (r) |
232 | return -EFAULT; | 298 | r = -EFAULT; |
233 | 299 | ||
234 | if (guestsrc + n < guestsrc) | 300 | goto out; |
235 | return -EFAULT; | 301 | } |
236 | 302 | ||
237 | guestsrc += origin; | 303 | /* copy first segment */ |
304 | uptr = (void __user *)gmap_fault(guestsrc, vcpu->arch.gmap); | ||
238 | 305 | ||
239 | return copy_from_user(to, (void __user *) guestsrc, n); | 306 | if (IS_ERR((void __force *) uptr)) |
240 | slowpath: | 307 | return PTR_ERR((void __force *) uptr); |
241 | return __copy_from_guest_slow(vcpu, to, guestsrc, n); | ||
242 | } | ||
243 | 308 | ||
244 | static inline int copy_to_guest_absolute(struct kvm_vcpu *vcpu, | 309 | size = PMD_SIZE - (guestsrc & ~PMD_MASK); |
245 | unsigned long guestdest, | ||
246 | const void *from, unsigned long n) | ||
247 | { | ||
248 | unsigned long origin = vcpu->arch.sie_block->gmsor; | ||
249 | unsigned long memsize = kvm_s390_vcpu_get_memsize(vcpu); | ||
250 | 310 | ||
251 | if (guestdest + n > memsize) | 311 | r = copy_from_user(to, uptr, size); |
252 | return -EFAULT; | ||
253 | 312 | ||
254 | if (guestdest + n < guestdest) | 313 | if (r) { |
255 | return -EFAULT; | 314 | r = -EFAULT; |
315 | goto out; | ||
316 | } | ||
317 | to += size; | ||
318 | n -= size; | ||
319 | guestsrc += size; | ||
320 | |||
321 | /* copy full segments */ | ||
322 | while (n >= PMD_SIZE) { | ||
323 | uptr = (void __user *)gmap_fault(guestsrc, vcpu->arch.gmap); | ||
324 | |||
325 | if (IS_ERR((void __force *) uptr)) | ||
326 | return PTR_ERR((void __force *) uptr); | ||
327 | |||
328 | r = copy_from_user(to, uptr, PMD_SIZE); | ||
329 | |||
330 | if (r) { | ||
331 | r = -EFAULT; | ||
332 | goto out; | ||
333 | } | ||
334 | to += PMD_SIZE; | ||
335 | n -= PMD_SIZE; | ||
336 | guestsrc += PMD_SIZE; | ||
337 | } | ||
338 | |||
339 | /* copy the tail segment */ | ||
340 | if (n) { | ||
341 | uptr = (void __user *)gmap_fault(guestsrc, vcpu->arch.gmap); | ||
256 | 342 | ||
257 | guestdest += origin; | 343 | if (IS_ERR((void __force *) uptr)) |
344 | return PTR_ERR((void __force *) uptr); | ||
258 | 345 | ||
259 | return copy_to_user((void __user *) guestdest, from, n); | 346 | r = copy_from_user(to, uptr, n); |
347 | |||
348 | if (r) | ||
349 | r = -EFAULT; | ||
350 | } | ||
351 | out: | ||
352 | return r; | ||
260 | } | 353 | } |
261 | 354 | ||
262 | static inline int copy_from_guest_absolute(struct kvm_vcpu *vcpu, void *to, | 355 | static inline int copy_from_guest_absolute(struct kvm_vcpu *vcpu, void *to, |
263 | unsigned long guestsrc, | 356 | unsigned long guestsrc, |
264 | unsigned long n) | 357 | unsigned long n) |
265 | { | 358 | { |
266 | unsigned long origin = vcpu->arch.sie_block->gmsor; | 359 | return __copy_from_guest_fast(vcpu, to, guestsrc, n); |
267 | unsigned long memsize = kvm_s390_vcpu_get_memsize(vcpu); | 360 | } |
268 | 361 | ||
269 | if (guestsrc + n > memsize) | 362 | static inline int copy_from_guest(struct kvm_vcpu *vcpu, void *to, |
270 | return -EFAULT; | 363 | unsigned long guestsrc, unsigned long n) |
364 | { | ||
365 | unsigned long prefix = vcpu->arch.sie_block->prefix; | ||
271 | 366 | ||
272 | if (guestsrc + n < guestsrc) | 367 | if ((guestsrc < 2 * PAGE_SIZE) && (guestsrc + n > 2 * PAGE_SIZE)) |
273 | return -EFAULT; | 368 | goto slowpath; |
274 | 369 | ||
275 | guestsrc += origin; | 370 | if ((guestsrc < prefix) && (guestsrc + n > prefix)) |
371 | goto slowpath; | ||
372 | |||
373 | if ((guestsrc < prefix + 2 * PAGE_SIZE) | ||
374 | && (guestsrc + n > prefix + 2 * PAGE_SIZE)) | ||
375 | goto slowpath; | ||
376 | |||
377 | if (guestsrc < 2 * PAGE_SIZE) | ||
378 | guestsrc += prefix; | ||
379 | else if ((guestsrc >= prefix) && (guestsrc < prefix + 2 * PAGE_SIZE)) | ||
380 | guestsrc -= prefix; | ||
276 | 381 | ||
277 | return copy_from_user(to, (void __user *) guestsrc, n); | 382 | return __copy_from_guest_fast(vcpu, to, guestsrc, n); |
383 | slowpath: | ||
384 | return __copy_from_guest_slow(vcpu, to, guestsrc, n); | ||
278 | } | 385 | } |
279 | #endif | 386 | #endif |
diff --git a/arch/s390/kvm/intercept.c b/arch/s390/kvm/intercept.c index f7b6df45d8be..c7c51898984e 100644 --- a/arch/s390/kvm/intercept.c +++ b/arch/s390/kvm/intercept.c | |||
@@ -105,6 +105,7 @@ static intercept_handler_t instruction_handlers[256] = { | |||
105 | [0xae] = kvm_s390_handle_sigp, | 105 | [0xae] = kvm_s390_handle_sigp, |
106 | [0xb2] = kvm_s390_handle_b2, | 106 | [0xb2] = kvm_s390_handle_b2, |
107 | [0xb7] = handle_lctl, | 107 | [0xb7] = handle_lctl, |
108 | [0xe5] = kvm_s390_handle_e5, | ||
108 | [0xeb] = handle_lctlg, | 109 | [0xeb] = handle_lctlg, |
109 | }; | 110 | }; |
110 | 111 | ||
@@ -159,22 +160,42 @@ static int handle_stop(struct kvm_vcpu *vcpu) | |||
159 | 160 | ||
160 | static int handle_validity(struct kvm_vcpu *vcpu) | 161 | static int handle_validity(struct kvm_vcpu *vcpu) |
161 | { | 162 | { |
163 | unsigned long vmaddr; | ||
162 | int viwhy = vcpu->arch.sie_block->ipb >> 16; | 164 | int viwhy = vcpu->arch.sie_block->ipb >> 16; |
163 | int rc; | 165 | int rc; |
164 | 166 | ||
165 | vcpu->stat.exit_validity++; | 167 | vcpu->stat.exit_validity++; |
166 | if ((viwhy == 0x37) && (vcpu->arch.sie_block->prefix | 168 | if (viwhy == 0x37) { |
167 | <= kvm_s390_vcpu_get_memsize(vcpu) - 2*PAGE_SIZE)) { | 169 | vmaddr = gmap_fault(vcpu->arch.sie_block->prefix, |
168 | rc = fault_in_pages_writeable((char __user *) | 170 | vcpu->arch.gmap); |
169 | vcpu->arch.sie_block->gmsor + | 171 | if (IS_ERR_VALUE(vmaddr)) { |
170 | vcpu->arch.sie_block->prefix, | 172 | rc = -EOPNOTSUPP; |
171 | 2*PAGE_SIZE); | 173 | goto out; |
172 | if (rc) | 174 | } |
175 | rc = fault_in_pages_writeable((char __user *) vmaddr, | ||
176 | PAGE_SIZE); | ||
177 | if (rc) { | ||
178 | /* user will receive sigsegv, exit to user */ | ||
179 | rc = -EOPNOTSUPP; | ||
180 | goto out; | ||
181 | } | ||
182 | vmaddr = gmap_fault(vcpu->arch.sie_block->prefix + PAGE_SIZE, | ||
183 | vcpu->arch.gmap); | ||
184 | if (IS_ERR_VALUE(vmaddr)) { | ||
185 | rc = -EOPNOTSUPP; | ||
186 | goto out; | ||
187 | } | ||
188 | rc = fault_in_pages_writeable((char __user *) vmaddr, | ||
189 | PAGE_SIZE); | ||
190 | if (rc) { | ||
173 | /* user will receive sigsegv, exit to user */ | 191 | /* user will receive sigsegv, exit to user */ |
174 | rc = -EOPNOTSUPP; | 192 | rc = -EOPNOTSUPP; |
193 | goto out; | ||
194 | } | ||
175 | } else | 195 | } else |
176 | rc = -EOPNOTSUPP; | 196 | rc = -EOPNOTSUPP; |
177 | 197 | ||
198 | out: | ||
178 | if (rc) | 199 | if (rc) |
179 | VCPU_EVENT(vcpu, 2, "unhandled validity intercept code %d", | 200 | VCPU_EVENT(vcpu, 2, "unhandled validity intercept code %d", |
180 | viwhy); | 201 | viwhy); |
diff --git a/arch/s390/kvm/interrupt.c b/arch/s390/kvm/interrupt.c index 35c21bf910c5..c9aeb4b4d0b8 100644 --- a/arch/s390/kvm/interrupt.c +++ b/arch/s390/kvm/interrupt.c | |||
@@ -128,6 +128,10 @@ static void __do_deliver_interrupt(struct kvm_vcpu *vcpu, | |||
128 | if (rc == -EFAULT) | 128 | if (rc == -EFAULT) |
129 | exception = 1; | 129 | exception = 1; |
130 | 130 | ||
131 | rc = put_guest_u16(vcpu, __LC_CPU_ADDRESS, inti->emerg.code); | ||
132 | if (rc == -EFAULT) | ||
133 | exception = 1; | ||
134 | |||
131 | rc = copy_to_guest(vcpu, __LC_EXT_OLD_PSW, | 135 | rc = copy_to_guest(vcpu, __LC_EXT_OLD_PSW, |
132 | &vcpu->arch.sie_block->gpsw, sizeof(psw_t)); | 136 | &vcpu->arch.sie_block->gpsw, sizeof(psw_t)); |
133 | if (rc == -EFAULT) | 137 | if (rc == -EFAULT) |
diff --git a/arch/s390/kvm/kvm-s390.c b/arch/s390/kvm/kvm-s390.c index 67345ae7ce8d..f17296e4fc89 100644 --- a/arch/s390/kvm/kvm-s390.c +++ b/arch/s390/kvm/kvm-s390.c | |||
@@ -62,6 +62,7 @@ struct kvm_stats_debugfs_item debugfs_entries[] = { | |||
62 | { "instruction_chsc", VCPU_STAT(instruction_chsc) }, | 62 | { "instruction_chsc", VCPU_STAT(instruction_chsc) }, |
63 | { "instruction_stsi", VCPU_STAT(instruction_stsi) }, | 63 | { "instruction_stsi", VCPU_STAT(instruction_stsi) }, |
64 | { "instruction_stfl", VCPU_STAT(instruction_stfl) }, | 64 | { "instruction_stfl", VCPU_STAT(instruction_stfl) }, |
65 | { "instruction_tprot", VCPU_STAT(instruction_tprot) }, | ||
65 | { "instruction_sigp_sense", VCPU_STAT(instruction_sigp_sense) }, | 66 | { "instruction_sigp_sense", VCPU_STAT(instruction_sigp_sense) }, |
66 | { "instruction_sigp_emergency", VCPU_STAT(instruction_sigp_emergency) }, | 67 | { "instruction_sigp_emergency", VCPU_STAT(instruction_sigp_emergency) }, |
67 | { "instruction_sigp_stop", VCPU_STAT(instruction_sigp_stop) }, | 68 | { "instruction_sigp_stop", VCPU_STAT(instruction_sigp_stop) }, |
@@ -189,7 +190,13 @@ int kvm_arch_init_vm(struct kvm *kvm) | |||
189 | debug_register_view(kvm->arch.dbf, &debug_sprintf_view); | 190 | debug_register_view(kvm->arch.dbf, &debug_sprintf_view); |
190 | VM_EVENT(kvm, 3, "%s", "vm created"); | 191 | VM_EVENT(kvm, 3, "%s", "vm created"); |
191 | 192 | ||
193 | kvm->arch.gmap = gmap_alloc(current->mm); | ||
194 | if (!kvm->arch.gmap) | ||
195 | goto out_nogmap; | ||
196 | |||
192 | return 0; | 197 | return 0; |
198 | out_nogmap: | ||
199 | debug_unregister(kvm->arch.dbf); | ||
193 | out_nodbf: | 200 | out_nodbf: |
194 | free_page((unsigned long)(kvm->arch.sca)); | 201 | free_page((unsigned long)(kvm->arch.sca)); |
195 | out_err: | 202 | out_err: |
@@ -234,11 +241,13 @@ void kvm_arch_destroy_vm(struct kvm *kvm) | |||
234 | kvm_free_vcpus(kvm); | 241 | kvm_free_vcpus(kvm); |
235 | free_page((unsigned long)(kvm->arch.sca)); | 242 | free_page((unsigned long)(kvm->arch.sca)); |
236 | debug_unregister(kvm->arch.dbf); | 243 | debug_unregister(kvm->arch.dbf); |
244 | gmap_free(kvm->arch.gmap); | ||
237 | } | 245 | } |
238 | 246 | ||
239 | /* Section: vcpu related */ | 247 | /* Section: vcpu related */ |
240 | int kvm_arch_vcpu_init(struct kvm_vcpu *vcpu) | 248 | int kvm_arch_vcpu_init(struct kvm_vcpu *vcpu) |
241 | { | 249 | { |
250 | vcpu->arch.gmap = vcpu->kvm->arch.gmap; | ||
242 | return 0; | 251 | return 0; |
243 | } | 252 | } |
244 | 253 | ||
@@ -284,8 +293,7 @@ static void kvm_s390_vcpu_initial_reset(struct kvm_vcpu *vcpu) | |||
284 | 293 | ||
285 | int kvm_arch_vcpu_setup(struct kvm_vcpu *vcpu) | 294 | int kvm_arch_vcpu_setup(struct kvm_vcpu *vcpu) |
286 | { | 295 | { |
287 | atomic_set(&vcpu->arch.sie_block->cpuflags, CPUSTAT_ZARCH); | 296 | atomic_set(&vcpu->arch.sie_block->cpuflags, CPUSTAT_ZARCH | CPUSTAT_SM); |
288 | set_bit(KVM_REQ_MMU_RELOAD, &vcpu->requests); | ||
289 | vcpu->arch.sie_block->ecb = 6; | 297 | vcpu->arch.sie_block->ecb = 6; |
290 | vcpu->arch.sie_block->eca = 0xC1002001U; | 298 | vcpu->arch.sie_block->eca = 0xC1002001U; |
291 | vcpu->arch.sie_block->fac = (int) (long) facilities; | 299 | vcpu->arch.sie_block->fac = (int) (long) facilities; |
@@ -453,6 +461,7 @@ static void __vcpu_run(struct kvm_vcpu *vcpu) | |||
453 | local_irq_disable(); | 461 | local_irq_disable(); |
454 | kvm_guest_enter(); | 462 | kvm_guest_enter(); |
455 | local_irq_enable(); | 463 | local_irq_enable(); |
464 | gmap_enable(vcpu->arch.gmap); | ||
456 | VCPU_EVENT(vcpu, 6, "entering sie flags %x", | 465 | VCPU_EVENT(vcpu, 6, "entering sie flags %x", |
457 | atomic_read(&vcpu->arch.sie_block->cpuflags)); | 466 | atomic_read(&vcpu->arch.sie_block->cpuflags)); |
458 | if (sie64a(vcpu->arch.sie_block, vcpu->arch.guest_gprs)) { | 467 | if (sie64a(vcpu->arch.sie_block, vcpu->arch.guest_gprs)) { |
@@ -461,6 +470,7 @@ static void __vcpu_run(struct kvm_vcpu *vcpu) | |||
461 | } | 470 | } |
462 | VCPU_EVENT(vcpu, 6, "exit sie icptcode %d", | 471 | VCPU_EVENT(vcpu, 6, "exit sie icptcode %d", |
463 | vcpu->arch.sie_block->icptcode); | 472 | vcpu->arch.sie_block->icptcode); |
473 | gmap_disable(vcpu->arch.gmap); | ||
464 | local_irq_disable(); | 474 | local_irq_disable(); |
465 | kvm_guest_exit(); | 475 | kvm_guest_exit(); |
466 | local_irq_enable(); | 476 | local_irq_enable(); |
@@ -474,17 +484,6 @@ int kvm_arch_vcpu_ioctl_run(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run) | |||
474 | sigset_t sigsaved; | 484 | sigset_t sigsaved; |
475 | 485 | ||
476 | rerun_vcpu: | 486 | rerun_vcpu: |
477 | if (vcpu->requests) | ||
478 | if (test_and_clear_bit(KVM_REQ_MMU_RELOAD, &vcpu->requests)) | ||
479 | kvm_s390_vcpu_set_mem(vcpu); | ||
480 | |||
481 | /* verify, that memory has been registered */ | ||
482 | if (!vcpu->arch.sie_block->gmslm) { | ||
483 | vcpu_put(vcpu); | ||
484 | VCPU_EVENT(vcpu, 3, "%s", "no memory registered to run vcpu"); | ||
485 | return -EINVAL; | ||
486 | } | ||
487 | |||
488 | if (vcpu->sigset_active) | 487 | if (vcpu->sigset_active) |
489 | sigprocmask(SIG_SETMASK, &vcpu->sigset, &sigsaved); | 488 | sigprocmask(SIG_SETMASK, &vcpu->sigset, &sigsaved); |
490 | 489 | ||
@@ -545,7 +544,7 @@ rerun_vcpu: | |||
545 | return rc; | 544 | return rc; |
546 | } | 545 | } |
547 | 546 | ||
548 | static int __guestcopy(struct kvm_vcpu *vcpu, u64 guestdest, const void *from, | 547 | static int __guestcopy(struct kvm_vcpu *vcpu, u64 guestdest, void *from, |
549 | unsigned long n, int prefix) | 548 | unsigned long n, int prefix) |
550 | { | 549 | { |
551 | if (prefix) | 550 | if (prefix) |
@@ -562,7 +561,7 @@ static int __guestcopy(struct kvm_vcpu *vcpu, u64 guestdest, const void *from, | |||
562 | */ | 561 | */ |
563 | int kvm_s390_vcpu_store_status(struct kvm_vcpu *vcpu, unsigned long addr) | 562 | int kvm_s390_vcpu_store_status(struct kvm_vcpu *vcpu, unsigned long addr) |
564 | { | 563 | { |
565 | const unsigned char archmode = 1; | 564 | unsigned char archmode = 1; |
566 | int prefix; | 565 | int prefix; |
567 | 566 | ||
568 | if (addr == KVM_S390_STORE_STATUS_NOADDR) { | 567 | if (addr == KVM_S390_STORE_STATUS_NOADDR) { |
@@ -680,10 +679,10 @@ int kvm_arch_prepare_memory_region(struct kvm *kvm, | |||
680 | if (mem->guest_phys_addr) | 679 | if (mem->guest_phys_addr) |
681 | return -EINVAL; | 680 | return -EINVAL; |
682 | 681 | ||
683 | if (mem->userspace_addr & (PAGE_SIZE - 1)) | 682 | if (mem->userspace_addr & 0xffffful) |
684 | return -EINVAL; | 683 | return -EINVAL; |
685 | 684 | ||
686 | if (mem->memory_size & (PAGE_SIZE - 1)) | 685 | if (mem->memory_size & 0xffffful) |
687 | return -EINVAL; | 686 | return -EINVAL; |
688 | 687 | ||
689 | if (!user_alloc) | 688 | if (!user_alloc) |
@@ -697,15 +696,14 @@ void kvm_arch_commit_memory_region(struct kvm *kvm, | |||
697 | struct kvm_memory_slot old, | 696 | struct kvm_memory_slot old, |
698 | int user_alloc) | 697 | int user_alloc) |
699 | { | 698 | { |
700 | int i; | 699 | int rc; |
701 | struct kvm_vcpu *vcpu; | ||
702 | 700 | ||
703 | /* request update of sie control block for all available vcpus */ | 701 | |
704 | kvm_for_each_vcpu(i, vcpu, kvm) { | 702 | rc = gmap_map_segment(kvm->arch.gmap, mem->userspace_addr, |
705 | if (test_and_set_bit(KVM_REQ_MMU_RELOAD, &vcpu->requests)) | 703 | mem->guest_phys_addr, mem->memory_size); |
706 | continue; | 704 | if (rc) |
707 | kvm_s390_inject_sigp_stop(vcpu, ACTION_RELOADVCPU_ON_STOP); | 705 | printk(KERN_WARNING "kvm-s390: failed to commit memory region\n"); |
708 | } | 706 | return; |
709 | } | 707 | } |
710 | 708 | ||
711 | void kvm_arch_flush_shadow(struct kvm *kvm) | 709 | void kvm_arch_flush_shadow(struct kvm *kvm) |
diff --git a/arch/s390/kvm/kvm-s390.h b/arch/s390/kvm/kvm-s390.h index a7b7586626db..99b0b7597115 100644 --- a/arch/s390/kvm/kvm-s390.h +++ b/arch/s390/kvm/kvm-s390.h | |||
@@ -58,35 +58,9 @@ int kvm_s390_inject_vcpu(struct kvm_vcpu *vcpu, | |||
58 | int kvm_s390_inject_program_int(struct kvm_vcpu *vcpu, u16 code); | 58 | int kvm_s390_inject_program_int(struct kvm_vcpu *vcpu, u16 code); |
59 | int kvm_s390_inject_sigp_stop(struct kvm_vcpu *vcpu, int action); | 59 | int kvm_s390_inject_sigp_stop(struct kvm_vcpu *vcpu, int action); |
60 | 60 | ||
61 | static inline long kvm_s390_vcpu_get_memsize(struct kvm_vcpu *vcpu) | ||
62 | { | ||
63 | return vcpu->arch.sie_block->gmslm | ||
64 | - vcpu->arch.sie_block->gmsor | ||
65 | - VIRTIODESCSPACE + 1ul; | ||
66 | } | ||
67 | |||
68 | static inline void kvm_s390_vcpu_set_mem(struct kvm_vcpu *vcpu) | ||
69 | { | ||
70 | int idx; | ||
71 | struct kvm_memory_slot *mem; | ||
72 | struct kvm_memslots *memslots; | ||
73 | |||
74 | idx = srcu_read_lock(&vcpu->kvm->srcu); | ||
75 | memslots = kvm_memslots(vcpu->kvm); | ||
76 | |||
77 | mem = &memslots->memslots[0]; | ||
78 | |||
79 | vcpu->arch.sie_block->gmsor = mem->userspace_addr; | ||
80 | vcpu->arch.sie_block->gmslm = | ||
81 | mem->userspace_addr + | ||
82 | (mem->npages << PAGE_SHIFT) + | ||
83 | VIRTIODESCSPACE - 1ul; | ||
84 | |||
85 | srcu_read_unlock(&vcpu->kvm->srcu, idx); | ||
86 | } | ||
87 | |||
88 | /* implemented in priv.c */ | 61 | /* implemented in priv.c */ |
89 | int kvm_s390_handle_b2(struct kvm_vcpu *vcpu); | 62 | int kvm_s390_handle_b2(struct kvm_vcpu *vcpu); |
63 | int kvm_s390_handle_e5(struct kvm_vcpu *vcpu); | ||
90 | 64 | ||
91 | /* implemented in sigp.c */ | 65 | /* implemented in sigp.c */ |
92 | int kvm_s390_handle_sigp(struct kvm_vcpu *vcpu); | 66 | int kvm_s390_handle_sigp(struct kvm_vcpu *vcpu); |
diff --git a/arch/s390/kvm/priv.c b/arch/s390/kvm/priv.c index 73c47bd95db3..391626361084 100644 --- a/arch/s390/kvm/priv.c +++ b/arch/s390/kvm/priv.c | |||
@@ -326,3 +326,52 @@ int kvm_s390_handle_b2(struct kvm_vcpu *vcpu) | |||
326 | } | 326 | } |
327 | return -EOPNOTSUPP; | 327 | return -EOPNOTSUPP; |
328 | } | 328 | } |
329 | |||
330 | static int handle_tprot(struct kvm_vcpu *vcpu) | ||
331 | { | ||
332 | int base1 = (vcpu->arch.sie_block->ipb & 0xf0000000) >> 28; | ||
333 | int disp1 = (vcpu->arch.sie_block->ipb & 0x0fff0000) >> 16; | ||
334 | int base2 = (vcpu->arch.sie_block->ipb & 0xf000) >> 12; | ||
335 | int disp2 = vcpu->arch.sie_block->ipb & 0x0fff; | ||
336 | u64 address1 = disp1 + base1 ? vcpu->arch.guest_gprs[base1] : 0; | ||
337 | u64 address2 = disp2 + base2 ? vcpu->arch.guest_gprs[base2] : 0; | ||
338 | struct vm_area_struct *vma; | ||
339 | |||
340 | vcpu->stat.instruction_tprot++; | ||
341 | |||
342 | /* we only handle the Linux memory detection case: | ||
343 | * access key == 0 | ||
344 | * guest DAT == off | ||
345 | * everything else goes to userspace. */ | ||
346 | if (address2 & 0xf0) | ||
347 | return -EOPNOTSUPP; | ||
348 | if (vcpu->arch.sie_block->gpsw.mask & PSW_MASK_DAT) | ||
349 | return -EOPNOTSUPP; | ||
350 | |||
351 | |||
352 | down_read(¤t->mm->mmap_sem); | ||
353 | vma = find_vma(current->mm, | ||
354 | (unsigned long) __guestaddr_to_user(vcpu, address1)); | ||
355 | if (!vma) { | ||
356 | up_read(¤t->mm->mmap_sem); | ||
357 | return kvm_s390_inject_program_int(vcpu, PGM_ADDRESSING); | ||
358 | } | ||
359 | |||
360 | vcpu->arch.sie_block->gpsw.mask &= ~(3ul << 44); | ||
361 | if (!(vma->vm_flags & VM_WRITE) && (vma->vm_flags & VM_READ)) | ||
362 | vcpu->arch.sie_block->gpsw.mask |= (1ul << 44); | ||
363 | if (!(vma->vm_flags & VM_WRITE) && !(vma->vm_flags & VM_READ)) | ||
364 | vcpu->arch.sie_block->gpsw.mask |= (2ul << 44); | ||
365 | |||
366 | up_read(¤t->mm->mmap_sem); | ||
367 | return 0; | ||
368 | } | ||
369 | |||
370 | int kvm_s390_handle_e5(struct kvm_vcpu *vcpu) | ||
371 | { | ||
372 | /* For e5xx... instructions we only handle TPROT */ | ||
373 | if ((vcpu->arch.sie_block->ipa & 0x00ff) == 0x01) | ||
374 | return handle_tprot(vcpu); | ||
375 | return -EOPNOTSUPP; | ||
376 | } | ||
377 | |||
diff --git a/arch/s390/kvm/sie64a.S b/arch/s390/kvm/sie64a.S deleted file mode 100644 index 5faa1b1b23fa..000000000000 --- a/arch/s390/kvm/sie64a.S +++ /dev/null | |||
@@ -1,98 +0,0 @@ | |||
1 | /* | ||
2 | * sie64a.S - low level sie call | ||
3 | * | ||
4 | * Copyright IBM Corp. 2008,2010 | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License (version 2 only) | ||
8 | * as published by the Free Software Foundation. | ||
9 | * | ||
10 | * Author(s): Heiko Carstens <heiko.carstens@de.ibm.com> | ||
11 | * Christian Ehrhardt <ehrhardt@linux.vnet.ibm.com> | ||
12 | */ | ||
13 | |||
14 | #include <linux/errno.h> | ||
15 | #include <asm/asm-offsets.h> | ||
16 | #include <asm/setup.h> | ||
17 | #include <asm/asm-offsets.h> | ||
18 | #include <asm/ptrace.h> | ||
19 | #include <asm/thread_info.h> | ||
20 | |||
21 | _TIF_EXIT_SIE = (_TIF_SIGPENDING | _TIF_NEED_RESCHED | _TIF_MCCK_PENDING) | ||
22 | |||
23 | /* | ||
24 | * offsets into stackframe | ||
25 | * SP_ = offsets into stack sie64 is called with | ||
26 | * SPI_ = offsets into irq stack | ||
27 | */ | ||
28 | SP_GREGS = __SF_EMPTY | ||
29 | SP_HOOK = __SF_EMPTY+8 | ||
30 | SP_GPP = __SF_EMPTY+16 | ||
31 | SPI_PSW = STACK_FRAME_OVERHEAD + __PT_PSW | ||
32 | |||
33 | |||
34 | .macro SPP newpp | ||
35 | tm __LC_MACHINE_FLAGS+6,0x20 # MACHINE_FLAG_SPP | ||
36 | jz 0f | ||
37 | .insn s,0xb2800000,\newpp | ||
38 | 0: | ||
39 | .endm | ||
40 | |||
41 | sie_irq_handler: | ||
42 | SPP __LC_CMF_HPP # set host id | ||
43 | larl %r2,sie_inst | ||
44 | clg %r2,SPI_PSW+8(0,%r15) # intercepted sie | ||
45 | jne 1f | ||
46 | xc __LC_SIE_HOOK(8),__LC_SIE_HOOK | ||
47 | lg %r2,__LC_THREAD_INFO # pointer thread_info struct | ||
48 | tm __TI_flags+7(%r2),_TIF_EXIT_SIE | ||
49 | jz 0f | ||
50 | larl %r2,sie_exit # work pending, leave sie | ||
51 | stg %r2,SPI_PSW+8(0,%r15) | ||
52 | br %r14 | ||
53 | 0: larl %r2,sie_reenter # re-enter with guest id | ||
54 | stg %r2,SPI_PSW+8(0,%r15) | ||
55 | 1: br %r14 | ||
56 | |||
57 | /* | ||
58 | * sie64a calling convention: | ||
59 | * %r2 pointer to sie control block | ||
60 | * %r3 guest register save area | ||
61 | */ | ||
62 | .globl sie64a | ||
63 | sie64a: | ||
64 | stg %r3,SP_GREGS(%r15) # save guest register save area | ||
65 | stmg %r6,%r14,__SF_GPRS(%r15) # save registers on entry | ||
66 | lgr %r14,%r2 # pointer to sie control block | ||
67 | larl %r5,sie_irq_handler | ||
68 | stg %r2,SP_GPP(%r15) | ||
69 | stg %r5,SP_HOOK(%r15) # save hook target | ||
70 | lmg %r0,%r13,0(%r3) # load guest gprs 0-13 | ||
71 | sie_reenter: | ||
72 | mvc __LC_SIE_HOOK(8),SP_HOOK(%r15) | ||
73 | SPP SP_GPP(%r15) # set guest id | ||
74 | sie_inst: | ||
75 | sie 0(%r14) | ||
76 | xc __LC_SIE_HOOK(8),__LC_SIE_HOOK | ||
77 | SPP __LC_CMF_HPP # set host id | ||
78 | sie_exit: | ||
79 | lg %r14,SP_GREGS(%r15) | ||
80 | stmg %r0,%r13,0(%r14) # save guest gprs 0-13 | ||
81 | lghi %r2,0 | ||
82 | lmg %r6,%r14,__SF_GPRS(%r15) | ||
83 | br %r14 | ||
84 | |||
85 | sie_err: | ||
86 | xc __LC_SIE_HOOK(8),__LC_SIE_HOOK | ||
87 | SPP __LC_CMF_HPP # set host id | ||
88 | lg %r14,SP_GREGS(%r15) | ||
89 | stmg %r0,%r13,0(%r14) # save guest gprs 0-13 | ||
90 | lghi %r2,-EFAULT | ||
91 | lmg %r6,%r14,__SF_GPRS(%r15) | ||
92 | br %r14 | ||
93 | |||
94 | .section __ex_table,"a" | ||
95 | .quad sie_inst,sie_err | ||
96 | .quad sie_exit,sie_err | ||
97 | .quad sie_reenter,sie_err | ||
98 | .previous | ||
diff --git a/arch/s390/kvm/sigp.c b/arch/s390/kvm/sigp.c index 702276f5e2fa..d6a50c1fb2e6 100644 --- a/arch/s390/kvm/sigp.c +++ b/arch/s390/kvm/sigp.c | |||
@@ -189,10 +189,8 @@ static int __sigp_set_prefix(struct kvm_vcpu *vcpu, u16 cpu_addr, u32 address, | |||
189 | 189 | ||
190 | /* make sure that the new value is valid memory */ | 190 | /* make sure that the new value is valid memory */ |
191 | address = address & 0x7fffe000u; | 191 | address = address & 0x7fffe000u; |
192 | if ((copy_from_user(&tmp, (void __user *) | 192 | if (copy_from_guest_absolute(vcpu, &tmp, address, 1) || |
193 | (address + vcpu->arch.sie_block->gmsor) , 1)) || | 193 | copy_from_guest_absolute(vcpu, &tmp, address + PAGE_SIZE, 1)) { |
194 | (copy_from_user(&tmp, (void __user *)(address + | ||
195 | vcpu->arch.sie_block->gmsor + PAGE_SIZE), 1))) { | ||
196 | *reg |= SIGP_STAT_INVALID_PARAMETER; | 194 | *reg |= SIGP_STAT_INVALID_PARAMETER; |
197 | return 1; /* invalid parameter */ | 195 | return 1; /* invalid parameter */ |
198 | } | 196 | } |
diff --git a/arch/s390/lib/qrnnd.S b/arch/s390/lib/qrnnd.S index eb1df632e749..d321329130ec 100644 --- a/arch/s390/lib/qrnnd.S +++ b/arch/s390/lib/qrnnd.S | |||
@@ -1,5 +1,7 @@ | |||
1 | # S/390 __udiv_qrnnd | 1 | # S/390 __udiv_qrnnd |
2 | 2 | ||
3 | #include <linux/linkage.h> | ||
4 | |||
3 | # r2 : &__r | 5 | # r2 : &__r |
4 | # r3 : upper half of 64 bit word n | 6 | # r3 : upper half of 64 bit word n |
5 | # r4 : lower half of 64 bit word n | 7 | # r4 : lower half of 64 bit word n |
@@ -8,8 +10,7 @@ | |||
8 | # the quotient q is to be returned | 10 | # the quotient q is to be returned |
9 | 11 | ||
10 | .text | 12 | .text |
11 | .globl __udiv_qrnnd | 13 | ENTRY(__udiv_qrnnd) |
12 | __udiv_qrnnd: | ||
13 | st %r2,24(%r15) # store pointer to reminder for later | 14 | st %r2,24(%r15) # store pointer to reminder for later |
14 | lr %r0,%r3 # reload n | 15 | lr %r0,%r3 # reload n |
15 | lr %r1,%r4 | 16 | lr %r1,%r4 |
diff --git a/arch/s390/mm/fault.c b/arch/s390/mm/fault.c index 095f782a5512..9564fc779b27 100644 --- a/arch/s390/mm/fault.c +++ b/arch/s390/mm/fault.c | |||
@@ -303,9 +303,24 @@ static inline int do_exception(struct pt_regs *regs, int access, | |||
303 | flags = FAULT_FLAG_ALLOW_RETRY; | 303 | flags = FAULT_FLAG_ALLOW_RETRY; |
304 | if (access == VM_WRITE || (trans_exc_code & store_indication) == 0x400) | 304 | if (access == VM_WRITE || (trans_exc_code & store_indication) == 0x400) |
305 | flags |= FAULT_FLAG_WRITE; | 305 | flags |= FAULT_FLAG_WRITE; |
306 | retry: | ||
307 | down_read(&mm->mmap_sem); | 306 | down_read(&mm->mmap_sem); |
308 | 307 | ||
308 | #ifdef CONFIG_PGSTE | ||
309 | if (test_tsk_thread_flag(current, TIF_SIE) && S390_lowcore.gmap) { | ||
310 | address = gmap_fault(address, | ||
311 | (struct gmap *) S390_lowcore.gmap); | ||
312 | if (address == -EFAULT) { | ||
313 | fault = VM_FAULT_BADMAP; | ||
314 | goto out_up; | ||
315 | } | ||
316 | if (address == -ENOMEM) { | ||
317 | fault = VM_FAULT_OOM; | ||
318 | goto out_up; | ||
319 | } | ||
320 | } | ||
321 | #endif | ||
322 | |||
323 | retry: | ||
309 | fault = VM_FAULT_BADMAP; | 324 | fault = VM_FAULT_BADMAP; |
310 | vma = find_vma(mm, address); | 325 | vma = find_vma(mm, address); |
311 | if (!vma) | 326 | if (!vma) |
@@ -356,6 +371,7 @@ retry: | |||
356 | /* Clear FAULT_FLAG_ALLOW_RETRY to avoid any risk | 371 | /* Clear FAULT_FLAG_ALLOW_RETRY to avoid any risk |
357 | * of starvation. */ | 372 | * of starvation. */ |
358 | flags &= ~FAULT_FLAG_ALLOW_RETRY; | 373 | flags &= ~FAULT_FLAG_ALLOW_RETRY; |
374 | down_read(&mm->mmap_sem); | ||
359 | goto retry; | 375 | goto retry; |
360 | } | 376 | } |
361 | } | 377 | } |
diff --git a/arch/s390/mm/hugetlbpage.c b/arch/s390/mm/hugetlbpage.c index a4d856db9154..597bb2d27c3c 100644 --- a/arch/s390/mm/hugetlbpage.c +++ b/arch/s390/mm/hugetlbpage.c | |||
@@ -35,7 +35,7 @@ int arch_prepare_hugepage(struct page *page) | |||
35 | if (MACHINE_HAS_HPAGE) | 35 | if (MACHINE_HAS_HPAGE) |
36 | return 0; | 36 | return 0; |
37 | 37 | ||
38 | ptep = (pte_t *) pte_alloc_one(&init_mm, address); | 38 | ptep = (pte_t *) pte_alloc_one(&init_mm, addr); |
39 | if (!ptep) | 39 | if (!ptep) |
40 | return -ENOMEM; | 40 | return -ENOMEM; |
41 | 41 | ||
diff --git a/arch/s390/mm/pgtable.c b/arch/s390/mm/pgtable.c index 37a23c223705..2adb23938a7f 100644 --- a/arch/s390/mm/pgtable.c +++ b/arch/s390/mm/pgtable.c | |||
@@ -16,6 +16,7 @@ | |||
16 | #include <linux/module.h> | 16 | #include <linux/module.h> |
17 | #include <linux/quicklist.h> | 17 | #include <linux/quicklist.h> |
18 | #include <linux/rcupdate.h> | 18 | #include <linux/rcupdate.h> |
19 | #include <linux/slab.h> | ||
19 | 20 | ||
20 | #include <asm/system.h> | 21 | #include <asm/system.h> |
21 | #include <asm/pgtable.h> | 22 | #include <asm/pgtable.h> |
@@ -133,30 +134,374 @@ void crst_table_downgrade(struct mm_struct *mm, unsigned long limit) | |||
133 | } | 134 | } |
134 | #endif | 135 | #endif |
135 | 136 | ||
136 | static inline unsigned int atomic_xor_bits(atomic_t *v, unsigned int bits) | 137 | #ifdef CONFIG_PGSTE |
138 | |||
139 | /** | ||
140 | * gmap_alloc - allocate a guest address space | ||
141 | * @mm: pointer to the parent mm_struct | ||
142 | * | ||
143 | * Returns a guest address space structure. | ||
144 | */ | ||
145 | struct gmap *gmap_alloc(struct mm_struct *mm) | ||
137 | { | 146 | { |
138 | unsigned int old, new; | 147 | struct gmap *gmap; |
148 | struct page *page; | ||
149 | unsigned long *table; | ||
139 | 150 | ||
140 | do { | 151 | gmap = kzalloc(sizeof(struct gmap), GFP_KERNEL); |
141 | old = atomic_read(v); | 152 | if (!gmap) |
142 | new = old ^ bits; | 153 | goto out; |
143 | } while (atomic_cmpxchg(v, old, new) != old); | 154 | INIT_LIST_HEAD(&gmap->crst_list); |
144 | return new; | 155 | gmap->mm = mm; |
156 | page = alloc_pages(GFP_KERNEL, ALLOC_ORDER); | ||
157 | if (!page) | ||
158 | goto out_free; | ||
159 | list_add(&page->lru, &gmap->crst_list); | ||
160 | table = (unsigned long *) page_to_phys(page); | ||
161 | crst_table_init(table, _REGION1_ENTRY_EMPTY); | ||
162 | gmap->table = table; | ||
163 | list_add(&gmap->list, &mm->context.gmap_list); | ||
164 | return gmap; | ||
165 | |||
166 | out_free: | ||
167 | kfree(gmap); | ||
168 | out: | ||
169 | return NULL; | ||
145 | } | 170 | } |
171 | EXPORT_SYMBOL_GPL(gmap_alloc); | ||
146 | 172 | ||
147 | /* | 173 | static int gmap_unlink_segment(struct gmap *gmap, unsigned long *table) |
148 | * page table entry allocation/free routines. | 174 | { |
175 | struct gmap_pgtable *mp; | ||
176 | struct gmap_rmap *rmap; | ||
177 | struct page *page; | ||
178 | |||
179 | if (*table & _SEGMENT_ENTRY_INV) | ||
180 | return 0; | ||
181 | page = pfn_to_page(*table >> PAGE_SHIFT); | ||
182 | mp = (struct gmap_pgtable *) page->index; | ||
183 | list_for_each_entry(rmap, &mp->mapper, list) { | ||
184 | if (rmap->entry != table) | ||
185 | continue; | ||
186 | list_del(&rmap->list); | ||
187 | kfree(rmap); | ||
188 | break; | ||
189 | } | ||
190 | *table = _SEGMENT_ENTRY_INV | _SEGMENT_ENTRY_RO | mp->vmaddr; | ||
191 | return 1; | ||
192 | } | ||
193 | |||
194 | static void gmap_flush_tlb(struct gmap *gmap) | ||
195 | { | ||
196 | if (MACHINE_HAS_IDTE) | ||
197 | __tlb_flush_idte((unsigned long) gmap->table | | ||
198 | _ASCE_TYPE_REGION1); | ||
199 | else | ||
200 | __tlb_flush_global(); | ||
201 | } | ||
202 | |||
203 | /** | ||
204 | * gmap_free - free a guest address space | ||
205 | * @gmap: pointer to the guest address space structure | ||
149 | */ | 206 | */ |
150 | #ifdef CONFIG_PGSTE | 207 | void gmap_free(struct gmap *gmap) |
151 | static inline unsigned long *page_table_alloc_pgste(struct mm_struct *mm) | 208 | { |
209 | struct page *page, *next; | ||
210 | unsigned long *table; | ||
211 | int i; | ||
212 | |||
213 | |||
214 | /* Flush tlb. */ | ||
215 | if (MACHINE_HAS_IDTE) | ||
216 | __tlb_flush_idte((unsigned long) gmap->table | | ||
217 | _ASCE_TYPE_REGION1); | ||
218 | else | ||
219 | __tlb_flush_global(); | ||
220 | |||
221 | /* Free all segment & region tables. */ | ||
222 | down_read(&gmap->mm->mmap_sem); | ||
223 | list_for_each_entry_safe(page, next, &gmap->crst_list, lru) { | ||
224 | table = (unsigned long *) page_to_phys(page); | ||
225 | if ((*table & _REGION_ENTRY_TYPE_MASK) == 0) | ||
226 | /* Remove gmap rmap structures for segment table. */ | ||
227 | for (i = 0; i < PTRS_PER_PMD; i++, table++) | ||
228 | gmap_unlink_segment(gmap, table); | ||
229 | __free_pages(page, ALLOC_ORDER); | ||
230 | } | ||
231 | up_read(&gmap->mm->mmap_sem); | ||
232 | list_del(&gmap->list); | ||
233 | kfree(gmap); | ||
234 | } | ||
235 | EXPORT_SYMBOL_GPL(gmap_free); | ||
236 | |||
237 | /** | ||
238 | * gmap_enable - switch primary space to the guest address space | ||
239 | * @gmap: pointer to the guest address space structure | ||
240 | */ | ||
241 | void gmap_enable(struct gmap *gmap) | ||
242 | { | ||
243 | /* Load primary space page table origin. */ | ||
244 | S390_lowcore.user_asce = _ASCE_TYPE_REGION1 | _ASCE_TABLE_LENGTH | | ||
245 | _ASCE_USER_BITS | __pa(gmap->table); | ||
246 | asm volatile("lctlg 1,1,%0\n" : : "m" (S390_lowcore.user_asce) ); | ||
247 | S390_lowcore.gmap = (unsigned long) gmap; | ||
248 | } | ||
249 | EXPORT_SYMBOL_GPL(gmap_enable); | ||
250 | |||
251 | /** | ||
252 | * gmap_disable - switch back to the standard primary address space | ||
253 | * @gmap: pointer to the guest address space structure | ||
254 | */ | ||
255 | void gmap_disable(struct gmap *gmap) | ||
256 | { | ||
257 | /* Load primary space page table origin. */ | ||
258 | S390_lowcore.user_asce = | ||
259 | gmap->mm->context.asce_bits | __pa(gmap->mm->pgd); | ||
260 | asm volatile("lctlg 1,1,%0\n" : : "m" (S390_lowcore.user_asce) ); | ||
261 | S390_lowcore.gmap = 0UL; | ||
262 | } | ||
263 | EXPORT_SYMBOL_GPL(gmap_disable); | ||
264 | |||
265 | static int gmap_alloc_table(struct gmap *gmap, | ||
266 | unsigned long *table, unsigned long init) | ||
267 | { | ||
268 | struct page *page; | ||
269 | unsigned long *new; | ||
270 | |||
271 | page = alloc_pages(GFP_KERNEL, ALLOC_ORDER); | ||
272 | if (!page) | ||
273 | return -ENOMEM; | ||
274 | new = (unsigned long *) page_to_phys(page); | ||
275 | crst_table_init(new, init); | ||
276 | down_read(&gmap->mm->mmap_sem); | ||
277 | if (*table & _REGION_ENTRY_INV) { | ||
278 | list_add(&page->lru, &gmap->crst_list); | ||
279 | *table = (unsigned long) new | _REGION_ENTRY_LENGTH | | ||
280 | (*table & _REGION_ENTRY_TYPE_MASK); | ||
281 | } else | ||
282 | __free_pages(page, ALLOC_ORDER); | ||
283 | up_read(&gmap->mm->mmap_sem); | ||
284 | return 0; | ||
285 | } | ||
286 | |||
287 | /** | ||
288 | * gmap_unmap_segment - unmap segment from the guest address space | ||
289 | * @gmap: pointer to the guest address space structure | ||
290 | * @addr: address in the guest address space | ||
291 | * @len: length of the memory area to unmap | ||
292 | * | ||
293 | * Returns 0 if the unmap succeded, -EINVAL if not. | ||
294 | */ | ||
295 | int gmap_unmap_segment(struct gmap *gmap, unsigned long to, unsigned long len) | ||
296 | { | ||
297 | unsigned long *table; | ||
298 | unsigned long off; | ||
299 | int flush; | ||
300 | |||
301 | if ((to | len) & (PMD_SIZE - 1)) | ||
302 | return -EINVAL; | ||
303 | if (len == 0 || to + len < to) | ||
304 | return -EINVAL; | ||
305 | |||
306 | flush = 0; | ||
307 | down_read(&gmap->mm->mmap_sem); | ||
308 | for (off = 0; off < len; off += PMD_SIZE) { | ||
309 | /* Walk the guest addr space page table */ | ||
310 | table = gmap->table + (((to + off) >> 53) & 0x7ff); | ||
311 | if (*table & _REGION_ENTRY_INV) | ||
312 | return 0; | ||
313 | table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); | ||
314 | table = table + (((to + off) >> 42) & 0x7ff); | ||
315 | if (*table & _REGION_ENTRY_INV) | ||
316 | return 0; | ||
317 | table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); | ||
318 | table = table + (((to + off) >> 31) & 0x7ff); | ||
319 | if (*table & _REGION_ENTRY_INV) | ||
320 | return 0; | ||
321 | table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); | ||
322 | table = table + (((to + off) >> 20) & 0x7ff); | ||
323 | |||
324 | /* Clear segment table entry in guest address space. */ | ||
325 | flush |= gmap_unlink_segment(gmap, table); | ||
326 | *table = _SEGMENT_ENTRY_INV; | ||
327 | } | ||
328 | up_read(&gmap->mm->mmap_sem); | ||
329 | if (flush) | ||
330 | gmap_flush_tlb(gmap); | ||
331 | return 0; | ||
332 | } | ||
333 | EXPORT_SYMBOL_GPL(gmap_unmap_segment); | ||
334 | |||
335 | /** | ||
336 | * gmap_mmap_segment - map a segment to the guest address space | ||
337 | * @gmap: pointer to the guest address space structure | ||
338 | * @from: source address in the parent address space | ||
339 | * @to: target address in the guest address space | ||
340 | * | ||
341 | * Returns 0 if the mmap succeded, -EINVAL or -ENOMEM if not. | ||
342 | */ | ||
343 | int gmap_map_segment(struct gmap *gmap, unsigned long from, | ||
344 | unsigned long to, unsigned long len) | ||
345 | { | ||
346 | unsigned long *table; | ||
347 | unsigned long off; | ||
348 | int flush; | ||
349 | |||
350 | if ((from | to | len) & (PMD_SIZE - 1)) | ||
351 | return -EINVAL; | ||
352 | if (len == 0 || from + len > PGDIR_SIZE || | ||
353 | from + len < from || to + len < to) | ||
354 | return -EINVAL; | ||
355 | |||
356 | flush = 0; | ||
357 | down_read(&gmap->mm->mmap_sem); | ||
358 | for (off = 0; off < len; off += PMD_SIZE) { | ||
359 | /* Walk the gmap address space page table */ | ||
360 | table = gmap->table + (((to + off) >> 53) & 0x7ff); | ||
361 | if ((*table & _REGION_ENTRY_INV) && | ||
362 | gmap_alloc_table(gmap, table, _REGION2_ENTRY_EMPTY)) | ||
363 | goto out_unmap; | ||
364 | table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); | ||
365 | table = table + (((to + off) >> 42) & 0x7ff); | ||
366 | if ((*table & _REGION_ENTRY_INV) && | ||
367 | gmap_alloc_table(gmap, table, _REGION3_ENTRY_EMPTY)) | ||
368 | goto out_unmap; | ||
369 | table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); | ||
370 | table = table + (((to + off) >> 31) & 0x7ff); | ||
371 | if ((*table & _REGION_ENTRY_INV) && | ||
372 | gmap_alloc_table(gmap, table, _SEGMENT_ENTRY_EMPTY)) | ||
373 | goto out_unmap; | ||
374 | table = (unsigned long *) (*table & _REGION_ENTRY_ORIGIN); | ||
375 | table = table + (((to + off) >> 20) & 0x7ff); | ||
376 | |||
377 | /* Store 'from' address in an invalid segment table entry. */ | ||
378 | flush |= gmap_unlink_segment(gmap, table); | ||
379 | *table = _SEGMENT_ENTRY_INV | _SEGMENT_ENTRY_RO | (from + off); | ||
380 | } | ||
381 | up_read(&gmap->mm->mmap_sem); | ||
382 | if (flush) | ||
383 | gmap_flush_tlb(gmap); | ||
384 | return 0; | ||
385 | |||
386 | out_unmap: | ||
387 | up_read(&gmap->mm->mmap_sem); | ||
388 | gmap_unmap_segment(gmap, to, len); | ||
389 | return -ENOMEM; | ||
390 | } | ||
391 | EXPORT_SYMBOL_GPL(gmap_map_segment); | ||
392 | |||
393 | unsigned long gmap_fault(unsigned long address, struct gmap *gmap) | ||
394 | { | ||
395 | unsigned long *table, vmaddr, segment; | ||
396 | struct mm_struct *mm; | ||
397 | struct gmap_pgtable *mp; | ||
398 | struct gmap_rmap *rmap; | ||
399 | struct vm_area_struct *vma; | ||
400 | struct page *page; | ||
401 | pgd_t *pgd; | ||
402 | pud_t *pud; | ||
403 | pmd_t *pmd; | ||
404 | |||
405 | current->thread.gmap_addr = address; | ||
406 | mm = gmap->mm; | ||
407 | /* Walk the gmap address space page table */ | ||
408 | table = gmap->table + ((address >> 53) & 0x7ff); | ||
409 | if (unlikely(*table & _REGION_ENTRY_INV)) | ||
410 | return -EFAULT; | ||
411 | table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); | ||
412 | table = table + ((address >> 42) & 0x7ff); | ||
413 | if (unlikely(*table & _REGION_ENTRY_INV)) | ||
414 | return -EFAULT; | ||
415 | table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); | ||
416 | table = table + ((address >> 31) & 0x7ff); | ||
417 | if (unlikely(*table & _REGION_ENTRY_INV)) | ||
418 | return -EFAULT; | ||
419 | table = (unsigned long *)(*table & _REGION_ENTRY_ORIGIN); | ||
420 | table = table + ((address >> 20) & 0x7ff); | ||
421 | |||
422 | /* Convert the gmap address to an mm address. */ | ||
423 | segment = *table; | ||
424 | if (likely(!(segment & _SEGMENT_ENTRY_INV))) { | ||
425 | page = pfn_to_page(segment >> PAGE_SHIFT); | ||
426 | mp = (struct gmap_pgtable *) page->index; | ||
427 | return mp->vmaddr | (address & ~PMD_MASK); | ||
428 | } else if (segment & _SEGMENT_ENTRY_RO) { | ||
429 | vmaddr = segment & _SEGMENT_ENTRY_ORIGIN; | ||
430 | vma = find_vma(mm, vmaddr); | ||
431 | if (!vma || vma->vm_start > vmaddr) | ||
432 | return -EFAULT; | ||
433 | |||
434 | /* Walk the parent mm page table */ | ||
435 | pgd = pgd_offset(mm, vmaddr); | ||
436 | pud = pud_alloc(mm, pgd, vmaddr); | ||
437 | if (!pud) | ||
438 | return -ENOMEM; | ||
439 | pmd = pmd_alloc(mm, pud, vmaddr); | ||
440 | if (!pmd) | ||
441 | return -ENOMEM; | ||
442 | if (!pmd_present(*pmd) && | ||
443 | __pte_alloc(mm, vma, pmd, vmaddr)) | ||
444 | return -ENOMEM; | ||
445 | /* pmd now points to a valid segment table entry. */ | ||
446 | rmap = kmalloc(sizeof(*rmap), GFP_KERNEL|__GFP_REPEAT); | ||
447 | if (!rmap) | ||
448 | return -ENOMEM; | ||
449 | /* Link gmap segment table entry location to page table. */ | ||
450 | page = pmd_page(*pmd); | ||
451 | mp = (struct gmap_pgtable *) page->index; | ||
452 | rmap->entry = table; | ||
453 | list_add(&rmap->list, &mp->mapper); | ||
454 | /* Set gmap segment table entry to page table. */ | ||
455 | *table = pmd_val(*pmd) & PAGE_MASK; | ||
456 | return vmaddr | (address & ~PMD_MASK); | ||
457 | } | ||
458 | return -EFAULT; | ||
459 | |||
460 | } | ||
461 | EXPORT_SYMBOL_GPL(gmap_fault); | ||
462 | |||
463 | void gmap_unmap_notifier(struct mm_struct *mm, unsigned long *table) | ||
464 | { | ||
465 | struct gmap_rmap *rmap, *next; | ||
466 | struct gmap_pgtable *mp; | ||
467 | struct page *page; | ||
468 | int flush; | ||
469 | |||
470 | flush = 0; | ||
471 | spin_lock(&mm->page_table_lock); | ||
472 | page = pfn_to_page(__pa(table) >> PAGE_SHIFT); | ||
473 | mp = (struct gmap_pgtable *) page->index; | ||
474 | list_for_each_entry_safe(rmap, next, &mp->mapper, list) { | ||
475 | *rmap->entry = | ||
476 | _SEGMENT_ENTRY_INV | _SEGMENT_ENTRY_RO | mp->vmaddr; | ||
477 | list_del(&rmap->list); | ||
478 | kfree(rmap); | ||
479 | flush = 1; | ||
480 | } | ||
481 | spin_unlock(&mm->page_table_lock); | ||
482 | if (flush) | ||
483 | __tlb_flush_global(); | ||
484 | } | ||
485 | |||
486 | static inline unsigned long *page_table_alloc_pgste(struct mm_struct *mm, | ||
487 | unsigned long vmaddr) | ||
152 | { | 488 | { |
153 | struct page *page; | 489 | struct page *page; |
154 | unsigned long *table; | 490 | unsigned long *table; |
491 | struct gmap_pgtable *mp; | ||
155 | 492 | ||
156 | page = alloc_page(GFP_KERNEL|__GFP_REPEAT); | 493 | page = alloc_page(GFP_KERNEL|__GFP_REPEAT); |
157 | if (!page) | 494 | if (!page) |
158 | return NULL; | 495 | return NULL; |
496 | mp = kmalloc(sizeof(*mp), GFP_KERNEL|__GFP_REPEAT); | ||
497 | if (!mp) { | ||
498 | __free_page(page); | ||
499 | return NULL; | ||
500 | } | ||
159 | pgtable_page_ctor(page); | 501 | pgtable_page_ctor(page); |
502 | mp->vmaddr = vmaddr & PMD_MASK; | ||
503 | INIT_LIST_HEAD(&mp->mapper); | ||
504 | page->index = (unsigned long) mp; | ||
160 | atomic_set(&page->_mapcount, 3); | 505 | atomic_set(&page->_mapcount, 3); |
161 | table = (unsigned long *) page_to_phys(page); | 506 | table = (unsigned long *) page_to_phys(page); |
162 | clear_table(table, _PAGE_TYPE_EMPTY, PAGE_SIZE/2); | 507 | clear_table(table, _PAGE_TYPE_EMPTY, PAGE_SIZE/2); |
@@ -167,24 +512,57 @@ static inline unsigned long *page_table_alloc_pgste(struct mm_struct *mm) | |||
167 | static inline void page_table_free_pgste(unsigned long *table) | 512 | static inline void page_table_free_pgste(unsigned long *table) |
168 | { | 513 | { |
169 | struct page *page; | 514 | struct page *page; |
515 | struct gmap_pgtable *mp; | ||
170 | 516 | ||
171 | page = pfn_to_page(__pa(table) >> PAGE_SHIFT); | 517 | page = pfn_to_page(__pa(table) >> PAGE_SHIFT); |
518 | mp = (struct gmap_pgtable *) page->index; | ||
519 | BUG_ON(!list_empty(&mp->mapper)); | ||
172 | pgtable_page_ctor(page); | 520 | pgtable_page_ctor(page); |
173 | atomic_set(&page->_mapcount, -1); | 521 | atomic_set(&page->_mapcount, -1); |
522 | kfree(mp); | ||
174 | __free_page(page); | 523 | __free_page(page); |
175 | } | 524 | } |
176 | #endif | ||
177 | 525 | ||
178 | unsigned long *page_table_alloc(struct mm_struct *mm) | 526 | #else /* CONFIG_PGSTE */ |
527 | |||
528 | static inline unsigned long *page_table_alloc_pgste(struct mm_struct *mm, | ||
529 | unsigned long vmaddr) | ||
530 | { | ||
531 | } | ||
532 | |||
533 | static inline void page_table_free_pgste(unsigned long *table) | ||
534 | { | ||
535 | } | ||
536 | |||
537 | static inline void gmap_unmap_notifier(struct mm_struct *mm, | ||
538 | unsigned long *table) | ||
539 | { | ||
540 | } | ||
541 | |||
542 | #endif /* CONFIG_PGSTE */ | ||
543 | |||
544 | static inline unsigned int atomic_xor_bits(atomic_t *v, unsigned int bits) | ||
545 | { | ||
546 | unsigned int old, new; | ||
547 | |||
548 | do { | ||
549 | old = atomic_read(v); | ||
550 | new = old ^ bits; | ||
551 | } while (atomic_cmpxchg(v, old, new) != old); | ||
552 | return new; | ||
553 | } | ||
554 | |||
555 | /* | ||
556 | * page table entry allocation/free routines. | ||
557 | */ | ||
558 | unsigned long *page_table_alloc(struct mm_struct *mm, unsigned long vmaddr) | ||
179 | { | 559 | { |
180 | struct page *page; | 560 | struct page *page; |
181 | unsigned long *table; | 561 | unsigned long *table; |
182 | unsigned int mask, bit; | 562 | unsigned int mask, bit; |
183 | 563 | ||
184 | #ifdef CONFIG_PGSTE | ||
185 | if (mm_has_pgste(mm)) | 564 | if (mm_has_pgste(mm)) |
186 | return page_table_alloc_pgste(mm); | 565 | return page_table_alloc_pgste(mm, vmaddr); |
187 | #endif | ||
188 | /* Allocate fragments of a 4K page as 1K/2K page table */ | 566 | /* Allocate fragments of a 4K page as 1K/2K page table */ |
189 | spin_lock_bh(&mm->context.list_lock); | 567 | spin_lock_bh(&mm->context.list_lock); |
190 | mask = FRAG_MASK; | 568 | mask = FRAG_MASK; |
@@ -222,10 +600,10 @@ void page_table_free(struct mm_struct *mm, unsigned long *table) | |||
222 | struct page *page; | 600 | struct page *page; |
223 | unsigned int bit, mask; | 601 | unsigned int bit, mask; |
224 | 602 | ||
225 | #ifdef CONFIG_PGSTE | 603 | if (mm_has_pgste(mm)) { |
226 | if (mm_has_pgste(mm)) | 604 | gmap_unmap_notifier(mm, table); |
227 | return page_table_free_pgste(table); | 605 | return page_table_free_pgste(table); |
228 | #endif | 606 | } |
229 | /* Free 1K/2K page table fragment of a 4K page */ | 607 | /* Free 1K/2K page table fragment of a 4K page */ |
230 | page = pfn_to_page(__pa(table) >> PAGE_SHIFT); | 608 | page = pfn_to_page(__pa(table) >> PAGE_SHIFT); |
231 | bit = 1 << ((__pa(table) & ~PAGE_MASK)/(PTRS_PER_PTE*sizeof(pte_t))); | 609 | bit = 1 << ((__pa(table) & ~PAGE_MASK)/(PTRS_PER_PTE*sizeof(pte_t))); |
@@ -249,10 +627,8 @@ static void __page_table_free_rcu(void *table, unsigned bit) | |||
249 | { | 627 | { |
250 | struct page *page; | 628 | struct page *page; |
251 | 629 | ||
252 | #ifdef CONFIG_PGSTE | ||
253 | if (bit == FRAG_MASK) | 630 | if (bit == FRAG_MASK) |
254 | return page_table_free_pgste(table); | 631 | return page_table_free_pgste(table); |
255 | #endif | ||
256 | /* Free 1K/2K page table fragment of a 4K page */ | 632 | /* Free 1K/2K page table fragment of a 4K page */ |
257 | page = pfn_to_page(__pa(table) >> PAGE_SHIFT); | 633 | page = pfn_to_page(__pa(table) >> PAGE_SHIFT); |
258 | if (atomic_xor_bits(&page->_mapcount, bit) == 0) { | 634 | if (atomic_xor_bits(&page->_mapcount, bit) == 0) { |
@@ -269,13 +645,12 @@ void page_table_free_rcu(struct mmu_gather *tlb, unsigned long *table) | |||
269 | unsigned int bit, mask; | 645 | unsigned int bit, mask; |
270 | 646 | ||
271 | mm = tlb->mm; | 647 | mm = tlb->mm; |
272 | #ifdef CONFIG_PGSTE | ||
273 | if (mm_has_pgste(mm)) { | 648 | if (mm_has_pgste(mm)) { |
649 | gmap_unmap_notifier(mm, table); | ||
274 | table = (unsigned long *) (__pa(table) | FRAG_MASK); | 650 | table = (unsigned long *) (__pa(table) | FRAG_MASK); |
275 | tlb_remove_table(tlb, table); | 651 | tlb_remove_table(tlb, table); |
276 | return; | 652 | return; |
277 | } | 653 | } |
278 | #endif | ||
279 | bit = 1 << ((__pa(table) & ~PAGE_MASK) / (PTRS_PER_PTE*sizeof(pte_t))); | 654 | bit = 1 << ((__pa(table) & ~PAGE_MASK) / (PTRS_PER_PTE*sizeof(pte_t))); |
280 | page = pfn_to_page(__pa(table) >> PAGE_SHIFT); | 655 | page = pfn_to_page(__pa(table) >> PAGE_SHIFT); |
281 | spin_lock_bh(&mm->context.list_lock); | 656 | spin_lock_bh(&mm->context.list_lock); |
diff --git a/arch/s390/mm/vmem.c b/arch/s390/mm/vmem.c index 8c1970d1dd91..781ff5169560 100644 --- a/arch/s390/mm/vmem.c +++ b/arch/s390/mm/vmem.c | |||
@@ -61,12 +61,12 @@ static inline pmd_t *vmem_pmd_alloc(void) | |||
61 | return pmd; | 61 | return pmd; |
62 | } | 62 | } |
63 | 63 | ||
64 | static pte_t __ref *vmem_pte_alloc(void) | 64 | static pte_t __ref *vmem_pte_alloc(unsigned long address) |
65 | { | 65 | { |
66 | pte_t *pte; | 66 | pte_t *pte; |
67 | 67 | ||
68 | if (slab_is_available()) | 68 | if (slab_is_available()) |
69 | pte = (pte_t *) page_table_alloc(&init_mm); | 69 | pte = (pte_t *) page_table_alloc(&init_mm, address); |
70 | else | 70 | else |
71 | pte = alloc_bootmem(PTRS_PER_PTE * sizeof(pte_t)); | 71 | pte = alloc_bootmem(PTRS_PER_PTE * sizeof(pte_t)); |
72 | if (!pte) | 72 | if (!pte) |
@@ -120,7 +120,7 @@ static int vmem_add_mem(unsigned long start, unsigned long size, int ro) | |||
120 | } | 120 | } |
121 | #endif | 121 | #endif |
122 | if (pmd_none(*pm_dir)) { | 122 | if (pmd_none(*pm_dir)) { |
123 | pt_dir = vmem_pte_alloc(); | 123 | pt_dir = vmem_pte_alloc(address); |
124 | if (!pt_dir) | 124 | if (!pt_dir) |
125 | goto out; | 125 | goto out; |
126 | pmd_populate(&init_mm, pm_dir, pt_dir); | 126 | pmd_populate(&init_mm, pm_dir, pt_dir); |
@@ -205,7 +205,7 @@ int __meminit vmemmap_populate(struct page *start, unsigned long nr, int node) | |||
205 | 205 | ||
206 | pm_dir = pmd_offset(pu_dir, address); | 206 | pm_dir = pmd_offset(pu_dir, address); |
207 | if (pmd_none(*pm_dir)) { | 207 | if (pmd_none(*pm_dir)) { |
208 | pt_dir = vmem_pte_alloc(); | 208 | pt_dir = vmem_pte_alloc(address); |
209 | if (!pt_dir) | 209 | if (!pt_dir) |
210 | goto out; | 210 | goto out; |
211 | pmd_populate(&init_mm, pm_dir, pt_dir); | 211 | pmd_populate(&init_mm, pm_dir, pt_dir); |
diff --git a/drivers/s390/block/dasd.c b/drivers/s390/block/dasd.c index 86b6f1cc1b10..432444af7ee4 100644 --- a/drivers/s390/block/dasd.c +++ b/drivers/s390/block/dasd.c | |||
@@ -22,6 +22,8 @@ | |||
22 | #include <linux/hdreg.h> | 22 | #include <linux/hdreg.h> |
23 | #include <linux/async.h> | 23 | #include <linux/async.h> |
24 | #include <linux/mutex.h> | 24 | #include <linux/mutex.h> |
25 | #include <linux/debugfs.h> | ||
26 | #include <linux/seq_file.h> | ||
25 | 27 | ||
26 | #include <asm/ccwdev.h> | 28 | #include <asm/ccwdev.h> |
27 | #include <asm/ebcdic.h> | 29 | #include <asm/ebcdic.h> |
@@ -45,6 +47,7 @@ | |||
45 | * SECTION: exported variables of dasd.c | 47 | * SECTION: exported variables of dasd.c |
46 | */ | 48 | */ |
47 | debug_info_t *dasd_debug_area; | 49 | debug_info_t *dasd_debug_area; |
50 | static struct dentry *dasd_debugfs_root_entry; | ||
48 | struct dasd_discipline *dasd_diag_discipline_pointer; | 51 | struct dasd_discipline *dasd_diag_discipline_pointer; |
49 | void dasd_int_handler(struct ccw_device *, unsigned long, struct irb *); | 52 | void dasd_int_handler(struct ccw_device *, unsigned long, struct irb *); |
50 | 53 | ||
@@ -71,6 +74,8 @@ static void dasd_return_cqr_cb(struct dasd_ccw_req *, void *); | |||
71 | static void dasd_device_timeout(unsigned long); | 74 | static void dasd_device_timeout(unsigned long); |
72 | static void dasd_block_timeout(unsigned long); | 75 | static void dasd_block_timeout(unsigned long); |
73 | static void __dasd_process_erp(struct dasd_device *, struct dasd_ccw_req *); | 76 | static void __dasd_process_erp(struct dasd_device *, struct dasd_ccw_req *); |
77 | static void dasd_profile_init(struct dasd_profile *, struct dentry *); | ||
78 | static void dasd_profile_exit(struct dasd_profile *); | ||
74 | 79 | ||
75 | /* | 80 | /* |
76 | * SECTION: Operations on the device structure. | 81 | * SECTION: Operations on the device structure. |
@@ -121,7 +126,7 @@ struct dasd_device *dasd_alloc_device(void) | |||
121 | device->state = DASD_STATE_NEW; | 126 | device->state = DASD_STATE_NEW; |
122 | device->target = DASD_STATE_NEW; | 127 | device->target = DASD_STATE_NEW; |
123 | mutex_init(&device->state_mutex); | 128 | mutex_init(&device->state_mutex); |
124 | 129 | spin_lock_init(&device->profile.lock); | |
125 | return device; | 130 | return device; |
126 | } | 131 | } |
127 | 132 | ||
@@ -159,6 +164,7 @@ struct dasd_block *dasd_alloc_block(void) | |||
159 | init_timer(&block->timer); | 164 | init_timer(&block->timer); |
160 | block->timer.function = dasd_block_timeout; | 165 | block->timer.function = dasd_block_timeout; |
161 | block->timer.data = (unsigned long) block; | 166 | block->timer.data = (unsigned long) block; |
167 | spin_lock_init(&block->profile.lock); | ||
162 | 168 | ||
163 | return block; | 169 | return block; |
164 | } | 170 | } |
@@ -222,19 +228,44 @@ static int dasd_state_known_to_new(struct dasd_device *device) | |||
222 | return 0; | 228 | return 0; |
223 | } | 229 | } |
224 | 230 | ||
231 | static struct dentry *dasd_debugfs_setup(const char *name, | ||
232 | struct dentry *base_dentry) | ||
233 | { | ||
234 | struct dentry *pde; | ||
235 | |||
236 | if (!base_dentry) | ||
237 | return NULL; | ||
238 | pde = debugfs_create_dir(name, base_dentry); | ||
239 | if (!pde || IS_ERR(pde)) | ||
240 | return NULL; | ||
241 | return pde; | ||
242 | } | ||
243 | |||
225 | /* | 244 | /* |
226 | * Request the irq line for the device. | 245 | * Request the irq line for the device. |
227 | */ | 246 | */ |
228 | static int dasd_state_known_to_basic(struct dasd_device *device) | 247 | static int dasd_state_known_to_basic(struct dasd_device *device) |
229 | { | 248 | { |
249 | struct dasd_block *block = device->block; | ||
230 | int rc; | 250 | int rc; |
231 | 251 | ||
232 | /* Allocate and register gendisk structure. */ | 252 | /* Allocate and register gendisk structure. */ |
233 | if (device->block) { | 253 | if (block) { |
234 | rc = dasd_gendisk_alloc(device->block); | 254 | rc = dasd_gendisk_alloc(block); |
235 | if (rc) | 255 | if (rc) |
236 | return rc; | 256 | return rc; |
237 | } | 257 | block->debugfs_dentry = |
258 | dasd_debugfs_setup(block->gdp->disk_name, | ||
259 | dasd_debugfs_root_entry); | ||
260 | dasd_profile_init(&block->profile, block->debugfs_dentry); | ||
261 | if (dasd_global_profile_level == DASD_PROFILE_ON) | ||
262 | dasd_profile_on(&device->block->profile); | ||
263 | } | ||
264 | device->debugfs_dentry = | ||
265 | dasd_debugfs_setup(dev_name(&device->cdev->dev), | ||
266 | dasd_debugfs_root_entry); | ||
267 | dasd_profile_init(&device->profile, device->debugfs_dentry); | ||
268 | |||
238 | /* register 'device' debug area, used for all DBF_DEV_XXX calls */ | 269 | /* register 'device' debug area, used for all DBF_DEV_XXX calls */ |
239 | device->debug_area = debug_register(dev_name(&device->cdev->dev), 4, 1, | 270 | device->debug_area = debug_register(dev_name(&device->cdev->dev), 4, 1, |
240 | 8 * sizeof(long)); | 271 | 8 * sizeof(long)); |
@@ -253,6 +284,9 @@ static int dasd_state_basic_to_known(struct dasd_device *device) | |||
253 | { | 284 | { |
254 | int rc; | 285 | int rc; |
255 | if (device->block) { | 286 | if (device->block) { |
287 | dasd_profile_exit(&device->block->profile); | ||
288 | if (device->block->debugfs_dentry) | ||
289 | debugfs_remove(device->block->debugfs_dentry); | ||
256 | dasd_gendisk_free(device->block); | 290 | dasd_gendisk_free(device->block); |
257 | dasd_block_clear_timer(device->block); | 291 | dasd_block_clear_timer(device->block); |
258 | } | 292 | } |
@@ -260,6 +294,9 @@ static int dasd_state_basic_to_known(struct dasd_device *device) | |||
260 | if (rc) | 294 | if (rc) |
261 | return rc; | 295 | return rc; |
262 | dasd_device_clear_timer(device); | 296 | dasd_device_clear_timer(device); |
297 | dasd_profile_exit(&device->profile); | ||
298 | if (device->debugfs_dentry) | ||
299 | debugfs_remove(device->debugfs_dentry); | ||
263 | 300 | ||
264 | DBF_DEV_EVENT(DBF_EMERG, device, "%p debug area deleted", device); | 301 | DBF_DEV_EVENT(DBF_EMERG, device, "%p debug area deleted", device); |
265 | if (device->debug_area != NULL) { | 302 | if (device->debug_area != NULL) { |
@@ -609,21 +646,13 @@ void dasd_enable_device(struct dasd_device *device) | |||
609 | /* | 646 | /* |
610 | * SECTION: device operation (interrupt handler, start i/o, term i/o ...) | 647 | * SECTION: device operation (interrupt handler, start i/o, term i/o ...) |
611 | */ | 648 | */ |
612 | #ifdef CONFIG_DASD_PROFILE | ||
613 | 649 | ||
614 | struct dasd_profile_info_t dasd_global_profile; | 650 | unsigned int dasd_global_profile_level = DASD_PROFILE_OFF; |
615 | unsigned int dasd_profile_level = DASD_PROFILE_OFF; | ||
616 | 651 | ||
617 | /* | 652 | #ifdef CONFIG_DASD_PROFILE |
618 | * Increments counter in global and local profiling structures. | 653 | struct dasd_profile_info dasd_global_profile_data; |
619 | */ | 654 | static struct dentry *dasd_global_profile_dentry; |
620 | #define dasd_profile_counter(value, counter, block) \ | 655 | static struct dentry *dasd_debugfs_global_entry; |
621 | { \ | ||
622 | int index; \ | ||
623 | for (index = 0; index < 31 && value >> (2+index); index++); \ | ||
624 | dasd_global_profile.counter[index]++; \ | ||
625 | block->profile.counter[index]++; \ | ||
626 | } | ||
627 | 656 | ||
628 | /* | 657 | /* |
629 | * Add profiling information for cqr before execution. | 658 | * Add profiling information for cqr before execution. |
@@ -634,30 +663,121 @@ static void dasd_profile_start(struct dasd_block *block, | |||
634 | { | 663 | { |
635 | struct list_head *l; | 664 | struct list_head *l; |
636 | unsigned int counter; | 665 | unsigned int counter; |
637 | 666 | struct dasd_device *device; | |
638 | if (dasd_profile_level != DASD_PROFILE_ON) | ||
639 | return; | ||
640 | 667 | ||
641 | /* count the length of the chanq for statistics */ | 668 | /* count the length of the chanq for statistics */ |
642 | counter = 0; | 669 | counter = 0; |
643 | list_for_each(l, &block->ccw_queue) | 670 | if (dasd_global_profile_level || block->profile.data) |
644 | if (++counter >= 31) | 671 | list_for_each(l, &block->ccw_queue) |
645 | break; | 672 | if (++counter >= 31) |
646 | dasd_global_profile.dasd_io_nr_req[counter]++; | 673 | break; |
647 | block->profile.dasd_io_nr_req[counter]++; | 674 | |
675 | if (dasd_global_profile_level) { | ||
676 | dasd_global_profile_data.dasd_io_nr_req[counter]++; | ||
677 | if (rq_data_dir(req) == READ) | ||
678 | dasd_global_profile_data.dasd_read_nr_req[counter]++; | ||
679 | } | ||
680 | |||
681 | spin_lock(&block->profile.lock); | ||
682 | if (block->profile.data) | ||
683 | block->profile.data->dasd_io_nr_req[counter]++; | ||
684 | if (rq_data_dir(req) == READ) | ||
685 | block->profile.data->dasd_read_nr_req[counter]++; | ||
686 | spin_unlock(&block->profile.lock); | ||
687 | |||
688 | /* | ||
689 | * We count the request for the start device, even though it may run on | ||
690 | * some other device due to error recovery. This way we make sure that | ||
691 | * we count each request only once. | ||
692 | */ | ||
693 | device = cqr->startdev; | ||
694 | if (device->profile.data) { | ||
695 | counter = 1; /* request is not yet queued on the start device */ | ||
696 | list_for_each(l, &device->ccw_queue) | ||
697 | if (++counter >= 31) | ||
698 | break; | ||
699 | } | ||
700 | spin_lock(&device->profile.lock); | ||
701 | if (device->profile.data) { | ||
702 | device->profile.data->dasd_io_nr_req[counter]++; | ||
703 | if (rq_data_dir(req) == READ) | ||
704 | device->profile.data->dasd_read_nr_req[counter]++; | ||
705 | } | ||
706 | spin_unlock(&device->profile.lock); | ||
648 | } | 707 | } |
649 | 708 | ||
650 | /* | 709 | /* |
651 | * Add profiling information for cqr after execution. | 710 | * Add profiling information for cqr after execution. |
652 | */ | 711 | */ |
712 | |||
713 | #define dasd_profile_counter(value, index) \ | ||
714 | { \ | ||
715 | for (index = 0; index < 31 && value >> (2+index); index++) \ | ||
716 | ; \ | ||
717 | } | ||
718 | |||
719 | static void dasd_profile_end_add_data(struct dasd_profile_info *data, | ||
720 | int is_alias, | ||
721 | int is_tpm, | ||
722 | int is_read, | ||
723 | long sectors, | ||
724 | int sectors_ind, | ||
725 | int tottime_ind, | ||
726 | int tottimeps_ind, | ||
727 | int strtime_ind, | ||
728 | int irqtime_ind, | ||
729 | int irqtimeps_ind, | ||
730 | int endtime_ind) | ||
731 | { | ||
732 | /* in case of an overflow, reset the whole profile */ | ||
733 | if (data->dasd_io_reqs == UINT_MAX) { | ||
734 | memset(data, 0, sizeof(*data)); | ||
735 | getnstimeofday(&data->starttod); | ||
736 | } | ||
737 | data->dasd_io_reqs++; | ||
738 | data->dasd_io_sects += sectors; | ||
739 | if (is_alias) | ||
740 | data->dasd_io_alias++; | ||
741 | if (is_tpm) | ||
742 | data->dasd_io_tpm++; | ||
743 | |||
744 | data->dasd_io_secs[sectors_ind]++; | ||
745 | data->dasd_io_times[tottime_ind]++; | ||
746 | data->dasd_io_timps[tottimeps_ind]++; | ||
747 | data->dasd_io_time1[strtime_ind]++; | ||
748 | data->dasd_io_time2[irqtime_ind]++; | ||
749 | data->dasd_io_time2ps[irqtimeps_ind]++; | ||
750 | data->dasd_io_time3[endtime_ind]++; | ||
751 | |||
752 | if (is_read) { | ||
753 | data->dasd_read_reqs++; | ||
754 | data->dasd_read_sects += sectors; | ||
755 | if (is_alias) | ||
756 | data->dasd_read_alias++; | ||
757 | if (is_tpm) | ||
758 | data->dasd_read_tpm++; | ||
759 | data->dasd_read_secs[sectors_ind]++; | ||
760 | data->dasd_read_times[tottime_ind]++; | ||
761 | data->dasd_read_time1[strtime_ind]++; | ||
762 | data->dasd_read_time2[irqtime_ind]++; | ||
763 | data->dasd_read_time3[endtime_ind]++; | ||
764 | } | ||
765 | } | ||
766 | |||
653 | static void dasd_profile_end(struct dasd_block *block, | 767 | static void dasd_profile_end(struct dasd_block *block, |
654 | struct dasd_ccw_req *cqr, | 768 | struct dasd_ccw_req *cqr, |
655 | struct request *req) | 769 | struct request *req) |
656 | { | 770 | { |
657 | long strtime, irqtime, endtime, tottime; /* in microseconds */ | 771 | long strtime, irqtime, endtime, tottime; /* in microseconds */ |
658 | long tottimeps, sectors; | 772 | long tottimeps, sectors; |
773 | struct dasd_device *device; | ||
774 | int sectors_ind, tottime_ind, tottimeps_ind, strtime_ind; | ||
775 | int irqtime_ind, irqtimeps_ind, endtime_ind; | ||
659 | 776 | ||
660 | if (dasd_profile_level != DASD_PROFILE_ON) | 777 | device = cqr->startdev; |
778 | if (!(dasd_global_profile_level || | ||
779 | block->profile.data || | ||
780 | device->profile.data)) | ||
661 | return; | 781 | return; |
662 | 782 | ||
663 | sectors = blk_rq_sectors(req); | 783 | sectors = blk_rq_sectors(req); |
@@ -672,29 +792,392 @@ static void dasd_profile_end(struct dasd_block *block, | |||
672 | tottime = ((cqr->endclk - cqr->buildclk) >> 12); | 792 | tottime = ((cqr->endclk - cqr->buildclk) >> 12); |
673 | tottimeps = tottime / sectors; | 793 | tottimeps = tottime / sectors; |
674 | 794 | ||
675 | if (!dasd_global_profile.dasd_io_reqs) | 795 | dasd_profile_counter(sectors, sectors_ind); |
676 | memset(&dasd_global_profile, 0, | 796 | dasd_profile_counter(tottime, tottime_ind); |
677 | sizeof(struct dasd_profile_info_t)); | 797 | dasd_profile_counter(tottimeps, tottimeps_ind); |
678 | dasd_global_profile.dasd_io_reqs++; | 798 | dasd_profile_counter(strtime, strtime_ind); |
679 | dasd_global_profile.dasd_io_sects += sectors; | 799 | dasd_profile_counter(irqtime, irqtime_ind); |
680 | 800 | dasd_profile_counter(irqtime / sectors, irqtimeps_ind); | |
681 | if (!block->profile.dasd_io_reqs) | 801 | dasd_profile_counter(endtime, endtime_ind); |
682 | memset(&block->profile, 0, | 802 | |
683 | sizeof(struct dasd_profile_info_t)); | 803 | if (dasd_global_profile_level) { |
684 | block->profile.dasd_io_reqs++; | 804 | dasd_profile_end_add_data(&dasd_global_profile_data, |
685 | block->profile.dasd_io_sects += sectors; | 805 | cqr->startdev != block->base, |
686 | 806 | cqr->cpmode == 1, | |
687 | dasd_profile_counter(sectors, dasd_io_secs, block); | 807 | rq_data_dir(req) == READ, |
688 | dasd_profile_counter(tottime, dasd_io_times, block); | 808 | sectors, sectors_ind, tottime_ind, |
689 | dasd_profile_counter(tottimeps, dasd_io_timps, block); | 809 | tottimeps_ind, strtime_ind, |
690 | dasd_profile_counter(strtime, dasd_io_time1, block); | 810 | irqtime_ind, irqtimeps_ind, |
691 | dasd_profile_counter(irqtime, dasd_io_time2, block); | 811 | endtime_ind); |
692 | dasd_profile_counter(irqtime / sectors, dasd_io_time2ps, block); | 812 | } |
693 | dasd_profile_counter(endtime, dasd_io_time3, block); | 813 | |
814 | spin_lock(&block->profile.lock); | ||
815 | if (block->profile.data) | ||
816 | dasd_profile_end_add_data(block->profile.data, | ||
817 | cqr->startdev != block->base, | ||
818 | cqr->cpmode == 1, | ||
819 | rq_data_dir(req) == READ, | ||
820 | sectors, sectors_ind, tottime_ind, | ||
821 | tottimeps_ind, strtime_ind, | ||
822 | irqtime_ind, irqtimeps_ind, | ||
823 | endtime_ind); | ||
824 | spin_unlock(&block->profile.lock); | ||
825 | |||
826 | spin_lock(&device->profile.lock); | ||
827 | if (device->profile.data) | ||
828 | dasd_profile_end_add_data(device->profile.data, | ||
829 | cqr->startdev != block->base, | ||
830 | cqr->cpmode == 1, | ||
831 | rq_data_dir(req) == READ, | ||
832 | sectors, sectors_ind, tottime_ind, | ||
833 | tottimeps_ind, strtime_ind, | ||
834 | irqtime_ind, irqtimeps_ind, | ||
835 | endtime_ind); | ||
836 | spin_unlock(&device->profile.lock); | ||
837 | } | ||
838 | |||
839 | void dasd_profile_reset(struct dasd_profile *profile) | ||
840 | { | ||
841 | struct dasd_profile_info *data; | ||
842 | |||
843 | spin_lock_bh(&profile->lock); | ||
844 | data = profile->data; | ||
845 | if (!data) { | ||
846 | spin_unlock_bh(&profile->lock); | ||
847 | return; | ||
848 | } | ||
849 | memset(data, 0, sizeof(*data)); | ||
850 | getnstimeofday(&data->starttod); | ||
851 | spin_unlock_bh(&profile->lock); | ||
852 | } | ||
853 | |||
854 | void dasd_global_profile_reset(void) | ||
855 | { | ||
856 | memset(&dasd_global_profile_data, 0, sizeof(dasd_global_profile_data)); | ||
857 | getnstimeofday(&dasd_global_profile_data.starttod); | ||
858 | } | ||
859 | |||
860 | int dasd_profile_on(struct dasd_profile *profile) | ||
861 | { | ||
862 | struct dasd_profile_info *data; | ||
863 | |||
864 | data = kzalloc(sizeof(*data), GFP_KERNEL); | ||
865 | if (!data) | ||
866 | return -ENOMEM; | ||
867 | spin_lock_bh(&profile->lock); | ||
868 | if (profile->data) { | ||
869 | spin_unlock_bh(&profile->lock); | ||
870 | kfree(data); | ||
871 | return 0; | ||
872 | } | ||
873 | getnstimeofday(&data->starttod); | ||
874 | profile->data = data; | ||
875 | spin_unlock_bh(&profile->lock); | ||
876 | return 0; | ||
877 | } | ||
878 | |||
879 | void dasd_profile_off(struct dasd_profile *profile) | ||
880 | { | ||
881 | spin_lock_bh(&profile->lock); | ||
882 | kfree(profile->data); | ||
883 | profile->data = NULL; | ||
884 | spin_unlock_bh(&profile->lock); | ||
885 | } | ||
886 | |||
887 | char *dasd_get_user_string(const char __user *user_buf, size_t user_len) | ||
888 | { | ||
889 | char *buffer; | ||
890 | |||
891 | buffer = kmalloc(user_len + 1, GFP_KERNEL); | ||
892 | if (buffer == NULL) | ||
893 | return ERR_PTR(-ENOMEM); | ||
894 | if (copy_from_user(buffer, user_buf, user_len) != 0) { | ||
895 | kfree(buffer); | ||
896 | return ERR_PTR(-EFAULT); | ||
897 | } | ||
898 | /* got the string, now strip linefeed. */ | ||
899 | if (buffer[user_len - 1] == '\n') | ||
900 | buffer[user_len - 1] = 0; | ||
901 | else | ||
902 | buffer[user_len] = 0; | ||
903 | return buffer; | ||
694 | } | 904 | } |
905 | |||
906 | static ssize_t dasd_stats_write(struct file *file, | ||
907 | const char __user *user_buf, | ||
908 | size_t user_len, loff_t *pos) | ||
909 | { | ||
910 | char *buffer, *str; | ||
911 | int rc; | ||
912 | struct seq_file *m = (struct seq_file *)file->private_data; | ||
913 | struct dasd_profile *prof = m->private; | ||
914 | |||
915 | if (user_len > 65536) | ||
916 | user_len = 65536; | ||
917 | buffer = dasd_get_user_string(user_buf, user_len); | ||
918 | if (IS_ERR(buffer)) | ||
919 | return PTR_ERR(buffer); | ||
920 | |||
921 | str = skip_spaces(buffer); | ||
922 | rc = user_len; | ||
923 | if (strncmp(str, "reset", 5) == 0) { | ||
924 | dasd_profile_reset(prof); | ||
925 | } else if (strncmp(str, "on", 2) == 0) { | ||
926 | rc = dasd_profile_on(prof); | ||
927 | if (!rc) | ||
928 | rc = user_len; | ||
929 | } else if (strncmp(str, "off", 3) == 0) { | ||
930 | dasd_profile_off(prof); | ||
931 | } else | ||
932 | rc = -EINVAL; | ||
933 | kfree(buffer); | ||
934 | return rc; | ||
935 | } | ||
936 | |||
937 | static void dasd_stats_array(struct seq_file *m, unsigned int *array) | ||
938 | { | ||
939 | int i; | ||
940 | |||
941 | for (i = 0; i < 32; i++) | ||
942 | seq_printf(m, "%u ", array[i]); | ||
943 | seq_putc(m, '\n'); | ||
944 | } | ||
945 | |||
946 | static void dasd_stats_seq_print(struct seq_file *m, | ||
947 | struct dasd_profile_info *data) | ||
948 | { | ||
949 | seq_printf(m, "start_time %ld.%09ld\n", | ||
950 | data->starttod.tv_sec, data->starttod.tv_nsec); | ||
951 | seq_printf(m, "total_requests %u\n", data->dasd_io_reqs); | ||
952 | seq_printf(m, "total_sectors %u\n", data->dasd_io_sects); | ||
953 | seq_printf(m, "total_pav %u\n", data->dasd_io_alias); | ||
954 | seq_printf(m, "total_hpf %u\n", data->dasd_io_tpm); | ||
955 | seq_printf(m, "histogram_sectors "); | ||
956 | dasd_stats_array(m, data->dasd_io_secs); | ||
957 | seq_printf(m, "histogram_io_times "); | ||
958 | dasd_stats_array(m, data->dasd_io_times); | ||
959 | seq_printf(m, "histogram_io_times_weighted "); | ||
960 | dasd_stats_array(m, data->dasd_io_timps); | ||
961 | seq_printf(m, "histogram_time_build_to_ssch "); | ||
962 | dasd_stats_array(m, data->dasd_io_time1); | ||
963 | seq_printf(m, "histogram_time_ssch_to_irq "); | ||
964 | dasd_stats_array(m, data->dasd_io_time2); | ||
965 | seq_printf(m, "histogram_time_ssch_to_irq_weighted "); | ||
966 | dasd_stats_array(m, data->dasd_io_time2ps); | ||
967 | seq_printf(m, "histogram_time_irq_to_end "); | ||
968 | dasd_stats_array(m, data->dasd_io_time3); | ||
969 | seq_printf(m, "histogram_ccw_queue_length "); | ||
970 | dasd_stats_array(m, data->dasd_io_nr_req); | ||
971 | seq_printf(m, "total_read_requests %u\n", data->dasd_read_reqs); | ||
972 | seq_printf(m, "total_read_sectors %u\n", data->dasd_read_sects); | ||
973 | seq_printf(m, "total_read_pav %u\n", data->dasd_read_alias); | ||
974 | seq_printf(m, "total_read_hpf %u\n", data->dasd_read_tpm); | ||
975 | seq_printf(m, "histogram_read_sectors "); | ||
976 | dasd_stats_array(m, data->dasd_read_secs); | ||
977 | seq_printf(m, "histogram_read_times "); | ||
978 | dasd_stats_array(m, data->dasd_read_times); | ||
979 | seq_printf(m, "histogram_read_time_build_to_ssch "); | ||
980 | dasd_stats_array(m, data->dasd_read_time1); | ||
981 | seq_printf(m, "histogram_read_time_ssch_to_irq "); | ||
982 | dasd_stats_array(m, data->dasd_read_time2); | ||
983 | seq_printf(m, "histogram_read_time_irq_to_end "); | ||
984 | dasd_stats_array(m, data->dasd_read_time3); | ||
985 | seq_printf(m, "histogram_read_ccw_queue_length "); | ||
986 | dasd_stats_array(m, data->dasd_read_nr_req); | ||
987 | } | ||
988 | |||
989 | static int dasd_stats_show(struct seq_file *m, void *v) | ||
990 | { | ||
991 | struct dasd_profile *profile; | ||
992 | struct dasd_profile_info *data; | ||
993 | |||
994 | profile = m->private; | ||
995 | spin_lock_bh(&profile->lock); | ||
996 | data = profile->data; | ||
997 | if (!data) { | ||
998 | spin_unlock_bh(&profile->lock); | ||
999 | seq_printf(m, "disabled\n"); | ||
1000 | return 0; | ||
1001 | } | ||
1002 | dasd_stats_seq_print(m, data); | ||
1003 | spin_unlock_bh(&profile->lock); | ||
1004 | return 0; | ||
1005 | } | ||
1006 | |||
1007 | static int dasd_stats_open(struct inode *inode, struct file *file) | ||
1008 | { | ||
1009 | struct dasd_profile *profile = inode->i_private; | ||
1010 | return single_open(file, dasd_stats_show, profile); | ||
1011 | } | ||
1012 | |||
1013 | static const struct file_operations dasd_stats_raw_fops = { | ||
1014 | .owner = THIS_MODULE, | ||
1015 | .open = dasd_stats_open, | ||
1016 | .read = seq_read, | ||
1017 | .llseek = seq_lseek, | ||
1018 | .release = single_release, | ||
1019 | .write = dasd_stats_write, | ||
1020 | }; | ||
1021 | |||
1022 | static ssize_t dasd_stats_global_write(struct file *file, | ||
1023 | const char __user *user_buf, | ||
1024 | size_t user_len, loff_t *pos) | ||
1025 | { | ||
1026 | char *buffer, *str; | ||
1027 | ssize_t rc; | ||
1028 | |||
1029 | if (user_len > 65536) | ||
1030 | user_len = 65536; | ||
1031 | buffer = dasd_get_user_string(user_buf, user_len); | ||
1032 | if (IS_ERR(buffer)) | ||
1033 | return PTR_ERR(buffer); | ||
1034 | str = skip_spaces(buffer); | ||
1035 | rc = user_len; | ||
1036 | if (strncmp(str, "reset", 5) == 0) { | ||
1037 | dasd_global_profile_reset(); | ||
1038 | } else if (strncmp(str, "on", 2) == 0) { | ||
1039 | dasd_global_profile_reset(); | ||
1040 | dasd_global_profile_level = DASD_PROFILE_GLOBAL_ONLY; | ||
1041 | } else if (strncmp(str, "off", 3) == 0) { | ||
1042 | dasd_global_profile_level = DASD_PROFILE_OFF; | ||
1043 | } else | ||
1044 | rc = -EINVAL; | ||
1045 | kfree(buffer); | ||
1046 | return rc; | ||
1047 | } | ||
1048 | |||
1049 | static int dasd_stats_global_show(struct seq_file *m, void *v) | ||
1050 | { | ||
1051 | if (!dasd_global_profile_level) { | ||
1052 | seq_printf(m, "disabled\n"); | ||
1053 | return 0; | ||
1054 | } | ||
1055 | dasd_stats_seq_print(m, &dasd_global_profile_data); | ||
1056 | return 0; | ||
1057 | } | ||
1058 | |||
1059 | static int dasd_stats_global_open(struct inode *inode, struct file *file) | ||
1060 | { | ||
1061 | return single_open(file, dasd_stats_global_show, NULL); | ||
1062 | } | ||
1063 | |||
1064 | static const struct file_operations dasd_stats_global_fops = { | ||
1065 | .owner = THIS_MODULE, | ||
1066 | .open = dasd_stats_global_open, | ||
1067 | .read = seq_read, | ||
1068 | .llseek = seq_lseek, | ||
1069 | .release = single_release, | ||
1070 | .write = dasd_stats_global_write, | ||
1071 | }; | ||
1072 | |||
1073 | static void dasd_profile_init(struct dasd_profile *profile, | ||
1074 | struct dentry *base_dentry) | ||
1075 | { | ||
1076 | mode_t mode; | ||
1077 | struct dentry *pde; | ||
1078 | |||
1079 | if (!base_dentry) | ||
1080 | return; | ||
1081 | profile->dentry = NULL; | ||
1082 | profile->data = NULL; | ||
1083 | mode = (S_IRUSR | S_IWUSR | S_IFREG); | ||
1084 | pde = debugfs_create_file("statistics", mode, base_dentry, | ||
1085 | profile, &dasd_stats_raw_fops); | ||
1086 | if (pde && !IS_ERR(pde)) | ||
1087 | profile->dentry = pde; | ||
1088 | return; | ||
1089 | } | ||
1090 | |||
1091 | static void dasd_profile_exit(struct dasd_profile *profile) | ||
1092 | { | ||
1093 | dasd_profile_off(profile); | ||
1094 | if (profile->dentry) { | ||
1095 | debugfs_remove(profile->dentry); | ||
1096 | profile->dentry = NULL; | ||
1097 | } | ||
1098 | } | ||
1099 | |||
1100 | static void dasd_statistics_removeroot(void) | ||
1101 | { | ||
1102 | dasd_global_profile_level = DASD_PROFILE_OFF; | ||
1103 | if (dasd_global_profile_dentry) { | ||
1104 | debugfs_remove(dasd_global_profile_dentry); | ||
1105 | dasd_global_profile_dentry = NULL; | ||
1106 | } | ||
1107 | if (dasd_debugfs_global_entry) | ||
1108 | debugfs_remove(dasd_debugfs_global_entry); | ||
1109 | if (dasd_debugfs_root_entry) | ||
1110 | debugfs_remove(dasd_debugfs_root_entry); | ||
1111 | } | ||
1112 | |||
1113 | static void dasd_statistics_createroot(void) | ||
1114 | { | ||
1115 | mode_t mode; | ||
1116 | struct dentry *pde; | ||
1117 | |||
1118 | dasd_debugfs_root_entry = NULL; | ||
1119 | dasd_debugfs_global_entry = NULL; | ||
1120 | dasd_global_profile_dentry = NULL; | ||
1121 | pde = debugfs_create_dir("dasd", NULL); | ||
1122 | if (!pde || IS_ERR(pde)) | ||
1123 | goto error; | ||
1124 | dasd_debugfs_root_entry = pde; | ||
1125 | pde = debugfs_create_dir("global", dasd_debugfs_root_entry); | ||
1126 | if (!pde || IS_ERR(pde)) | ||
1127 | goto error; | ||
1128 | dasd_debugfs_global_entry = pde; | ||
1129 | |||
1130 | mode = (S_IRUSR | S_IWUSR | S_IFREG); | ||
1131 | pde = debugfs_create_file("statistics", mode, dasd_debugfs_global_entry, | ||
1132 | NULL, &dasd_stats_global_fops); | ||
1133 | if (!pde || IS_ERR(pde)) | ||
1134 | goto error; | ||
1135 | dasd_global_profile_dentry = pde; | ||
1136 | return; | ||
1137 | |||
1138 | error: | ||
1139 | DBF_EVENT(DBF_ERR, "%s", | ||
1140 | "Creation of the dasd debugfs interface failed"); | ||
1141 | dasd_statistics_removeroot(); | ||
1142 | return; | ||
1143 | } | ||
1144 | |||
695 | #else | 1145 | #else |
696 | #define dasd_profile_start(block, cqr, req) do {} while (0) | 1146 | #define dasd_profile_start(block, cqr, req) do {} while (0) |
697 | #define dasd_profile_end(block, cqr, req) do {} while (0) | 1147 | #define dasd_profile_end(block, cqr, req) do {} while (0) |
1148 | |||
1149 | static void dasd_statistics_createroot(void) | ||
1150 | { | ||
1151 | return; | ||
1152 | } | ||
1153 | |||
1154 | static void dasd_statistics_removeroot(void) | ||
1155 | { | ||
1156 | return; | ||
1157 | } | ||
1158 | |||
1159 | int dasd_stats_generic_show(struct seq_file *m, void *v) | ||
1160 | { | ||
1161 | seq_printf(m, "Statistics are not activated in this kernel\n"); | ||
1162 | return 0; | ||
1163 | } | ||
1164 | |||
1165 | static void dasd_profile_init(struct dasd_profile *profile, | ||
1166 | struct dentry *base_dentry) | ||
1167 | { | ||
1168 | return; | ||
1169 | } | ||
1170 | |||
1171 | static void dasd_profile_exit(struct dasd_profile *profile) | ||
1172 | { | ||
1173 | return; | ||
1174 | } | ||
1175 | |||
1176 | int dasd_profile_on(struct dasd_profile *profile) | ||
1177 | { | ||
1178 | return 0; | ||
1179 | } | ||
1180 | |||
698 | #endif /* CONFIG_DASD_PROFILE */ | 1181 | #endif /* CONFIG_DASD_PROFILE */ |
699 | 1182 | ||
700 | /* | 1183 | /* |
@@ -2441,6 +2924,7 @@ dasd_exit(void) | |||
2441 | debug_unregister(dasd_debug_area); | 2924 | debug_unregister(dasd_debug_area); |
2442 | dasd_debug_area = NULL; | 2925 | dasd_debug_area = NULL; |
2443 | } | 2926 | } |
2927 | dasd_statistics_removeroot(); | ||
2444 | } | 2928 | } |
2445 | 2929 | ||
2446 | /* | 2930 | /* |
@@ -2992,6 +3476,8 @@ static int __init dasd_init(void) | |||
2992 | 3476 | ||
2993 | dasd_diag_discipline_pointer = NULL; | 3477 | dasd_diag_discipline_pointer = NULL; |
2994 | 3478 | ||
3479 | dasd_statistics_createroot(); | ||
3480 | |||
2995 | rc = dasd_devmap_init(); | 3481 | rc = dasd_devmap_init(); |
2996 | if (rc) | 3482 | if (rc) |
2997 | goto failed; | 3483 | goto failed; |
diff --git a/drivers/s390/block/dasd_int.h b/drivers/s390/block/dasd_int.h index d1e4f2c1264c..1dd12bd85a69 100644 --- a/drivers/s390/block/dasd_int.h +++ b/drivers/s390/block/dasd_int.h | |||
@@ -382,6 +382,41 @@ struct dasd_path { | |||
382 | __u8 npm; | 382 | __u8 npm; |
383 | }; | 383 | }; |
384 | 384 | ||
385 | struct dasd_profile_info { | ||
386 | /* legacy part of profile data, as in dasd_profile_info_t */ | ||
387 | unsigned int dasd_io_reqs; /* number of requests processed */ | ||
388 | unsigned int dasd_io_sects; /* number of sectors processed */ | ||
389 | unsigned int dasd_io_secs[32]; /* histogram of request's sizes */ | ||
390 | unsigned int dasd_io_times[32]; /* histogram of requests's times */ | ||
391 | unsigned int dasd_io_timps[32]; /* h. of requests's times per sector */ | ||
392 | unsigned int dasd_io_time1[32]; /* hist. of time from build to start */ | ||
393 | unsigned int dasd_io_time2[32]; /* hist. of time from start to irq */ | ||
394 | unsigned int dasd_io_time2ps[32]; /* hist. of time from start to irq */ | ||
395 | unsigned int dasd_io_time3[32]; /* hist. of time from irq to end */ | ||
396 | unsigned int dasd_io_nr_req[32]; /* hist. of # of requests in chanq */ | ||
397 | |||
398 | /* new data */ | ||
399 | struct timespec starttod; /* time of start or last reset */ | ||
400 | unsigned int dasd_io_alias; /* requests using an alias */ | ||
401 | unsigned int dasd_io_tpm; /* requests using transport mode */ | ||
402 | unsigned int dasd_read_reqs; /* total number of read requests */ | ||
403 | unsigned int dasd_read_sects; /* total number read sectors */ | ||
404 | unsigned int dasd_read_alias; /* read request using an alias */ | ||
405 | unsigned int dasd_read_tpm; /* read requests in transport mode */ | ||
406 | unsigned int dasd_read_secs[32]; /* histogram of request's sizes */ | ||
407 | unsigned int dasd_read_times[32]; /* histogram of requests's times */ | ||
408 | unsigned int dasd_read_time1[32]; /* hist. time from build to start */ | ||
409 | unsigned int dasd_read_time2[32]; /* hist. of time from start to irq */ | ||
410 | unsigned int dasd_read_time3[32]; /* hist. of time from irq to end */ | ||
411 | unsigned int dasd_read_nr_req[32]; /* hist. of # of requests in chanq */ | ||
412 | }; | ||
413 | |||
414 | struct dasd_profile { | ||
415 | struct dentry *dentry; | ||
416 | struct dasd_profile_info *data; | ||
417 | spinlock_t lock; | ||
418 | }; | ||
419 | |||
385 | struct dasd_device { | 420 | struct dasd_device { |
386 | /* Block device stuff. */ | 421 | /* Block device stuff. */ |
387 | struct dasd_block *block; | 422 | struct dasd_block *block; |
@@ -431,6 +466,9 @@ struct dasd_device { | |||
431 | 466 | ||
432 | /* default expiration time in s */ | 467 | /* default expiration time in s */ |
433 | unsigned long default_expires; | 468 | unsigned long default_expires; |
469 | |||
470 | struct dentry *debugfs_dentry; | ||
471 | struct dasd_profile profile; | ||
434 | }; | 472 | }; |
435 | 473 | ||
436 | struct dasd_block { | 474 | struct dasd_block { |
@@ -453,9 +491,8 @@ struct dasd_block { | |||
453 | struct tasklet_struct tasklet; | 491 | struct tasklet_struct tasklet; |
454 | struct timer_list timer; | 492 | struct timer_list timer; |
455 | 493 | ||
456 | #ifdef CONFIG_DASD_PROFILE | 494 | struct dentry *debugfs_dentry; |
457 | struct dasd_profile_info_t profile; | 495 | struct dasd_profile profile; |
458 | #endif | ||
459 | }; | 496 | }; |
460 | 497 | ||
461 | 498 | ||
@@ -589,12 +626,13 @@ dasd_check_blocksize(int bsize) | |||
589 | } | 626 | } |
590 | 627 | ||
591 | /* externals in dasd.c */ | 628 | /* externals in dasd.c */ |
592 | #define DASD_PROFILE_ON 1 | 629 | #define DASD_PROFILE_OFF 0 |
593 | #define DASD_PROFILE_OFF 0 | 630 | #define DASD_PROFILE_ON 1 |
631 | #define DASD_PROFILE_GLOBAL_ONLY 2 | ||
594 | 632 | ||
595 | extern debug_info_t *dasd_debug_area; | 633 | extern debug_info_t *dasd_debug_area; |
596 | extern struct dasd_profile_info_t dasd_global_profile; | 634 | extern struct dasd_profile_info dasd_global_profile_data; |
597 | extern unsigned int dasd_profile_level; | 635 | extern unsigned int dasd_global_profile_level; |
598 | extern const struct block_device_operations dasd_device_operations; | 636 | extern const struct block_device_operations dasd_device_operations; |
599 | 637 | ||
600 | extern struct kmem_cache *dasd_page_cache; | 638 | extern struct kmem_cache *dasd_page_cache; |
@@ -662,6 +700,11 @@ void dasd_device_remove_stop_bits(struct dasd_device *, int); | |||
662 | 700 | ||
663 | int dasd_device_is_ro(struct dasd_device *); | 701 | int dasd_device_is_ro(struct dasd_device *); |
664 | 702 | ||
703 | void dasd_profile_reset(struct dasd_profile *); | ||
704 | int dasd_profile_on(struct dasd_profile *); | ||
705 | void dasd_profile_off(struct dasd_profile *); | ||
706 | void dasd_global_profile_reset(void); | ||
707 | char *dasd_get_user_string(const char __user *, size_t); | ||
665 | 708 | ||
666 | /* externals in dasd_devmap.c */ | 709 | /* externals in dasd_devmap.c */ |
667 | extern int dasd_max_devindex; | 710 | extern int dasd_max_devindex; |
diff --git a/drivers/s390/block/dasd_ioctl.c b/drivers/s390/block/dasd_ioctl.c index 72261e4c516d..eb4e034378cd 100644 --- a/drivers/s390/block/dasd_ioctl.c +++ b/drivers/s390/block/dasd_ioctl.c | |||
@@ -239,7 +239,7 @@ dasd_ioctl_format(struct block_device *bdev, void __user *argp) | |||
239 | */ | 239 | */ |
240 | static int dasd_ioctl_reset_profile(struct dasd_block *block) | 240 | static int dasd_ioctl_reset_profile(struct dasd_block *block) |
241 | { | 241 | { |
242 | memset(&block->profile, 0, sizeof(struct dasd_profile_info_t)); | 242 | dasd_profile_reset(&block->profile); |
243 | return 0; | 243 | return 0; |
244 | } | 244 | } |
245 | 245 | ||
@@ -248,10 +248,40 @@ static int dasd_ioctl_reset_profile(struct dasd_block *block) | |||
248 | */ | 248 | */ |
249 | static int dasd_ioctl_read_profile(struct dasd_block *block, void __user *argp) | 249 | static int dasd_ioctl_read_profile(struct dasd_block *block, void __user *argp) |
250 | { | 250 | { |
251 | if (dasd_profile_level == DASD_PROFILE_OFF) | 251 | struct dasd_profile_info_t *data; |
252 | |||
253 | data = kmalloc(sizeof(*data), GFP_KERNEL); | ||
254 | if (!data) | ||
255 | return -ENOMEM; | ||
256 | |||
257 | spin_lock_bh(&block->profile.lock); | ||
258 | if (block->profile.data) { | ||
259 | data->dasd_io_reqs = block->profile.data->dasd_io_reqs; | ||
260 | data->dasd_io_sects = block->profile.data->dasd_io_sects; | ||
261 | memcpy(data->dasd_io_secs, block->profile.data->dasd_io_secs, | ||
262 | sizeof(data->dasd_io_secs)); | ||
263 | memcpy(data->dasd_io_times, block->profile.data->dasd_io_times, | ||
264 | sizeof(data->dasd_io_times)); | ||
265 | memcpy(data->dasd_io_timps, block->profile.data->dasd_io_timps, | ||
266 | sizeof(data->dasd_io_timps)); | ||
267 | memcpy(data->dasd_io_time1, block->profile.data->dasd_io_time1, | ||
268 | sizeof(data->dasd_io_time1)); | ||
269 | memcpy(data->dasd_io_time2, block->profile.data->dasd_io_time2, | ||
270 | sizeof(data->dasd_io_time2)); | ||
271 | memcpy(data->dasd_io_time2ps, | ||
272 | block->profile.data->dasd_io_time2ps, | ||
273 | sizeof(data->dasd_io_time2ps)); | ||
274 | memcpy(data->dasd_io_time3, block->profile.data->dasd_io_time3, | ||
275 | sizeof(data->dasd_io_time3)); | ||
276 | memcpy(data->dasd_io_nr_req, | ||
277 | block->profile.data->dasd_io_nr_req, | ||
278 | sizeof(data->dasd_io_nr_req)); | ||
279 | spin_unlock_bh(&block->profile.lock); | ||
280 | } else { | ||
281 | spin_unlock_bh(&block->profile.lock); | ||
252 | return -EIO; | 282 | return -EIO; |
253 | if (copy_to_user(argp, &block->profile, | 283 | } |
254 | sizeof(struct dasd_profile_info_t))) | 284 | if (copy_to_user(argp, data, sizeof(*data))) |
255 | return -EFAULT; | 285 | return -EFAULT; |
256 | return 0; | 286 | return 0; |
257 | } | 287 | } |
diff --git a/drivers/s390/block/dasd_proc.c b/drivers/s390/block/dasd_proc.c index c4a6a31bd9cd..6c3c5364d082 100644 --- a/drivers/s390/block/dasd_proc.c +++ b/drivers/s390/block/dasd_proc.c | |||
@@ -32,28 +32,6 @@ static struct proc_dir_entry *dasd_proc_root_entry = NULL; | |||
32 | static struct proc_dir_entry *dasd_devices_entry = NULL; | 32 | static struct proc_dir_entry *dasd_devices_entry = NULL; |
33 | static struct proc_dir_entry *dasd_statistics_entry = NULL; | 33 | static struct proc_dir_entry *dasd_statistics_entry = NULL; |
34 | 34 | ||
35 | #ifdef CONFIG_DASD_PROFILE | ||
36 | static char * | ||
37 | dasd_get_user_string(const char __user *user_buf, size_t user_len) | ||
38 | { | ||
39 | char *buffer; | ||
40 | |||
41 | buffer = kmalloc(user_len + 1, GFP_KERNEL); | ||
42 | if (buffer == NULL) | ||
43 | return ERR_PTR(-ENOMEM); | ||
44 | if (copy_from_user(buffer, user_buf, user_len) != 0) { | ||
45 | kfree(buffer); | ||
46 | return ERR_PTR(-EFAULT); | ||
47 | } | ||
48 | /* got the string, now strip linefeed. */ | ||
49 | if (buffer[user_len - 1] == '\n') | ||
50 | buffer[user_len - 1] = 0; | ||
51 | else | ||
52 | buffer[user_len] = 0; | ||
53 | return buffer; | ||
54 | } | ||
55 | #endif /* CONFIG_DASD_PROFILE */ | ||
56 | |||
57 | static int | 35 | static int |
58 | dasd_devices_show(struct seq_file *m, void *v) | 36 | dasd_devices_show(struct seq_file *m, void *v) |
59 | { | 37 | { |
@@ -167,6 +145,55 @@ static const struct file_operations dasd_devices_file_ops = { | |||
167 | }; | 145 | }; |
168 | 146 | ||
169 | #ifdef CONFIG_DASD_PROFILE | 147 | #ifdef CONFIG_DASD_PROFILE |
148 | static int dasd_stats_all_block_on(void) | ||
149 | { | ||
150 | int i, rc; | ||
151 | struct dasd_device *device; | ||
152 | |||
153 | rc = 0; | ||
154 | for (i = 0; i < dasd_max_devindex; ++i) { | ||
155 | device = dasd_device_from_devindex(i); | ||
156 | if (IS_ERR(device)) | ||
157 | continue; | ||
158 | if (device->block) | ||
159 | rc = dasd_profile_on(&device->block->profile); | ||
160 | dasd_put_device(device); | ||
161 | if (rc) | ||
162 | return rc; | ||
163 | } | ||
164 | return 0; | ||
165 | } | ||
166 | |||
167 | static void dasd_stats_all_block_off(void) | ||
168 | { | ||
169 | int i; | ||
170 | struct dasd_device *device; | ||
171 | |||
172 | for (i = 0; i < dasd_max_devindex; ++i) { | ||
173 | device = dasd_device_from_devindex(i); | ||
174 | if (IS_ERR(device)) | ||
175 | continue; | ||
176 | if (device->block) | ||
177 | dasd_profile_off(&device->block->profile); | ||
178 | dasd_put_device(device); | ||
179 | } | ||
180 | } | ||
181 | |||
182 | static void dasd_stats_all_block_reset(void) | ||
183 | { | ||
184 | int i; | ||
185 | struct dasd_device *device; | ||
186 | |||
187 | for (i = 0; i < dasd_max_devindex; ++i) { | ||
188 | device = dasd_device_from_devindex(i); | ||
189 | if (IS_ERR(device)) | ||
190 | continue; | ||
191 | if (device->block) | ||
192 | dasd_profile_reset(&device->block->profile); | ||
193 | dasd_put_device(device); | ||
194 | } | ||
195 | } | ||
196 | |||
170 | static void dasd_statistics_array(struct seq_file *m, unsigned int *array, int factor) | 197 | static void dasd_statistics_array(struct seq_file *m, unsigned int *array, int factor) |
171 | { | 198 | { |
172 | int i; | 199 | int i; |
@@ -183,18 +210,18 @@ static void dasd_statistics_array(struct seq_file *m, unsigned int *array, int f | |||
183 | static int dasd_stats_proc_show(struct seq_file *m, void *v) | 210 | static int dasd_stats_proc_show(struct seq_file *m, void *v) |
184 | { | 211 | { |
185 | #ifdef CONFIG_DASD_PROFILE | 212 | #ifdef CONFIG_DASD_PROFILE |
186 | struct dasd_profile_info_t *prof; | 213 | struct dasd_profile_info *prof; |
187 | int factor; | 214 | int factor; |
188 | 215 | ||
189 | /* check for active profiling */ | 216 | /* check for active profiling */ |
190 | if (dasd_profile_level == DASD_PROFILE_OFF) { | 217 | if (!dasd_global_profile_level) { |
191 | seq_printf(m, "Statistics are off - they might be " | 218 | seq_printf(m, "Statistics are off - they might be " |
192 | "switched on using 'echo set on > " | 219 | "switched on using 'echo set on > " |
193 | "/proc/dasd/statistics'\n"); | 220 | "/proc/dasd/statistics'\n"); |
194 | return 0; | 221 | return 0; |
195 | } | 222 | } |
223 | prof = &dasd_global_profile_data; | ||
196 | 224 | ||
197 | prof = &dasd_global_profile; | ||
198 | /* prevent counter 'overflow' on output */ | 225 | /* prevent counter 'overflow' on output */ |
199 | for (factor = 1; (prof->dasd_io_reqs / factor) > 9999999; | 226 | for (factor = 1; (prof->dasd_io_reqs / factor) > 9999999; |
200 | factor *= 10); | 227 | factor *= 10); |
@@ -245,6 +272,7 @@ static ssize_t dasd_stats_proc_write(struct file *file, | |||
245 | { | 272 | { |
246 | #ifdef CONFIG_DASD_PROFILE | 273 | #ifdef CONFIG_DASD_PROFILE |
247 | char *buffer, *str; | 274 | char *buffer, *str; |
275 | int rc; | ||
248 | 276 | ||
249 | if (user_len > 65536) | 277 | if (user_len > 65536) |
250 | user_len = 65536; | 278 | user_len = 65536; |
@@ -259,32 +287,40 @@ static ssize_t dasd_stats_proc_write(struct file *file, | |||
259 | str = skip_spaces(str + 4); | 287 | str = skip_spaces(str + 4); |
260 | if (strcmp(str, "on") == 0) { | 288 | if (strcmp(str, "on") == 0) { |
261 | /* switch on statistics profiling */ | 289 | /* switch on statistics profiling */ |
262 | dasd_profile_level = DASD_PROFILE_ON; | 290 | rc = dasd_stats_all_block_on(); |
291 | if (rc) { | ||
292 | dasd_stats_all_block_off(); | ||
293 | goto out_error; | ||
294 | } | ||
295 | dasd_global_profile_reset(); | ||
296 | dasd_global_profile_level = DASD_PROFILE_ON; | ||
263 | pr_info("The statistics feature has been switched " | 297 | pr_info("The statistics feature has been switched " |
264 | "on\n"); | 298 | "on\n"); |
265 | } else if (strcmp(str, "off") == 0) { | 299 | } else if (strcmp(str, "off") == 0) { |
266 | /* switch off and reset statistics profiling */ | 300 | /* switch off and reset statistics profiling */ |
267 | memset(&dasd_global_profile, | 301 | dasd_global_profile_level = DASD_PROFILE_OFF; |
268 | 0, sizeof (struct dasd_profile_info_t)); | 302 | dasd_global_profile_reset(); |
269 | dasd_profile_level = DASD_PROFILE_OFF; | 303 | dasd_stats_all_block_off(); |
270 | pr_info("The statistics feature has been switched " | 304 | pr_info("The statistics feature has been switched " |
271 | "off\n"); | 305 | "off\n"); |
272 | } else | 306 | } else |
273 | goto out_error; | 307 | goto out_parse_error; |
274 | } else if (strncmp(str, "reset", 5) == 0) { | 308 | } else if (strncmp(str, "reset", 5) == 0) { |
275 | /* reset the statistics */ | 309 | /* reset the statistics */ |
276 | memset(&dasd_global_profile, 0, | 310 | dasd_global_profile_reset(); |
277 | sizeof (struct dasd_profile_info_t)); | 311 | dasd_stats_all_block_reset(); |
278 | pr_info("The statistics have been reset\n"); | 312 | pr_info("The statistics have been reset\n"); |
279 | } else | 313 | } else |
280 | goto out_error; | 314 | goto out_parse_error; |
281 | kfree(buffer); | 315 | kfree(buffer); |
282 | return user_len; | 316 | return user_len; |
283 | out_error: | 317 | out_parse_error: |
318 | rc = -EINVAL; | ||
284 | pr_warning("%s is not a supported value for /proc/dasd/statistics\n", | 319 | pr_warning("%s is not a supported value for /proc/dasd/statistics\n", |
285 | str); | 320 | str); |
321 | out_error: | ||
286 | kfree(buffer); | 322 | kfree(buffer); |
287 | return -EINVAL; | 323 | return rc; |
288 | #else | 324 | #else |
289 | pr_warning("/proc/dasd/statistics: is not activated in this kernel\n"); | 325 | pr_warning("/proc/dasd/statistics: is not activated in this kernel\n"); |
290 | return user_len; | 326 | return user_len; |
diff --git a/drivers/s390/char/Kconfig b/drivers/s390/char/Kconfig index a4f117d9fdc6..2c9a776bd63c 100644 --- a/drivers/s390/char/Kconfig +++ b/drivers/s390/char/Kconfig | |||
@@ -116,9 +116,6 @@ config S390_TAPE | |||
116 | called tape390 and include all selected interfaces and | 116 | called tape390 and include all selected interfaces and |
117 | hardware drivers. | 117 | hardware drivers. |
118 | 118 | ||
119 | comment "S/390 tape interface support" | ||
120 | depends on S390_TAPE | ||
121 | |||
122 | comment "S/390 tape hardware support" | 119 | comment "S/390 tape hardware support" |
123 | depends on S390_TAPE | 120 | depends on S390_TAPE |
124 | 121 | ||
diff --git a/drivers/s390/cio/qdio_thinint.c b/drivers/s390/cio/qdio_thinint.c index 5c4e741d8221..68be6e157126 100644 --- a/drivers/s390/cio/qdio_thinint.c +++ b/drivers/s390/cio/qdio_thinint.c | |||
@@ -95,9 +95,11 @@ void tiqdio_remove_input_queues(struct qdio_irq *irq_ptr) | |||
95 | } | 95 | } |
96 | } | 96 | } |
97 | 97 | ||
98 | static inline u32 shared_ind_set(void) | 98 | static inline u32 clear_shared_ind(void) |
99 | { | 99 | { |
100 | return q_indicators[TIQDIO_SHARED_IND].ind; | 100 | if (!atomic_read(&q_indicators[TIQDIO_SHARED_IND].count)) |
101 | return 0; | ||
102 | return xchg(&q_indicators[TIQDIO_SHARED_IND].ind, 0); | ||
101 | } | 103 | } |
102 | 104 | ||
103 | /** | 105 | /** |
@@ -107,7 +109,7 @@ static inline u32 shared_ind_set(void) | |||
107 | */ | 109 | */ |
108 | static void tiqdio_thinint_handler(void *alsi, void *data) | 110 | static void tiqdio_thinint_handler(void *alsi, void *data) |
109 | { | 111 | { |
110 | u32 si_used = shared_ind_set(); | 112 | u32 si_used = clear_shared_ind(); |
111 | struct qdio_q *q; | 113 | struct qdio_q *q; |
112 | 114 | ||
113 | last_ai_time = S390_lowcore.int_clock; | 115 | last_ai_time = S390_lowcore.int_clock; |
@@ -150,13 +152,6 @@ static void tiqdio_thinint_handler(void *alsi, void *data) | |||
150 | qperf_inc(q, adapter_int); | 152 | qperf_inc(q, adapter_int); |
151 | } | 153 | } |
152 | rcu_read_unlock(); | 154 | rcu_read_unlock(); |
153 | |||
154 | /* | ||
155 | * If the shared indicator was used clear it now after all queues | ||
156 | * were processed. | ||
157 | */ | ||
158 | if (si_used && shared_ind_set()) | ||
159 | xchg(&q_indicators[TIQDIO_SHARED_IND].ind, 0); | ||
160 | } | 155 | } |
161 | 156 | ||
162 | static int set_subchannel_ind(struct qdio_irq *irq_ptr, int reset) | 157 | static int set_subchannel_ind(struct qdio_irq *irq_ptr, int reset) |
diff --git a/drivers/s390/crypto/ap_bus.c b/drivers/s390/crypto/ap_bus.c index 16e4a25596e7..f8134a44cefa 100644 --- a/drivers/s390/crypto/ap_bus.c +++ b/drivers/s390/crypto/ap_bus.c | |||
@@ -6,6 +6,7 @@ | |||
6 | * Martin Schwidefsky <schwidefsky@de.ibm.com> | 6 | * Martin Schwidefsky <schwidefsky@de.ibm.com> |
7 | * Ralph Wuerthner <rwuerthn@de.ibm.com> | 7 | * Ralph Wuerthner <rwuerthn@de.ibm.com> |
8 | * Felix Beck <felix.beck@de.ibm.com> | 8 | * Felix Beck <felix.beck@de.ibm.com> |
9 | * Holger Dengler <hd@linux.vnet.ibm.com> | ||
9 | * | 10 | * |
10 | * Adjunct processor bus. | 11 | * Adjunct processor bus. |
11 | * | 12 | * |
@@ -222,47 +223,52 @@ ap_queue_interruption_control(ap_qid_t qid, void *ind) | |||
222 | } | 223 | } |
223 | #endif | 224 | #endif |
224 | 225 | ||
225 | static inline struct ap_queue_status __ap_4096_commands_available(ap_qid_t qid, | 226 | #ifdef CONFIG_64BIT |
226 | int *support) | 227 | static inline struct ap_queue_status |
228 | __ap_query_functions(ap_qid_t qid, unsigned int *functions) | ||
227 | { | 229 | { |
228 | register unsigned long reg0 asm ("0") = 0UL | qid | (1UL << 23); | 230 | register unsigned long reg0 asm ("0") = 0UL | qid | (1UL << 23); |
229 | register struct ap_queue_status reg1 asm ("1"); | 231 | register struct ap_queue_status reg1 asm ("1") = AP_QUEUE_STATUS_INVALID; |
230 | register unsigned long reg2 asm ("2") = 0UL; | 232 | register unsigned long reg2 asm ("2"); |
231 | 233 | ||
232 | asm volatile( | 234 | asm volatile( |
233 | ".long 0xb2af0000\n" | 235 | ".long 0xb2af0000\n" |
234 | "0: la %1,0\n" | 236 | "0:\n" |
235 | "1:\n" | 237 | EX_TABLE(0b, 0b) |
236 | EX_TABLE(0b, 1b) | 238 | : "+d" (reg0), "+d" (reg1), "=d" (reg2) |
237 | : "+d" (reg0), "=d" (reg1), "=d" (reg2) | ||
238 | : | 239 | : |
239 | : "cc"); | 240 | : "cc"); |
240 | 241 | ||
241 | if (reg2 & 0x6000000000000000ULL) | 242 | *functions = (unsigned int)(reg2 >> 32); |
242 | *support = 1; | ||
243 | else | ||
244 | *support = 0; | ||
245 | |||
246 | return reg1; | 243 | return reg1; |
247 | } | 244 | } |
245 | #endif | ||
248 | 246 | ||
249 | /** | 247 | /** |
250 | * ap_4096_commands_availablen(): Check for availability of 4096 bit RSA | 248 | * ap_query_functions(): Query supported functions. |
251 | * support. | ||
252 | * @qid: The AP queue number | 249 | * @qid: The AP queue number |
250 | * @functions: Pointer to functions field. | ||
253 | * | 251 | * |
254 | * Returns 1 if 4096 bit RSA keys are support fo the AP, returns 0 if not. | 252 | * Returns |
253 | * 0 on success. | ||
254 | * -ENODEV if queue not valid. | ||
255 | * -EBUSY if device busy. | ||
256 | * -EINVAL if query function is not supported | ||
255 | */ | 257 | */ |
256 | int ap_4096_commands_available(ap_qid_t qid) | 258 | static int ap_query_functions(ap_qid_t qid, unsigned int *functions) |
257 | { | 259 | { |
260 | #ifdef CONFIG_64BIT | ||
258 | struct ap_queue_status status; | 261 | struct ap_queue_status status; |
259 | int i, support = 0; | 262 | int i; |
260 | status = __ap_4096_commands_available(qid, &support); | 263 | status = __ap_query_functions(qid, functions); |
261 | 264 | ||
262 | for (i = 0; i < AP_MAX_RESET; i++) { | 265 | for (i = 0; i < AP_MAX_RESET; i++) { |
266 | if (ap_queue_status_invalid_test(&status)) | ||
267 | return -ENODEV; | ||
268 | |||
263 | switch (status.response_code) { | 269 | switch (status.response_code) { |
264 | case AP_RESPONSE_NORMAL: | 270 | case AP_RESPONSE_NORMAL: |
265 | return support; | 271 | return 0; |
266 | case AP_RESPONSE_RESET_IN_PROGRESS: | 272 | case AP_RESPONSE_RESET_IN_PROGRESS: |
267 | case AP_RESPONSE_BUSY: | 273 | case AP_RESPONSE_BUSY: |
268 | break; | 274 | break; |
@@ -270,7 +276,7 @@ int ap_4096_commands_available(ap_qid_t qid) | |||
270 | case AP_RESPONSE_DECONFIGURED: | 276 | case AP_RESPONSE_DECONFIGURED: |
271 | case AP_RESPONSE_CHECKSTOPPED: | 277 | case AP_RESPONSE_CHECKSTOPPED: |
272 | case AP_RESPONSE_INVALID_ADDRESS: | 278 | case AP_RESPONSE_INVALID_ADDRESS: |
273 | return 0; | 279 | return -ENODEV; |
274 | case AP_RESPONSE_OTHERWISE_CHANGED: | 280 | case AP_RESPONSE_OTHERWISE_CHANGED: |
275 | break; | 281 | break; |
276 | default: | 282 | default: |
@@ -278,10 +284,31 @@ int ap_4096_commands_available(ap_qid_t qid) | |||
278 | } | 284 | } |
279 | if (i < AP_MAX_RESET - 1) { | 285 | if (i < AP_MAX_RESET - 1) { |
280 | udelay(5); | 286 | udelay(5); |
281 | status = __ap_4096_commands_available(qid, &support); | 287 | status = __ap_query_functions(qid, functions); |
282 | } | 288 | } |
283 | } | 289 | } |
284 | return support; | 290 | return -EBUSY; |
291 | #else | ||
292 | return -EINVAL; | ||
293 | #endif | ||
294 | } | ||
295 | |||
296 | /** | ||
297 | * ap_4096_commands_availablen(): Check for availability of 4096 bit RSA | ||
298 | * support. | ||
299 | * @qid: The AP queue number | ||
300 | * | ||
301 | * Returns 1 if 4096 bit RSA keys are support fo the AP, returns 0 if not. | ||
302 | */ | ||
303 | int ap_4096_commands_available(ap_qid_t qid) | ||
304 | { | ||
305 | unsigned int functions; | ||
306 | |||
307 | if (ap_query_functions(qid, &functions)) | ||
308 | return 0; | ||
309 | |||
310 | return test_ap_facility(functions, 1) && | ||
311 | test_ap_facility(functions, 2); | ||
285 | } | 312 | } |
286 | EXPORT_SYMBOL(ap_4096_commands_available); | 313 | EXPORT_SYMBOL(ap_4096_commands_available); |
287 | 314 | ||
@@ -1135,6 +1162,7 @@ static void ap_scan_bus(struct work_struct *unused) | |||
1135 | struct device *dev; | 1162 | struct device *dev; |
1136 | ap_qid_t qid; | 1163 | ap_qid_t qid; |
1137 | int queue_depth, device_type; | 1164 | int queue_depth, device_type; |
1165 | unsigned int device_functions; | ||
1138 | int rc, i; | 1166 | int rc, i; |
1139 | 1167 | ||
1140 | if (ap_select_domain() != 0) | 1168 | if (ap_select_domain() != 0) |
@@ -1183,14 +1211,30 @@ static void ap_scan_bus(struct work_struct *unused) | |||
1183 | INIT_LIST_HEAD(&ap_dev->list); | 1211 | INIT_LIST_HEAD(&ap_dev->list); |
1184 | setup_timer(&ap_dev->timeout, ap_request_timeout, | 1212 | setup_timer(&ap_dev->timeout, ap_request_timeout, |
1185 | (unsigned long) ap_dev); | 1213 | (unsigned long) ap_dev); |
1186 | if (device_type == 0) { | 1214 | switch (device_type) { |
1215 | case 0: | ||
1187 | if (ap_probe_device_type(ap_dev)) { | 1216 | if (ap_probe_device_type(ap_dev)) { |
1188 | kfree(ap_dev); | 1217 | kfree(ap_dev); |
1189 | continue; | 1218 | continue; |
1190 | } | 1219 | } |
1191 | } | 1220 | break; |
1192 | else | 1221 | case 10: |
1222 | if (ap_query_functions(qid, &device_functions)) { | ||
1223 | kfree(ap_dev); | ||
1224 | continue; | ||
1225 | } | ||
1226 | if (test_ap_facility(device_functions, 3)) | ||
1227 | ap_dev->device_type = AP_DEVICE_TYPE_CEX3C; | ||
1228 | else if (test_ap_facility(device_functions, 4)) | ||
1229 | ap_dev->device_type = AP_DEVICE_TYPE_CEX3A; | ||
1230 | else { | ||
1231 | kfree(ap_dev); | ||
1232 | continue; | ||
1233 | } | ||
1234 | break; | ||
1235 | default: | ||
1193 | ap_dev->device_type = device_type; | 1236 | ap_dev->device_type = device_type; |
1237 | } | ||
1194 | 1238 | ||
1195 | ap_dev->device.bus = &ap_bus_type; | 1239 | ap_dev->device.bus = &ap_bus_type; |
1196 | ap_dev->device.parent = ap_root_device; | 1240 | ap_dev->device.parent = ap_root_device; |
diff --git a/drivers/s390/crypto/ap_bus.h b/drivers/s390/crypto/ap_bus.h index 08b9738285b4..d960a6309eec 100644 --- a/drivers/s390/crypto/ap_bus.h +++ b/drivers/s390/crypto/ap_bus.h | |||
@@ -6,6 +6,7 @@ | |||
6 | * Martin Schwidefsky <schwidefsky@de.ibm.com> | 6 | * Martin Schwidefsky <schwidefsky@de.ibm.com> |
7 | * Ralph Wuerthner <rwuerthn@de.ibm.com> | 7 | * Ralph Wuerthner <rwuerthn@de.ibm.com> |
8 | * Felix Beck <felix.beck@de.ibm.com> | 8 | * Felix Beck <felix.beck@de.ibm.com> |
9 | * Holger Dengler <hd@linux.vnet.ibm.com> | ||
9 | * | 10 | * |
10 | * Adjunct processor bus header file. | 11 | * Adjunct processor bus header file. |
11 | * | 12 | * |
@@ -72,7 +73,26 @@ struct ap_queue_status { | |||
72 | unsigned int int_enabled : 1; | 73 | unsigned int int_enabled : 1; |
73 | unsigned int response_code : 8; | 74 | unsigned int response_code : 8; |
74 | unsigned int pad2 : 16; | 75 | unsigned int pad2 : 16; |
75 | }; | 76 | } __packed; |
77 | |||
78 | #define AP_QUEUE_STATUS_INVALID \ | ||
79 | { 1, 1, 1, 0xF, 1, 0xFF, 0xFFFF } | ||
80 | |||
81 | static inline | ||
82 | int ap_queue_status_invalid_test(struct ap_queue_status *status) | ||
83 | { | ||
84 | struct ap_queue_status invalid = AP_QUEUE_STATUS_INVALID; | ||
85 | return !(memcmp(status, &invalid, sizeof(struct ap_queue_status))); | ||
86 | } | ||
87 | |||
88 | #define MAX_AP_FACILITY 31 | ||
89 | |||
90 | static inline int test_ap_facility(unsigned int function, unsigned int nr) | ||
91 | { | ||
92 | if (nr > MAX_AP_FACILITY) | ||
93 | return 0; | ||
94 | return function & (unsigned int)(0x80000000 >> nr); | ||
95 | } | ||
76 | 96 | ||
77 | #define AP_RESPONSE_NORMAL 0x00 | 97 | #define AP_RESPONSE_NORMAL 0x00 |
78 | #define AP_RESPONSE_Q_NOT_AVAIL 0x01 | 98 | #define AP_RESPONSE_Q_NOT_AVAIL 0x01 |
@@ -869,11 +869,11 @@ int page_referenced(struct page *page, | |||
869 | vm_flags); | 869 | vm_flags); |
870 | if (we_locked) | 870 | if (we_locked) |
871 | unlock_page(page); | 871 | unlock_page(page); |
872 | |||
873 | if (page_test_and_clear_young(page_to_pfn(page))) | ||
874 | referenced++; | ||
872 | } | 875 | } |
873 | out: | 876 | out: |
874 | if (page_test_and_clear_young(page_to_pfn(page))) | ||
875 | referenced++; | ||
876 | |||
877 | return referenced; | 877 | return referenced; |
878 | } | 878 | } |
879 | 879 | ||
diff --git a/net/iucv/iucv.c b/net/iucv/iucv.c index 7f9124914b13..f2b713847b45 100644 --- a/net/iucv/iucv.c +++ b/net/iucv/iucv.c | |||
@@ -1988,12 +1988,13 @@ static int __init iucv_init(void) | |||
1988 | rc = -EPROTONOSUPPORT; | 1988 | rc = -EPROTONOSUPPORT; |
1989 | goto out; | 1989 | goto out; |
1990 | } | 1990 | } |
1991 | ctl_set_bit(0, 1); | ||
1991 | rc = iucv_query_maxconn(); | 1992 | rc = iucv_query_maxconn(); |
1992 | if (rc) | 1993 | if (rc) |
1993 | goto out; | 1994 | goto out_ctl; |
1994 | rc = register_external_interrupt(0x4000, iucv_external_interrupt); | 1995 | rc = register_external_interrupt(0x4000, iucv_external_interrupt); |
1995 | if (rc) | 1996 | if (rc) |
1996 | goto out; | 1997 | goto out_ctl; |
1997 | iucv_root = root_device_register("iucv"); | 1998 | iucv_root = root_device_register("iucv"); |
1998 | if (IS_ERR(iucv_root)) { | 1999 | if (IS_ERR(iucv_root)) { |
1999 | rc = PTR_ERR(iucv_root); | 2000 | rc = PTR_ERR(iucv_root); |
@@ -2055,6 +2056,8 @@ out_free: | |||
2055 | root_device_unregister(iucv_root); | 2056 | root_device_unregister(iucv_root); |
2056 | out_int: | 2057 | out_int: |
2057 | unregister_external_interrupt(0x4000, iucv_external_interrupt); | 2058 | unregister_external_interrupt(0x4000, iucv_external_interrupt); |
2059 | out_ctl: | ||
2060 | ctl_clear_bit(0, 1); | ||
2058 | out: | 2061 | out: |
2059 | return rc; | 2062 | return rc; |
2060 | } | 2063 | } |