delay.c 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. /*
  2. * arch/s390/kernel/delay.c
  3. * Precise Delay Loops for S390
  4. *
  5. * S390 version
  6. * Copyright (C) 1999 IBM Deutschland Entwicklung GmbH, IBM Corporation
  7. * Author(s): Martin Schwidefsky (schwidefsky@de.ibm.com),
  8. *
  9. * Derived from "arch/i386/lib/delay.c"
  10. * Copyright (C) 1993 Linus Torvalds
  11. * Copyright (C) 1997 Martin Mares <mj@atrey.karlin.mff.cuni.cz>
  12. */
  13. #include <linux/sched.h>
  14. #include <linux/delay.h>
  15. #ifdef CONFIG_SMP
  16. #include <asm/smp.h>
  17. #endif
  18. void __delay(unsigned long loops)
  19. {
  20. /*
  21. * To end the bloody studid and useless discussion about the
  22. * BogoMips number I took the liberty to define the __delay
  23. * function in a way that that resulting BogoMips number will
  24. * yield the megahertz number of the cpu. The important function
  25. * is udelay and that is done using the tod clock. -- martin.
  26. */
  27. asm volatile("0: brct %0,0b" : : "d" ((loops/2) + 1));
  28. }
  29. /*
  30. * Waits for 'usecs' microseconds using the tod clock, giving up the time slice
  31. * of the virtual PU inbetween to avoid congestion.
  32. */
  33. void __udelay(unsigned long usecs)
  34. {
  35. uint64_t start_cc;
  36. if (usecs == 0)
  37. return;
  38. start_cc = get_clock();
  39. do {
  40. cpu_relax();
  41. } while (((get_clock() - start_cc)/4096) < usecs);
  42. }