ls1c_delay.c 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. // 软件延时源文件
  2. #include "ls1c_clock.h"
  3. /*
  4. * 延时指定时间,单位ms
  5. * @j 延时时间,单位ms
  6. */
  7. void delay_ms(int j)
  8. {
  9. int k_max = clk_get_cpu_rate()/1000/3; // 除以1000表示ms,除以3为测试所得的经验(可以理解为最内层循环执行一次需要的时钟个数)
  10. int k = k_max;
  11. for ( ; j > 0; j--)
  12. {
  13. for (k = k_max; k > 0; k--)
  14. {
  15. __asm__ ("nop"); // 注意,这里必须用内联汇编,否则会被优化掉
  16. }
  17. }
  18. return ;
  19. }
  20. /*
  21. * 延时指定时间,单位us
  22. * @n 延时时间,单位us
  23. */
  24. void delay_us(int n)
  25. {
  26. int count_1us = clk_get_cpu_rate() / 1000000 / 3; // 延时1us的循环次数
  27. int count_max; // 延时n微秒的循环次数
  28. int tmp;
  29. // 根据延时长短微调(注意,这里是手动优化的,cpu频率改变了可能需要重新优化,此时cpu频率为252Mhz)
  30. if (10 >= n) // <=10us
  31. {
  32. count_1us -= 35;
  33. }
  34. else if (100 >= n) // <= 100us
  35. {
  36. count_1us -= 6;
  37. }
  38. else // > 100us
  39. {
  40. count_1us -= 1;
  41. }
  42. count_max = n * count_1us;
  43. // 延时
  44. for (tmp = count_max; tmp > 0; tmp--)
  45. {
  46. __asm__ ("nop"); // 注意,这里必须用内联汇编,否则会被优化掉
  47. }
  48. return ;
  49. }
  50. /*
  51. * 延时指定时间,单位s
  52. * @i 延时时间,单位s
  53. */
  54. void delay_s(int i)
  55. {
  56. for ( ; i > 0; i--)
  57. {
  58. delay_ms(1000);
  59. }
  60. return ;
  61. }