can_producer_consumer.cpp 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. #include "can_producer_consumer.h"
  2. #include <iostream>
  3. CAN_Producer_Consumer::CAN_Producer_Consumer(const int bufSize)
  4. {
  5. bufferSize = bufSize;
  6. buffer.resize(bufferSize);
  7. freeSpace.release(bufferSize);
  8. }
  9. uint64_t CAN_Producer_Consumer::Produce_Element(const iv::can::canraw &xraw) //return the position of first element int this storage
  10. {
  11. uint64_t tempPtr = producerPtr % bufferSize;
  12. freeSpace.acquire();
  13. producerLock.lock();
  14. buffer[producerPtr++ % bufferSize] = xraw;
  15. producerLock.unlock();
  16. usedSpace.release();
  17. return tempPtr;
  18. }
  19. uint64_t CAN_Producer_Consumer::Produce_Elements(const iv::can::canmsg &xmsg,const int &size)
  20. {
  21. uint64_t tempPtr = producerPtr % bufferSize;
  22. if(size < xmsg.rawmsg_size())
  23. {
  24. std::cout<<"Warning! the input size is less than the number of message element."<<std::endl;
  25. freeSpace.acquire(size);
  26. producerLock.lock();
  27. for(int i=0;i<size;i++)
  28. {
  29. buffer[producerPtr++ % bufferSize] = xmsg.rawmsg(i);
  30. }
  31. producerLock.unlock();
  32. usedSpace.release(size);
  33. }
  34. else
  35. {
  36. if(size > xmsg.rawmsg_size())
  37. std::cout<<"Warning! the input size is more than the number of message element."<<std::endl;
  38. freeSpace.acquire(xmsg.rawmsg_size());
  39. producerLock.lock();
  40. for(int i=0;i<xmsg.rawmsg_size();i++)
  41. {
  42. buffer[producerPtr++ % bufferSize] = xmsg.rawmsg(i);
  43. }
  44. producerLock.unlock();
  45. usedSpace.release(xmsg.rawmsg_size());
  46. }
  47. return tempPtr;
  48. }
  49. uint64_t CAN_Producer_Consumer::Produce_Elements_From_CANMsg(const iv::can::canmsg &xmsg)
  50. {
  51. uint64_t tempPtr = producerPtr % bufferSize;
  52. freeSpace.acquire(xmsg.rawmsg_size());
  53. producerLock.lock();
  54. for(int i=0;i<xmsg.rawmsg_size();i++)
  55. {
  56. buffer[producerPtr++ % bufferSize] = xmsg.rawmsg(i);
  57. }
  58. producerLock.unlock();
  59. usedSpace.release(xmsg.rawmsg_size());
  60. return tempPtr;
  61. }
  62. iv::can::canraw CAN_Producer_Consumer::Consume_Element(void)
  63. {
  64. iv::can::canraw xraw;
  65. usedSpace.acquire(); //this function is block mode
  66. consumerLock.lock();
  67. xraw = buffer.at(consumerPtr++ % bufferSize);
  68. consumerLock.unlock();
  69. freeSpace.release();
  70. return xraw;
  71. }
  72. iv::can::canraw CAN_Producer_Consumer::Consume_Element(const int timeout)
  73. {
  74. iv::can::canraw xraw;
  75. bool tempResult = usedSpace.tryAcquire(1,timeout);
  76. if(tempResult)
  77. {
  78. consumerLock.lock();
  79. xraw = buffer.at(consumerPtr++ % bufferSize);
  80. consumerLock.unlock();
  81. freeSpace.release();
  82. }
  83. else
  84. xraw.Clear();
  85. return xraw;
  86. }
  87. iv::can::canmsg CAN_Producer_Consumer::Consume_Elements(const int &size)
  88. {
  89. iv::can::canmsg xmsg;
  90. usedSpace.acquire(size); //this function is block mode
  91. consumerLock.lock();
  92. for(int i=0;i<size;i++)
  93. {
  94. xmsg.add_rawmsg()->CopyFrom(buffer.at(consumerPtr++ % bufferSize));
  95. }
  96. consumerLock.unlock();
  97. freeSpace.release(size);
  98. return xmsg;
  99. }
  100. uint64_t CAN_Producer_Consumer::Consume_Element_To_CANMsg(iv::can::canmsg &xmsg)
  101. {
  102. uint64_t tempPtr = consumerPtr % bufferSize;
  103. usedSpace.acquire(); //this function is block mode
  104. iv::can::canraw *praw = xmsg.add_rawmsg();
  105. consumerLock.lock();
  106. praw->CopyFrom(buffer.at(consumerPtr++ % bufferSize));
  107. consumerLock.unlock();
  108. freeSpace.release();
  109. return tempPtr;
  110. }
  111. uint64_t CAN_Producer_Consumer::Consume_Element_To_CANMsg(iv::can::canmsg &xmsg,int timeout)
  112. {
  113. uint64_t tempPtr = consumerPtr % bufferSize;
  114. bool tempResult = usedSpace.tryAcquire(1,timeout); //this function is block mode
  115. if(tempResult)
  116. {
  117. iv::can::canraw *praw = xmsg.add_rawmsg();
  118. consumerLock.lock();
  119. praw->CopyFrom(buffer.at(consumerPtr++ % bufferSize));
  120. consumerLock.unlock();
  121. freeSpace.release();
  122. }
  123. return tempPtr;
  124. }