mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2024-11-28 23:28:49 -05:00
Thanks Bill.
git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@7622 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
parent
4565b182ff
commit
38ab140ab6
20
lib/crc.f90
Normal file
20
lib/crc.f90
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
module crc
|
||||||
|
use, intrinsic :: iso_c_binding, only: c_int, c_loc, c_int8_t, c_bool, c_short
|
||||||
|
interface
|
||||||
|
function crc12 (data, length) bind (C, name="crc12")
|
||||||
|
use, intrinsic :: iso_c_binding, only: c_short, c_ptr, c_int
|
||||||
|
implicit none
|
||||||
|
integer (c_short) :: crc12
|
||||||
|
type (c_ptr), value :: data
|
||||||
|
integer (c_int), value :: length
|
||||||
|
end function crc12
|
||||||
|
|
||||||
|
function crc12_check (data, length) bind (C, name="crc12_check")
|
||||||
|
use, intrinsic :: iso_c_binding, only: c_bool, c_ptr, c_int
|
||||||
|
implicit none
|
||||||
|
logical (c_bool) :: crc12_check
|
||||||
|
type (c_ptr), value :: data
|
||||||
|
integer (c_int), value :: length
|
||||||
|
end function crc12_check
|
||||||
|
end interface
|
||||||
|
end module crc
|
20
lib/crc12.cpp
Normal file
20
lib/crc12.cpp
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
#include <boost/crc.hpp>
|
||||||
|
#include <boost/cstdint.hpp>
|
||||||
|
|
||||||
|
extern "C"
|
||||||
|
{
|
||||||
|
short crc12 (unsigned char const * data, int length);
|
||||||
|
bool crc12_check (unsigned char const * data, int length);
|
||||||
|
}
|
||||||
|
|
||||||
|
// assumes CRC is last 16 bits of the data and is set to zero
|
||||||
|
// caller should assign the returned CRC into the message in big endian byte order
|
||||||
|
short crc12 (unsigned char const * data, int length)
|
||||||
|
{
|
||||||
|
return boost::augmented_crc<12, 0xc06> (data, length);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool crc12_check (unsigned char const * data, int length)
|
||||||
|
{
|
||||||
|
return !boost::augmented_crc<12, 0xc06> (data, length);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user