1. 21 12月, 2013 2 次提交
  2. 19 10月, 2013 1 次提交
  3. 14 10月, 2013 1 次提交
  4. 12 10月, 2013 1 次提交
    • G
      kernel: use skip list to implement timer list · d59aa279
      Grissiom 提交于
      Skip list is a "random" data structure that in high possibilities it
      would get O(log(N)) time complexity in inserting while the old list get
      O(N). Forthermore, when set RT_TIMER_SKIP_LIST_LEVEL to 1, it will just
      the same as the old double linked list, both in time and space
      complexity.
      
      Benchmarks shows that when RT_TIMER_SKIP_LIST_LEVEL is 3, the average
      time of random insertion of new timer is about 2 times faster than the
      old timer when there are 100 timers and 3 times faster when there are
      200 timers.
      
      However, it restores the deprecated funcion rt_system_timer_init. BSPs
      must invoke it upon system startup.
      d59aa279
  5. 11 10月, 2013 1 次提交
    • G
      kernel: add RT_DEBUG_IN_THREAD_CONTEXT · 6f71308e
      Grissiom 提交于
      In thread context means: 1) the scheduler has been started; 2) not in
      interrupt context. It is more stronger than RT_DEBUG_NOT_IN_INTERRUPT.
      With this commit, you will catch the error on situations like taking
      mutex before scheduling instead of crashing on NULL pointer reference.
      6f71308e
  6. 24 9月, 2013 1 次提交
  7. 23 9月, 2013 1 次提交
    • G
      kservice: export vsnprintf as rt_vsnprintf · 7b0a3afd
      Grissiom 提交于
      vsnprintf is a common string function that could be used in many places.
      Using both vsnprintf in libc and vsnprintf in the RTT could make a
      bigger image. Moreover, if newlib is not enabled when compiling with
      GCC, referencing vsnprintf will lead to link error:
      
          .../arm-none-eabi/lib/armv7-ar/thumb/softfp/libc.a(lib_a-sbrkr.o):
          In function `_sbrk_r':
          sbrkr.c:(.text._sbrk_r+0xc): undefined reference to `_sbrk'
          collect2: error: ld returned 1 exit status
      
      Using rt_vsnprintf could avoid such problem.
      7b0a3afd
  8. 14 9月, 2013 1 次提交
  9. 19 8月, 2013 1 次提交
  10. 22 7月, 2013 1 次提交
  11. 15 7月, 2013 1 次提交
  12. 11 7月, 2013 1 次提交
  13. 09 7月, 2013 1 次提交
    • G
      device: add ref_count support · 7bcce9e8
      Grissiom 提交于
      This is a simple work around to the current device stack design. A
      ref_count could let different modules to open/close the same device
      independently without interfere others in some degree.
      
      But there is still some data shared between the modules, like flag,
      open_flag and user_data. Moreover, it won't yield an error if A open a
      device, and B read from it before open it in B. Maybe alloc a new handle
      in rt_device_open will be the ultimate solution. But that is much bigger
      change and we may leave it to future development.
      7bcce9e8
  14. 29 6月, 2013 1 次提交
  15. 24 6月, 2013 2 次提交
  16. 23 6月, 2013 1 次提交
  17. 03 6月, 2013 1 次提交
  18. 25 4月, 2013 1 次提交
  19. 17 4月, 2013 1 次提交
  20. 10 4月, 2013 1 次提交
  21. 23 3月, 2013 1 次提交
  22. 17 1月, 2013 1 次提交
  23. 08 1月, 2013 1 次提交
  24. 31 12月, 2012 1 次提交
  25. 29 12月, 2012 1 次提交
  26. 25 12月, 2012 9 次提交
  27. 22 12月, 2012 1 次提交
  28. 21 12月, 2012 3 次提交