ChunkAdapterGEV.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. //-----------------------------------------------------------------------------
  2. // (c) 2006 by Basler Vision Technologies
  3. // Section: Vision Components
  4. // Project: GenApi
  5. // Author: Fritz Dierks
  6. // $Header$
  7. //
  8. // License: This file is published under the license of the EMVA GenICam Standard Group.
  9. // A text file describing the legal terms is included in your installation as 'GenICam_license.pdf'.
  10. // If for some reason you are missing this file please contact the EMVA or visit the website
  11. // (http://www.genicam.org) for a full copy.
  12. //
  13. // THIS SOFTWARE IS PROVIDED BY THE EMVA GENICAM STANDARD GROUP "AS IS"
  14. // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
  15. // THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  16. // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE EMVA GENICAM STANDARD GROUP
  17. // OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  18. // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  19. // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
  20. // OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
  21. // WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  22. // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  23. // POSSIBILITY OF SUCH DAMAGE.
  24. //-----------------------------------------------------------------------------
  25. /**
  26. \file
  27. \brief Declaration of the CChunkAdapterGEV class.
  28. */
  29. #ifndef GENAPI_CHUNKADAPTERGEV_H
  30. #define GENAPI_CHUNKADAPTERGEV_H
  31. #include <GenApi/ChunkAdapter.h>
  32. namespace GENAPI_NAMESPACE
  33. {
  34. /* ------------------------------------------- */
  35. // Declartion of GigE Vision Chunk message trailer
  36. // make sure everything is properly packed
  37. # pragma pack(push, 1)
  38. //! header of a GVCP request packet
  39. typedef struct GVCP_CHUNK_TRAILER
  40. {
  41. uint32_t ChunkID;
  42. uint32_t ChunkLength;
  43. } GVCP_CHUNK_TRAILER;
  44. // restore the previous packing
  45. # pragma pack(pop)
  46. /* ------------------------------------------- */
  47. //! Connects a chunked DCAM buffer to a node map
  48. class GENAPI_DECL CChunkAdapterGEV : public CChunkAdapter
  49. {
  50. public:
  51. //! Constructor
  52. CChunkAdapterGEV(INodeMap* pNodeMap = NULL, int64_t MaxChunkCacheSize = -1);
  53. //! Destructor
  54. virtual ~CChunkAdapterGEV();
  55. //! Checks if a buffer contains chunks in a known format
  56. virtual bool CheckBufferLayout(uint8_t *pBuffer, int64_t BufferLength);
  57. //! Attaches a buffer to the matching ChunkPort
  58. virtual void AttachBuffer(uint8_t *pBuffer, int64_t BufferLength, AttachStatistics_t *pAttachStatistics = NULL);
  59. };
  60. }
  61. #endif // GENAPI_CHUNKADAPTERGEV_H