aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mips
diff options
context:
space:
mode:
authorRalf Baechle <ralf@linux-mips.org>2013-04-10 18:16:53 -0400
committerRalf Baechle <ralf@linux-mips.org>2013-04-11 09:39:52 -0400
commite01961ceea5453ba93c386adf49fff6d1b811e74 (patch)
tree96e5c10f926631426a89a746a833257233bab747 /arch/mips
parent9fcb705929fb476d48ff47a54a67e9da659f10c5 (diff)
MIPS: Remove further use of .subsection
7837314d141c661c70bc13c5050694413ecfe14a [MIPS: Get rid of branches to .subsections] removed most uses of .subsection] removed most uses of .subsection in inline assembler code. It left the instances in spinlock.h alone because we knew their use was in fairly small files where .subsection use was fine but of course this was a fragile assumption. LTO breaks this assumption resulting in build errors due to exceeded branch range, so remove further instances of .subsection. The two functions that still use .macro don't currently cause issues however this use is still fragile. Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch/mips')
-rw-r--r--arch/mips/include/asm/spinlock.h116
1 files changed, 44 insertions, 72 deletions
diff --git a/arch/mips/include/asm/spinlock.h b/arch/mips/include/asm/spinlock.h
index 5130c88d6420..0b1dbd22e6f8 100644
--- a/arch/mips/include/asm/spinlock.h
+++ b/arch/mips/include/asm/spinlock.h
@@ -242,25 +242,16 @@ static inline void arch_read_lock(arch_rwlock_t *rw)
242 : "m" (rw->lock) 242 : "m" (rw->lock)
243 : "memory"); 243 : "memory");
244 } else { 244 } else {
245 __asm__ __volatile__( 245 do {
246 " .set noreorder # arch_read_lock \n" 246 __asm__ __volatile__(
247 "1: ll %1, %2 \n" 247 "1: ll %1, %2 # arch_read_lock \n"
248 " bltz %1, 3f \n" 248 " bltz %1, 1b \n"
249 " addu %1, 1 \n" 249 " addu %1, 1 \n"
250 "2: sc %1, %0 \n" 250 "2: sc %1, %0 \n"
251 " beqz %1, 1b \n" 251 : "=m" (rw->lock), "=&r" (tmp)
252 " nop \n" 252 : "m" (rw->lock)
253 " .subsection 2 \n" 253 : "memory");
254 "3: ll %1, %2 \n" 254 } while (unlikely(!tmp));
255 " bltz %1, 3b \n"
256 " addu %1, 1 \n"
257 " b 2b \n"
258 " nop \n"
259 " .previous \n"
260 " .set reorder \n"
261 : "=m" (rw->lock), "=&r" (tmp)
262 : "m" (rw->lock)
263 : "memory");
264 } 255 }
265 256
266 smp_llsc_mb(); 257 smp_llsc_mb();
@@ -285,21 +276,15 @@ static inline void arch_read_unlock(arch_rwlock_t *rw)
285 : "m" (rw->lock) 276 : "m" (rw->lock)
286 : "memory"); 277 : "memory");
287 } else { 278 } else {
288 __asm__ __volatile__( 279 do {
289 " .set noreorder # arch_read_unlock \n" 280 __asm__ __volatile__(
290 "1: ll %1, %2 \n" 281 "1: ll %1, %2 # arch_read_unlock \n"
291 " sub %1, 1 \n" 282 " sub %1, 1 \n"
292 " sc %1, %0 \n" 283 " sc %1, %0 \n"
293 " beqz %1, 2f \n" 284 : "=m" (rw->lock), "=&r" (tmp)
294 " nop \n" 285 : "m" (rw->lock)
295 " .subsection 2 \n" 286 : "memory");
296 "2: b 1b \n" 287 } while (unlikely(!tmp));
297 " nop \n"
298 " .previous \n"
299 " .set reorder \n"
300 : "=m" (rw->lock), "=&r" (tmp)
301 : "m" (rw->lock)
302 : "memory");
303 } 288 }
304} 289}
305 290
@@ -321,25 +306,16 @@ static inline void arch_write_lock(arch_rwlock_t *rw)
321 : "m" (rw->lock) 306 : "m" (rw->lock)
322 : "memory"); 307 : "memory");
323 } else { 308 } else {
324 __asm__ __volatile__( 309 do {
325 " .set noreorder # arch_write_lock \n" 310 __asm__ __volatile__(
326 "1: ll %1, %2 \n" 311 "1: ll %1, %2 # arch_write_lock \n"
327 " bnez %1, 3f \n" 312 " bnez %1, 1b \n"
328 " lui %1, 0x8000 \n" 313 " lui %1, 0x8000 \n"
329 "2: sc %1, %0 \n" 314 "2: sc %1, %0 \n"
330 " beqz %1, 3f \n" 315 : "=m" (rw->lock), "=&r" (tmp)
331 " nop \n" 316 : "m" (rw->lock)
332 " .subsection 2 \n" 317 : "memory");
333 "3: ll %1, %2 \n" 318 } while (unlikely(!tmp));
334 " bnez %1, 3b \n"
335 " lui %1, 0x8000 \n"
336 " b 2b \n"
337 " nop \n"
338 " .previous \n"
339 " .set reorder \n"
340 : "=m" (rw->lock), "=&r" (tmp)
341 : "m" (rw->lock)
342 : "memory");
343 } 319 }
344 320
345 smp_llsc_mb(); 321 smp_llsc_mb();
@@ -424,25 +400,21 @@ static inline int arch_write_trylock(arch_rwlock_t *rw)
424 : "m" (rw->lock) 400 : "m" (rw->lock)
425 : "memory"); 401 : "memory");
426 } else { 402 } else {
427 __asm__ __volatile__( 403 do {
428 " .set noreorder # arch_write_trylock \n" 404 __asm__ __volatile__(
429 " li %2, 0 \n" 405 " ll %1, %3 # arch_write_trylock \n"
430 "1: ll %1, %3 \n" 406 " li %2, 0 \n"
431 " bnez %1, 2f \n" 407 " bnez %1, 2f \n"
432 " lui %1, 0x8000 \n" 408 " lui %1, 0x8000 \n"
433 " sc %1, %0 \n" 409 " sc %1, %0 \n"
434 " beqz %1, 3f \n" 410 " li %2, 1 \n"
435 " li %2, 1 \n" 411 "2: \n"
436 "2: \n" 412 : "=m" (rw->lock), "=&r" (tmp), "=&r" (ret)
437 __WEAK_LLSC_MB 413 : "m" (rw->lock)
438 " .subsection 2 \n" 414 : "memory");
439 "3: b 1b \n" 415 } while (unlikely(!tmp));
440 " li %2, 0 \n" 416
441 " .previous \n" 417 smp_llsc_mb();
442 " .set reorder \n"
443 : "=m" (rw->lock), "=&r" (tmp), "=&r" (ret)
444 : "m" (rw->lock)
445 : "memory");
446 } 418 }
447 419
448 return ret; 420 return ret;