crc.c
上传用户:aoeyumen
上传日期:2007-01-06
资源大小:3329k
文件大小:1k
源码类别:

DVD

开发平台:

Unix_Linux

  1. /* 
  2.  *    crc.c
  3.  *
  4.  * Copyright (C) Aaron Holtzman - May 1999
  5.  *
  6.  *  This file is part of ac3dec, a free Dolby AC-3 stream decoder.
  7.  *
  8.  *  ac3dec is free software; you can redistribute it and/or modify
  9.  *  it under the terms of the GNU General Public License as published by
  10.  *  the Free Software Foundation; either version 2, or (at your option)
  11.  *  any later version.
  12.  *   
  13.  *  ac3dec is distributed in the hope that it will be useful,
  14.  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  15.  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  16.  *  GNU General Public License for more details.
  17.  *   
  18.  *  You should have received a copy of the GNU General Public License
  19.  *  along with GNU Make; see the file COPYING.  If not, write to
  20.  *  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. 
  21.  *
  22.  */
  23. #include <stdlib.h>
  24. #include <stdio.h>
  25. #include "ac3.h"
  26. #include "crc.h"
  27. static uint_16 state;
  28. void
  29. crc_init(void)
  30. {
  31. state = 0;
  32. }
  33. void
  34. crc_process(uint_32 data, uint_32 num_bits)
  35. {
  36. uint_32 shift_reg;
  37. data <<= 32 - num_bits;
  38. shift_reg = state;
  39. while(num_bits)
  40. {
  41. shift_reg <<= 1;
  42. if((shift_reg >> 16) ^ (data >> 31))
  43. shift_reg = (shift_reg ^ 0x8005);
  44. shift_reg &= 0xffff;
  45. data <<= 1;
  46. num_bits--;
  47. }
  48. state = shift_reg;
  49. }
  50. int
  51. crc_validate(void)
  52. {
  53. return(state  == 0);
  54. }