-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathBdpPacket.h
151 lines (134 loc) · 2.78 KB
/
BdpPacket.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
#ifndef __BDPPACKET_H__
#define __BDPPACKET_H__
enum enumCommand {
eSelectBonDriver = 0,
eCreateBonDriver,
eOpenTuner,
eCloseTuner,
eSetChannel1,
eGetSignalLevel,
eWaitTsStream,
eGetReadyCount,
eGetTsStream,
ePurgeTsStream,
eRelease,
eGetTunerName,
eIsTunerOpening,
eEnumTuningSpace,
eEnumChannelName,
eSetChannel2,
eGetCurSpace,
eGetCurChannel,
eGetTotalDeviceNum,
eGetActiveDeviceNum,
eSetLnbPower,
eGetClientInfo,
};
struct stPacketHead {
BYTE m_bSync;
BYTE m_bCommand;
BYTE m_bReserved1;
BYTE m_bReserved2;
DWORD m_dwBodyLength;
} __attribute__((packed));
struct stPacket {
stPacketHead head;
BYTE payload[1];
} __attribute__((packed));
#define SYNC_BYTE 0xff
class cPacketHolder {
#ifdef __BONDRIVERPROXY_H__
friend class cProxyServer;
#elif defined(__BONDRIVER_PROXYEX_H__)
friend class cProxyServerEx;
#else
friend class cProxyClient;
#endif
union {
stPacket *m_pPacket;
BYTE *m_pBuf;
};
size_t m_Size;
BOOL m_bDelete;
inline void init(size_t PayloadSize)
{
m_pBuf = new BYTE[sizeof(stPacketHead) + PayloadSize];
m_bDelete = TRUE;
}
public:
cPacketHolder(size_t PayloadSize)
{
init(PayloadSize);
}
cPacketHolder(enumCommand eCmd, size_t PayloadSize)
{
init(PayloadSize);
*(DWORD *)m_pBuf = 0;
m_pPacket->head.m_bSync = SYNC_BYTE;
SetCommand(eCmd);
m_pPacket->head.m_dwBodyLength = htonl((DWORD)PayloadSize);
m_Size = sizeof(stPacketHead) + PayloadSize;
}
~cPacketHolder()
{
if (m_bDelete)
delete[] m_pBuf;
}
inline BOOL IsValid(){ return (m_pPacket->head.m_bSync == SYNC_BYTE); }
inline BOOL IsTS(){ return (m_pPacket->head.m_bCommand == (BYTE)eGetTsStream); }
inline enumCommand GetCommand(){ return (enumCommand)m_pPacket->head.m_bCommand; }
inline void SetCommand(enumCommand eCmd){ m_pPacket->head.m_bCommand = (BYTE)eCmd; }
inline DWORD GetBodyLength(){ return ntohl(m_pPacket->head.m_dwBodyLength); }
inline void SetDeleteFlag(BOOL b){ m_bDelete = b; }
};
class cPacketFifo : protected std::queue<cPacketHolder *> {
const size_t m_fifoSize;
cCriticalSection m_Lock;
cEvent m_Event;
public:
cPacketFifo(pthread_cond_t &c, pthread_mutex_t &m) : m_fifoSize(g_PacketFifoSize), m_Event(c, m){}
~cPacketFifo()
{
LOCK(m_Lock);
while (!empty())
{
cPacketHolder *p = front();
pop();
delete p;
}
}
void Push(cPacketHolder *p)
{
LOCK(m_Lock);
if (size() >= m_fifoSize)
{
::fprintf(stderr, "Packet Queue OVERFLOW : size[%zu]\n", size());
// TSの場合のみドロップ
if (p->IsTS())
{
delete p;
return;
}
}
push(p);
m_Event.Set();
}
void Pop(cPacketHolder **p)
{
LOCK(m_Lock);
if (!empty())
{
*p = front();
pop();
if (empty())
m_Event.Reset();
}
else
m_Event.Reset();
}
cEvent *GetEventHandle()
{
return &m_Event;
}
};
#endif // __BDPPACKET_H__