forked from T38Modem/t38modem
-
Notifications
You must be signed in to change notification settings - Fork 0
/
fcs.cxx
66 lines (60 loc) · 1.63 KB
/
fcs.cxx
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
/*
* fcs.cxx
*
* T38FAX Pseudo Modem
*
* Copyright (c) 2003-2004 Vyacheslav Frolov
*
* Open H323 Project
*
* The contents of this file are subject to the Mozilla Public License
* Version 1.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
* the License for the specific language governing rights and limitations
* under the License.
*
* The Original Code is Open H323 Library.
*
* The Initial Developer of the Original Code is Vyacheslav Frolov
*
* Contributor(s): Equivalence Pty ltd
*
* $Log: fcs.cxx,v $
* Revision 1.3 2004-07-06 16:07:24 vfrolov
* Included ptlib.h for precompiling
*
* Revision 1.3 2004/07/06 16:07:24 vfrolov
* Included ptlib.h for precompiling
*
* Revision 1.2 2004/02/17 13:22:50 vfrolov
* Fixed MSVC compile errors
*
* Revision 1.1 2003/12/04 13:29:00 vfrolov
* Initial revision
*
*
*/
#include <ptlib.h>
#include "fcs.h"
///////////////////////////////////////////////////////////////
#define new PNEW
///////////////////////////////////////////////////////////////
void FCS::build(const void *_pBuf, PINDEX count)
{
const BYTE *pBuf = (const BYTE *)_pBuf;
for (PINDEX i = 0 ; i < count ; i++) {
BYTE c = *(pBuf++);
for (BYTE m = 0x80 ; m ; m >>= 1) {
fcs <<= 1;
if (c & m)
fcs ^= 0x10000;
if (fcs & 0x10000)
fcs ^= 0x11021;
}
}
}
///////////////////////////////////////////////////////////////