msg.h 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. #ifndef _SYS_MSG_H
  2. #define _SYS_MSG_H
  3. /*
  4. * Copyright (C) 2001-2003 by Telogis.com. All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. *
  10. * 1. Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * 3. Neither the name of the copyright holders nor the names of
  16. * contributors may be used to endorse or promote products derived
  17. * from this software without specific prior written permission.
  18. *
  19. * THIS SOFTWARE IS PROVIDED BY EGNITE SOFTWARE GMBH AND CONTRIBUTORS
  20. * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  21. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  22. * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL EGNITE
  23. * SOFTWARE GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  24. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  25. * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
  26. * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
  27. * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  28. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
  29. * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  30. * SUCH DAMAGE.
  31. *
  32. * For additional information see http://www.ethernut.de/
  33. *
  34. * This code was kindly provided by Ralph Mason.
  35. *
  36. */
  37. /*
  38. * $Log: msg.h,v $
  39. * Revision 1.2 2004/03/08 11:20:36 haraldkipp
  40. * Not all compilers like arrays of size zero.
  41. *
  42. * Revision 1.1 2004/02/04 18:05:04 drsung
  43. * First version of message queueing implemented. Thanks to Ralph Mason, who provided this code.
  44. * Still contains some debug functions.
  45. *
  46. */
  47. #include <sys/timer.h>
  48. #ifdef _PC
  49. #pragma warning (disable:4200)
  50. #endif
  51. typedef struct _NUTMSG NUTMSG;
  52. struct _NUTMSG {
  53. u_char id;
  54. int param;
  55. void *data;
  56. };
  57. typedef struct _NUTMSGTMR NUTMSGTMR;
  58. struct _NUTMSGTMR;
  59. typedef struct _NUTMSGQ NUTMSGQ;
  60. struct _NUTMSGQ {
  61. HANDLE mq_wait; /* Wait for a message */
  62. NUTMSGTMR *mq_timers;
  63. NUTMSGQ *mq_next;
  64. u_char mq_read;
  65. u_char mq_write;
  66. u_char mq_mask;
  67. NUTMSG mq_que[1];
  68. };
  69. extern NUTMSGQ *NutMsgQCreate(u_char len);
  70. extern int NutMsgQBroadcast(u_char id, int param, void *data);
  71. extern int NutMsgQPost(NUTMSGQ * que, u_char id, int param, void *data);
  72. extern int NutMsgQSend(NUTMSGQ * que, u_char id, int param, void *data);
  73. extern int NutMsgQGetMessage(NUTMSGQ * que, NUTMSG * msg, u_long timeout);
  74. extern int NutMsgQFull(NUTMSGQ * que);
  75. extern void NutMsgQFlush(NUTMSGQ * que);
  76. extern HANDLE NutMsgQStartTimer(NUTMSGQ * que, u_long ms, int param, void *data, u_char flags);
  77. extern void NutMsgQStopTimer(HANDLE timer);
  78. #define MSG_TIMER 0xfe
  79. #define MSG_NULL 0xff
  80. #endif