mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-11-03 13:30:52 -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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user