⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 crclib.cpp

📁 著名的任天堂FC游戏机模拟器VirtuaNes 085版的源码!
💻 CPP
字号:
//
// CRC僠僃僢僋梡儔僀僽儔儕僋儔僗
//
#include "Crclib.h"

BOOL	CRC::m_Init = FALSE;
BOOL	CRC::m_InitRev = FALSE;
DWORD	CRC::m_CrcTable[ UCHAR_MAX+1 ];
DWORD	CRC::m_CrcTableRev[ UCHAR_MAX+1 ];

#define CRCPOLY1 0x04C11DB7UL
#define CRCPOLY2 0xEDB88320UL

DWORD	CRC::Crc( INT size, LPBYTE c )
{
	if( !m_Init ) {
		MakeTable();
		m_Init = TRUE;
	}

	DWORD	r = 0xFFFFFFFFUL;
	while( --size >= 0 ) {
		r = (r << CHAR_BIT) ^ m_CrcTable[(BYTE)(r >> (32 - CHAR_BIT)) ^ *c++];
	}
	return ~r & 0xFFFFFFFFUL;
}

DWORD	CRC::CrcRev( INT size, LPBYTE c )
{
	if( !m_InitRev ) {
		MakeTableRev();
		m_InitRev = TRUE;
	}

	DWORD	r = 0xFFFFFFFFUL;
	while( --size >= 0 ) {
		r = (r >> CHAR_BIT) ^ m_CrcTableRev[(BYTE)r ^ *c++];
	}
	return r ^ 0xFFFFFFFFUL;
}

void	CRC::MakeTable()
{
INT	i, j;
DWORD	r;

	for( i = 0; i <= UCHAR_MAX; i++ ) {
		r = (DWORD)i << (32 - CHAR_BIT);
		for( j = 0; j < CHAR_BIT; j++ ) {
			if( r & 0x80000000UL ) r = (r << 1) ^ CRCPOLY1;
			else                   r <<= 1;
		}
		m_CrcTable[i] = r & 0xFFFFFFFFUL;
	}
}

void	CRC::MakeTableRev()
{
INT	i, j;
DWORD	r;

	for( i = 0; i <= UCHAR_MAX; i++ ) {
		r = i;
		for( j = 0; j < CHAR_BIT; j++ ) {
			if( r & 1 ) r = (r >> 1) ^ CRCPOLY2;
			else        r >>= 1;
		}
		m_CrcTableRev[i] = r;
	}
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -