123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311 |
- #include <stdio.h>
- #include <unistd.h>
- #include <malloc.h>
- #include "emitlib.h"
- unsigned int timings[4][2] = {
- {250, 250},
- {250, 1200},
- {250, 2600},
- {250, 9900}
- };
- unsigned char numbering[4] = {0x05, 0x06, 0x09, 0x0A};
- BIT_BUFFER createBitBuffer()
- {
- BIT_BUFFER buffer;
- buffer.byteSize = 1;
- buffer.bitSize = 0;
- buffer.data = (char*) malloc(1);
- buffer.data[0] = 0;
- return buffer;
- }
- void destroyBitBuffer(BIT_BUFFER buffer)
- {
- free(buffer.data);
- }
- BIT_BUFFER createByteBuffer()
- {
- BYTE_BUFFER buffer;
- buffer.size = 0;
- buffer.data = (char*) malloc(1);
- return buffer;
- }
- void destroyByteBuffer(BIT_BUFFER buffer)
- {
- free(buffer.data);
- }
- void printfBitBuffer(BIT_BUFFER buffer)
- {
- printf("bytes: %d\nbits: %d\n", buffer.byteSize, buffer.bitSize);
- unsigned char byte;
- unsigned char bit;
- unsigned int x;
- int i;
- for(x=0; x<buffer.byteSize; x++) {
- byte = buffer.data[x];
- for(i=0x80; i>0; i>>=1) {
- if ((bit==0) && (byte & i)) {
- fprintf(stdout, "\n");
- }
- bit = ((byte & i) == i);
- fprintf(stdout, "%d", bit);
- }
- }
- }
- void printfByteBuffer(BYTE_BUFFER buffer)
- {
- unsigned int i;
- for(i=0; i<buffer.size; i++) {
- fprintf(stdout, "%02X ", buffer.data[i];
- }
- }
- void pushBit(BIT_BUFFER* buffer, unsigned char bit)
- {
- buffer->data[buffer->byteSize-1] |= bit << (7-buffer->bitSize);
- buffer->bitSize++;
- if (buffer->bitSize == 8) {
- buffer->bitSize = 0;
- buffer->byteSize++;
- buffer->data = (char*)realloc(buffer->data, buffer->byteSize);
- buffer->data[buffer->byteSize-1] = 0;
- }
- }
- void pushByte(BYTE_BUFFER* buffer, unsigned char byte)
- {
- buffer->size++
- buffer->data = (char*)realloc(buffer->size);
- buffer->data[buffer->size-1] = byte;
- }
- void pushWord(BYTE_BUFFER* buffer, unsigned short int word)
- {
- unsigned char* data = &word;
- pushByte(buffer, data[1]);
- pushByte(buffer, data[0]);
- }
- void pushBytes(BYTE_BUFFER* buffer, unsigned char *byte, unsigned int len)
- {
- buffer->data = (char*)realloc(buffer->size+len);
- memcpy(&buffer->data[buffer->size], byte, len);
- buffer->size += len;
- }
- BYTE_BUFFER homeEasyEncode(BYTE_BUFFER *buffer)
- {
- BYTE_BUFFER result = createByteBuffer();
- unsigned char byte;
- unsigned char encodedByte;
- unsigned int i;
- for(i=0; i<buffer->size; i++) {
- byte = buffer->data[i];
- pushWord(buffer, encodeByte(byte);
- }
- return result;
- }
- BYTE_BUFFER homeEasyDecode(BYTE_BUFFER *buffer)
- {
- BYTE_BUFFER result = createByteBuffer();
- unsigned short int word;
- unsigned char *byte = &word;
- unsigned int i;
- for(i=0; i<(buffer->size+1)/2; i++) {
- byte[1] = buffer->data[2*i];
- byte[0] = (2*i+1 < buffer->size ? buffer->data[2*i+1]:0);
- pushByte(buffer, decodeByte(word));
- }
- return result;
- }
- unsigned char decodeByte(unsigned short int byte)
- {
- unsigned char decodedChar=0;
- int j;
- int shift = 6;
- for(j=0x8000;j>0; j>>=2) {
- decodedChar |= (((byte & j) == j) ? 0x01 : 0x00) << shift;
- shift -=1;
- }
- return decodedChar;
- }
- unsigned short int encodeByte(unsigned char byte)
- {
- unsigned short int encodedChar=0;
- int j;
- int shift = 6;
- for(j=0x80;j>0; j>>=1) {
- encodedChar |= (((byte & j) == j) ? 0x02 : 0x01) << shift;
- shift -=2;
- }
- return encodedChar;
- }
- void appendBit(BIT_BUFFER* buffer, unsigned char bit, unsigned int usec, unsigned int freq)
- {
- unsigned int i;
- for(i=0; i<(usec * freq) / 1e6; i++) {
- pushBit(buffer, bit);
- }
- }
- void appendData(BIT_BUFFER* buffer, unsigned int type, unsigned int freq)
- {
- appendBit(buffer, 1, timings[type][0], freq);
- appendBit(buffer, 0, timings[type][1], freq);
- }
- void appendByte(BIT_BUFFER* buffer, unsigned char byte, unsigned int freq)
- {
- int i;
- for(i=0x80; i>0; i>>=1) {
- appendData(buffer, ((byte & i) == i), freq);
- }
- printf("%02X ", byte);
- }
- void pushCode(BIT_BUFFER* buffer, unsigned char* id, unsigned char section, unsigned char nb, unsigned char on, unsigned char global, unsigned int freq)
- {
- unsigned char byte6 = (id[6] & 0xf0) + numbering[on + (global ? 2 : 0)];
- unsigned char byte7 = (numbering[section] << 4) + numbering[nb];
- unsigned int i;
- if (global) {
- byte7 = 0x55;
- }
- appendData(buffer, START_OF_FRAME, freq);
- printf("SOF ");
- for(i=0; i<6; i++) {
- appendByte(buffer, id[i], freq);
- }
- appendByte(buffer, byte6, freq);
- appendByte(buffer, byte7, freq);
- appendData(buffer, END_OF_DATA, freq);
- printf("EOD ");
- }
|