Mark stack variables as early clobber for technical correctness
In the field 5x52 asm for x86_64, stack variables are provided as outputs. The existing inputs are all forcibly allocated to registers, so cannot coincide, but mark them as early clobber anyway to make this clearer.
This commit is contained in:
		
							parent
							
								
									0c729ba70d
								
							
						
					
					
						commit
						350b4bd6e6
					
				| @ -280,7 +280,7 @@ __asm__ __volatile__( | ||||
|     "addq %%rsi,%%r8\n" | ||||
|     /* r[4] = c */ | ||||
|     "movq %%r8,32(%%rdi)\n" | ||||
| : "+S"(a), "=m"(tmp1), "=m"(tmp2), "=m"(tmp3) | ||||
| : "+S"(a), "=&m"(tmp1), "=&m"(tmp2), "=&m"(tmp3) | ||||
| : "b"(b), "D"(r) | ||||
| : "%rax", "%rcx", "%rdx", "%r8", "%r9", "%r10", "%r11", "%r12", "%r13", "%r14", "%r15", "cc", "memory" | ||||
| ); | ||||
| @ -495,7 +495,7 @@ __asm__ __volatile__( | ||||
|     "addq %%rsi,%%r8\n" | ||||
|     /* r[4] = c */ | ||||
|     "movq %%r8,32(%%rdi)\n" | ||||
| : "+S"(a), "=m"(tmp1), "=m"(tmp2), "=m"(tmp3) | ||||
| : "+S"(a), "=&m"(tmp1), "=&m"(tmp2), "=&m"(tmp3) | ||||
| : "D"(r) | ||||
| : "%rax", "%rbx", "%rcx", "%rdx", "%r8", "%r9", "%r10", "%r11", "%r12", "%r13", "%r14", "%r15", "cc", "memory" | ||||
| ); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user