hsk_libs-dev  163:b63ae088cc97
High Speed Karlsruhe XC878 library collection
 All Data Structures Files Functions Variables Typedefs Macros Groups Pages
hsk_icm7228.c File Reference

HSK ICM7228 8-Digit LED Display Decoder Driver implementation. More...

#include <Infineon/XC878.h>
#include "hsk_icm7228.h"
Include dependency graph for hsk_icm7228.c:

Macros

#define ILLUMINATE_OFFSET   16
 The offset for illuminating a number of segments. More...
 

Functions

void hsk_icm7228_writeString (ubyte *const buffer, const char *str, ubyte pos, ubyte len)
 Convert an ASCII string to 7 segment encoding and store it in an xdata buffer. More...
 
void hsk_icm7228_writeDec (ubyte *const buffer, uword value, char power, const ubyte pos, ubyte len)
 Write a 7 segment encoded, right aligned decimal number into an xdata buffer. More...
 
void hsk_icm7228_writeHex (ubyte *const buffer, uword value, char power, const ubyte pos, ubyte len)
 Write a 7 segment encoded, right aligned hexadecimal number into an xdata buffer. More...
 
void hsk_icm7228_illuminate (ubyte *const buffer, ubyte segments, ubyte pos, ubyte len)
 Illumante the given number of segments. More...
 

Variables

const char hsk_icm7228_codepage []
 This is a codepage to translate 7bit ASCII characters into corresponding 7 segment display patterns. More...
 

Detailed Description

HSK ICM7228 8-Digit LED Display Decoder Driver implementation.

This file implements the static functions of the ICM7228 display decoder driver.

See Also
Intersil ICM7228 Data Sheet: ICM7228.pdf
Author
kami

Macro Definition Documentation

#define ILLUMINATE_OFFSET   16

The offset for illuminating a number of segments.

Function Documentation

void hsk_icm7228_illuminate ( ubyte *const  buffer,
ubyte  segments,
ubyte  pos,
ubyte  len 
)

Illumante the given number of segments.

Parameters
bufferThe target buffer for the encoded string
segmentsThe number of segments to illuminate
posThe target position in the buffer
lenThe number of digits available to encode the number
void hsk_icm7228_writeDec ( ubyte *const  buffer,
uword  value,
char  power,
const ubyte  pos,
ubyte  len 
)

Write a 7 segment encoded, right aligned decimal number into an xdata buffer.

The power parameter controlls the placing of the '.' by 10 to the power. E.g. value = 12, power = -1 and len = 3 would result in the encoding of " 1.2". If power = 0, no dot is drawn. If the power is positive (typically 1), the resulting string would be filled with '0' characters. I.e. the previous example with power = 1 would result in an encoding of "012".

Parameters
bufferThe target buffer for the encoded string
valueThe number to encode
powerThe 10 base power of the number to encode
posThe target position in the buffer
lenThe number of digits available to encode the number
void hsk_icm7228_writeHex ( ubyte *const  buffer,
uword  value,
char  power,
const ubyte  pos,
ubyte  len 
)

Write a 7 segment encoded, right aligned hexadecimal number into an xdata buffer.

The power parameter controlls the placing of the '.' by 16 to the power. E.g. value = 0x1A, power = -1 and len = 3 would result in the encoding of " 1.A". If power = 0, no dot is drawn. If the power is positive (typically 1), the resulting string would be filled with '0' characters. I.e. the previous example with power = 1 would result in an encoding of "01A".

Parameters
bufferThe target buffer for the encoded string
valueThe number to encode
powerThe 16 base power of the number to encode
posThe target position in the buffer
lenThe number of digits available to encode the number
void hsk_icm7228_writeString ( ubyte *const  buffer,
const char *  str,
ubyte  pos,
ubyte  len 
)

Convert an ASCII string to 7 segment encoding and store it in an xdata buffer.

This function is usually invoked through the <prefix>_writeString() function created by ICM7228_FACTORY.

The function will write into the buffer until it has been filled with len characters or it encounters a 0 character reading from str. If the character '.' is encountered it is merged with the previous character, unless that character is a '.' itself. Thus a single dot does not use additional buffer space. The 7 character string "foo ..." would result in 6 encoded bytes. Thus the proper len value for that string would be 6.

Parameters
bufferThe target buffer for the encoded string
strThe buffer to read the ASCII string from
posThe position in the buffer to write the encoded string to
lenThe target length of the encoded string

Variable Documentation

const char hsk_icm7228_codepage[]
Initial value:
= {
0xFB, 0xB0, 0xED, 0xF5, 0xB6, 0xD7, 0xDF, 0xF0,
0xFF, 0xF7, 0xFE, 0x9F, 0xCB, 0xBD, 0xCF, 0xCE,
0x80, 0xC0, 0xE0, 0xF0, 0xF1, 0xF9, 0xFB, 0xFF,
0x7F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x80, 0x00, 0x00, 0x00, 0x00, 0x82, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0xFB, 0xB0, 0xED, 0xF5, 0xB6, 0xD7, 0xDF, 0xF0,
0xFF, 0xF7, 0xFE, 0x9F, 0xCB, 0xBD, 0xCF, 0xCE,
0x00, 0xFE, 0x9F, 0xCB, 0xBD, 0xCF, 0xCE, 0xDF,
0xBE, 0x8A, 0xB1, 0xDE, 0x8B, 0xFA, 0xFA, 0x9D,
0xEE, 0xF6, 0x8C, 0xD7, 0x8F, 0xBB, 0x99, 0xBB,
0xB4, 0xB6, 0xC5, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0xFE, 0x9F, 0xCB, 0xBD, 0xCF, 0xCE, 0xDF,
0xBE, 0x8A, 0xB1, 0xDE, 0x8B, 0xFA, 0xFA, 0x9D,
0xEE, 0xF6, 0x8C, 0xD7, 0x8F, 0xBB, 0x99, 0xBB,
0xB4, 0xB6, 0xC5, 0x00, 0x00, 0x00, 0x00, 0x00
}

This is a codepage to translate 7bit ASCII characters into corresponding 7 segment display patterns.

The ASCII character can be used to receive the desired 7 segment code. E.g. hsk_icm7228_codepage['A'] retrieves the letter 'A' from the table.

Some letters like 'X' are badly recognisable, others cannot be well represented at all. E.g. the letters 'M' and 'W' are identical to the letters 'N' and 'U'.

Capitals and small characters are identical. Characters without proper encoding are filled with 0x00, which leaves only the '.' of a 7 segment display active.

The 6 characters beyond 0-9 return "ABCDEF", which permits for easier display of HEX digits.

The first 16 characters from index 0 return the characters "0123456789ABCDEF" as well.