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
|
/*
* 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.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;
}
}
}
///////////////////////////////////////////////////////////////
|