FreeCalypso > hg > fc-tourmaline
view src/gpf/ccd/bitfun.h @ 268:f2e52cab0a73
abb_inth.c: check all interrupt causes, not just one
The original code used if - else if - else if etc constructs, thus
the first detected interrupt was the only one handled. However,
Iota ITSTATREG is a clear-on-read register, thus if we only handle
the first detected interrupt and skip checking the others, then the
other interrupts will be lost, if more than one interrupt happened
to occur in one ABB interrupt handling cycle - a form of rare race
condition. Change the code to check all interrupts that were read
in this cycle.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 13 Jun 2021 18:17:53 +0000 |
parents | 4e78acac3d88 |
children |
line wrap: on
line source
/* +----------------------------------------------------------------------------- | Project : | Modul : bitfun.h +----------------------------------------------------------------------------- | Copyright 2002 Texas Instruments Berlin, AG | All rights reserved. | | This file is confidential and a trade secret of Texas | Instruments Berlin, AG | The receipt of or possession of this file does not convey | any rights to reproduce or disclose its contents or to | manufacture, use, or sell anything it may describe, in | whole, or in part, without the specific written consent of | Texas Instruments Berlin, AG. +----------------------------------------------------------------------------- | Purpose : Condat Coder Decoder | Prototypes of the elementary bit manipulation functions +----------------------------------------------------------------------------- */ #ifndef __BITFUN #define __BITFUN #ifndef __BITFUN_C__ EXTERN void bf_writePadBits (T_CCD_Globs *globs); EXTERN void bf_writeVal (ULONG value, ULONG bSize, T_CCD_Globs *globs); EXTERN ULONG bf_getBits (ULONG len, T_CCD_Globs *globs); EXTERN void bf_writeBitStr_PER (USHORT len, T_CCD_Globs *globs); EXTERN void bf_readBitStr_PER (USHORT len, T_CCD_Globs *globs); EXTERN void bf_writeBits (ULONG len, T_CCD_Globs *globs); EXTERN void bf_readBits (ULONG len, T_CCD_Globs *globs); EXTERN void bf_writeBitChunk (ULONG len, T_CCD_Globs *globs); EXTERN void bf_readBitChunk (ULONG len, T_CCD_Globs *globs); EXTERN BOOL bf_readBit (T_CCD_Globs *globs); EXTERN void bf_writeBit (BOOL Bit, T_CCD_Globs *globs); EXTERN UBYTE bf_decodeByteNumber (const ULONG len, T_CCD_Globs *globs); EXTERN ULONG bf_decodeShortNumber (const ULONG len, T_CCD_Globs *globs); EXTERN ULONG bf_decodeLongNumber (UBYTE len, T_CCD_Globs *globs); EXTERN void bf_codeShortNumber (UBYTE len, USHORT val, T_CCD_Globs *globs); EXTERN void bf_codeByteNumber (UBYTE len, UBYTE val, T_CCD_Globs *globs); EXTERN void bf_codeLongNumber (UBYTE len, ULONG val, T_CCD_Globs *globs); EXTERN void bf_recodeShortNumber (USHORT pos, UBYTE len, USHORT val, T_CCD_Globs *globs); EXTERN void bf_recodeByteNumber (USHORT pos, UBYTE len, UBYTE val, T_CCD_Globs *globs); EXTERN void bf_recodeBit (USHORT pos, UBYTE Bit, T_CCD_Globs *globs); EXTERN void bf_rShift8Bit (USHORT srcBitPos, USHORT bitLen, T_CCD_Globs *globs); #endif /* __BITFUN_C__ */ /* a Macro for incrementing the position in the bitbuffer */ /* _bitpos, _bytepos and _byteoffs are recalculated */ #define bf_incBitpos(A, globs) globs->bitpos = (USHORT)(globs->bitpos+(A));\ globs->bytepos = (USHORT)(globs->bitpos >> 3);\ globs->byteoffs = (UBYTE)(globs->bitpos & 7) #define bf_setBitpos(A, globs) globs->bitpos = (USHORT)(A);\ globs->bytepos = (USHORT)(globs->bitpos >> 3);\ globs->byteoffs = (UBYTE)(globs->bitpos & 7) /* * end of bitstream if we can not read almost 4 bits */ #define bf_endOfBitstream(globs) (globs->bitpos >= globs->maxBitpos) #endif