| 1 | /*
|
|---|
| 2 | =============================================================================
|
|---|
| 3 | mangle.c -- mangle a bit stream
|
|---|
| 4 | Version 2 -- 1987-08-28 -- D.N. Lynx Crowe
|
|---|
| 5 | (c) Copyright 1987 - D.N. Lynx Crowe
|
|---|
| 6 | =============================================================================
|
|---|
| 7 | */
|
|---|
| 8 |
|
|---|
| 9 | /*
|
|---|
| 10 | =============================================================================
|
|---|
| 11 | mangle(bitmap, nb, ib) -- reorder the 'nb' least significant bits
|
|---|
| 12 | in 'ib' according to 'bitmap'. Assumes that 'bitmap' is at least 'nb'
|
|---|
| 13 | words long, and that nb <= 32. The 'bitmap' translation table contains
|
|---|
| 14 | an output word for each bit in the input word, with each 'bitmap' entry
|
|---|
| 15 | corresponding to the bit number matching its index. For example,
|
|---|
| 16 | 'bitmap[0]' contains the word which will be 'OR'ed into the output if
|
|---|
| 17 | the least significant bit of the input word is set, while 'bitmap[31]'
|
|---|
| 18 | corresponds to the most significant bit of the input word.
|
|---|
| 19 | =============================================================================
|
|---|
| 20 | */
|
|---|
| 21 |
|
|---|
| 22 | long
|
|---|
| 23 | mangle(bitmap, nb, ib)
|
|---|
| 24 | register long *bitmap; /* bit map table pointer */
|
|---|
| 25 | register short nb; /* number of least significant input bits */
|
|---|
| 26 | register long ib; /* input data (in nb least significant bits) */
|
|---|
| 27 | {
|
|---|
| 28 | register long bm; /* scan mask */
|
|---|
| 29 | register long rv; /* result value */
|
|---|
| 30 | register short bn; /* bit number (bitmap index) */
|
|---|
| 31 |
|
|---|
| 32 | bm = 0x00000001L; /* setup scan mask */
|
|---|
| 33 | rv = 0x00000000L; /* clear the output word */
|
|---|
| 34 |
|
|---|
| 35 | for (bn = 0; bn < nb; bn++) { /* scan across nb bits */
|
|---|
| 36 |
|
|---|
| 37 | if (ib & bm) /* if the input bit is 1 */
|
|---|
| 38 | rv |= bitmap[bn]; /* 'OR' the bitmap into rv */
|
|---|
| 39 |
|
|---|
| 40 | bm <<= 1; /* shift the scan mask left */
|
|---|
| 41 | }
|
|---|
| 42 |
|
|---|
| 43 | return(rv); /* return rv as the result */
|
|---|
| 44 | }
|
|---|