Modularizando o src

Dependencies:   EALib EthernetInterface_vz mbed-rtos mbed

Fork of header_main_colinas_V0-20-09-14 by VZTECH

Committer:
klauss
Date:
Wed May 20 19:50:31 2015 +0000
Revision:
126:1f90756250fb
Parent:
125:8ff4dc96ad58
Child:
129:d73538fbc017
under validation

Who changed what in which revision?

UserRevisionLine numberNew contents of line
klauss 69:65665afbad5d 1 /**
klauss 69:65665afbad5d 2 * @file vz_protocol.h
klauss 69:65665afbad5d 3 * @Synopsis Implementa as principais funcionalidades do protocolo de comunicação entre os CBx -> Header e Header -> CBx.
klauss 69:65665afbad5d 4 * @author Jhonatan Casale
klauss 69:65665afbad5d 5 * @version 1
klauss 69:65665afbad5d 6 * @date 2014-11-05
klauss 69:65665afbad5d 7 */
klauss 69:65665afbad5d 8
klauss 74:81c47fff88a5 9 #ifndef __VZ_PROTOCOL_H__
klauss 74:81c47fff88a5 10 #define __VZ_PROTOCOL_H__
klauss 0:4d17cd9c8f9d 11
klauss 121:ee02790d00b7 12 #include "EthernetInterface.h"
klauss 121:ee02790d00b7 13 #include "mbed.h"
klauss 121:ee02790d00b7 14 #include <string.h>
klauss 0:4d17cd9c8f9d 15 #include <stdlib.h>
klauss 0:4d17cd9c8f9d 16 #include <stdint.h>
klauss 121:ee02790d00b7 17 #include "debug.h"
klauss 0:4d17cd9c8f9d 18 #include "bits.h"
klauss 119:ee6a53069455 19 #include "clock.h"
klauss 121:ee02790d00b7 20 #include "utils.h"
klauss 122:480c44b0e205 21 #include "shared_variables.h"
klauss 122:480c44b0e205 22
klauss 0:4d17cd9c8f9d 23
klauss 119:ee6a53069455 24 const uint16_t SHIFT_PORT = 3000;
klauss 121:ee02790d00b7 25 ///< Deslocamento padrão de porta, usado na forma <ext recebido + SHIFT_PORT>
klauss 119:ee6a53069455 26
klauss 119:ee6a53069455 27 const uint8_t MIN_EXT = 1;
klauss 121:ee02790d00b7 28 ///< Define o valor minimo de ramal que sera processado.
klauss 121:ee02790d00b7 29
klauss 81:3656f00ab3db 30 extern int begin;
klauss 121:ee02790d00b7 31 ///< Registra o numero do menor ramal conhecido pela header até o momento
klauss 81:3656f00ab3db 32
klauss 119:ee6a53069455 33 const uint16_t MAX_EXT = 5999;
klauss 121:ee02790d00b7 34 ///< Define o valor máximo de ramal que sera processado.
klauss 79:9bc12aa305a9 35
klauss 121:ee02790d00b7 36 extern int end;
klauss 121:ee02790d00b7 37 ///< Registra o numero do maior ramal conhecido pela header até o momento
klauss 36:728498a78e1e 38
klauss 119:ee6a53069455 39 const uint8_t VZ_HEADER_OFFSET = 7;
klauss 69:65665afbad5d 40 ///< Indica o inicio dos dados recebidos efetivamente no pacote VZ.
klauss 121:ee02790d00b7 41
klauss 119:ee6a53069455 42 const uint8_t CLOCK_SYNC_SIZE = 14;
klauss 69:65665afbad5d 43 ///< Indica o numero de bytes ocupados pelo relogio no pacote transmitido.
klauss 121:ee02790d00b7 44
klauss 119:ee6a53069455 45 const uint8_t SEQ_NUM_SIZE = 1;
klauss 69:65665afbad5d 46 ///< Indica o numero de bytes ocupados para uso de sequence number.
klauss 121:ee02790d00b7 47
klauss 126:1f90756250fb 48 const uint8_t SEQ_NUM_PLACE = 7;
klauss 126:1f90756250fb 49 ///< Indica o numero de bytes ocupados para uso de sequence number.
klauss 126:1f90756250fb 50
klauss 119:ee6a53069455 51 const uint8_t CB_AUDIO_DATA_SIZE = 240;
klauss 69:65665afbad5d 52 ///< Indica o numero de pacotes enviados pelo CBx referente a dados de audio.
klauss 121:ee02790d00b7 53
klauss 119:ee6a53069455 54 const uint8_t TIMESLICE_PLACE = 22;
klauss 69:65665afbad5d 55 ///< Indica o local ( em relação ao começo do pacote ) onde se encontra o timeslice.
klauss 0:4d17cd9c8f9d 56
klauss 125:8ff4dc96ad58 57 const uint8_t TYPE_PLACE = 6;
klauss 125:8ff4dc96ad58 58 ///< Indica o local ( em relação ao começo do pacote ) onde se encontra o timeslice.
klauss 125:8ff4dc96ad58 59
klauss 119:ee6a53069455 60 const uint16_t BASE_PORT = 5000;
klauss 119:ee6a53069455 61 ///< Estabelece o menor ramal aceito para tratamento
klauss 119:ee6a53069455 62
klauss 119:ee6a53069455 63 const uint8_t MAX_CB_IN_A_BRANCH = 52;
klauss 78:1353744f01e1 64 ///< Estabelece o nro máximo de CBx em um mesmo ramo
klauss 69:65665afbad5d 65
klauss 119:ee6a53069455 66 const uint8_t BOOT = 0x00;
klauss 69:65665afbad5d 67 ///< Indica o tipo boot, enviado pelo CBx, assim que o mesmo liga ou sofre reboot.
klauss 100:09a23fcd3bdf 68
klauss 119:ee6a53069455 69 const uint8_t REGISTRY = 0x02;
klauss 69:65665afbad5d 70 ///< Tipo de registro, enviado pelo CBx, quando o mesmo quer se registrar, enviado pela Header para verificar se determinado CBx ainda esta ativo.
klauss 121:ee02790d00b7 71
klauss 126:1f90756250fb 72 const uint8_t REGISTRY_ACK = 0x02 or BIT7;
klauss 121:ee02790d00b7 73 ///< "ack de resposta" do tiop REGISTRY
klauss 100:09a23fcd3bdf 74
klauss 119:ee6a53069455 75 const uint8_t INVITE = 0x04;
klauss 69:65665afbad5d 76 ///< Representa o tipo de pedido de invite, enviado pelo CBx sempre quando o mesmo quer iniciar uma ligação com o server.
klauss 121:ee02790d00b7 77
klauss 126:1f90756250fb 78 const uint8_t INVITE_ACK = 0x04 or BIT7;
klauss 121:ee02790d00b7 79 ///< "ack de resposta" do tiop INVITE
klauss 100:09a23fcd3bdf 80
klauss 119:ee6a53069455 81 const uint8_t AUDIO = 0x08;
klauss 69:65665afbad5d 82 ///< Pacotes do tipo audio são trocados entre Header e CBx durante a ligação, representam os dados RTP.
klauss 119:ee6a53069455 83
klauss 119:ee6a53069455 84 const uint8_t TELEMETRY = 0x10;
klauss 69:65665afbad5d 85 ///< Define o tipo de pacote de telemetria enviado pelo CBx.
klauss 119:ee6a53069455 86
klauss 119:ee6a53069455 87 const uint8_t BOOTLOADER_CBX = 0x03;
klauss 114:472502b31a12 88 ///< Define o tipo de pacote para a gravação do CBx
klauss 119:ee6a53069455 89
klauss 119:ee6a53069455 90 const uint8_t CB_BYE = 0x20;
klauss 69:65665afbad5d 91 ///< Representa o tipo de pacote que o CBx envia para a Header solicitando o final da ligação.
klauss 121:ee02790d00b7 92
klauss 126:1f90756250fb 93 const uint8_t CB_BYE_ACK = 0x20 or BIT7;
klauss 121:ee02790d00b7 94 ///< "ack de resposta" do tiop CB_BYE
klauss 119:ee6a53069455 95
klauss 119:ee6a53069455 96 const uint8_t PROMPT = 0x01;
klauss 69:65665afbad5d 97 ///< Identifica o tipo de pacote responsavel por mandar comandos executáveis no Cbx.
klauss 119:ee6a53069455 98
klauss 119:ee6a53069455 99 const uint8_t FLOOD = 0x40;
klauss 69:65665afbad5d 100 ///< Representa os pacotes de flood, úteis para validação de comunicação Header-CBx.
klauss 119:ee6a53069455 101
klauss 119:ee6a53069455 102 const uint8_t FW = 0x50;
klauss 99:e80850c51106 103 ///< Tipo para redirecionamento semn tratamento para uma determinada porta UDP pré-configurada.
klauss 121:ee02790d00b7 104
klauss 119:ee6a53069455 105 const uint8_t FW1 = 0x51;
klauss 99:e80850c51106 106 ///< Tipo para redirecionamento semn tratamento para uma determinada porta UDP pré-configurada.
klauss 121:ee02790d00b7 107
klauss 119:ee6a53069455 108 const uint8_t FW2 = 0x52;
klauss 119:ee6a53069455 109 ///< Tipo para redirecionamento semn tratamento para uma determinada porta UDP pré-configurada.
klauss 121:ee02790d00b7 110
klauss 119:ee6a53069455 111 const uint8_t FW3 = 0x53;
klauss 99:e80850c51106 112 ///< Tipo para redirecionamento semn tratamento para uma determinada porta UDP pré-configurada.
klauss 121:ee02790d00b7 113
klauss 119:ee6a53069455 114 const uint8_t FW4 = 0x54;
klauss 99:e80850c51106 115 ///< Tipo para redirecionamento semn tratamento para uma determinada porta UDP pré-configurada.
klauss 121:ee02790d00b7 116
klauss 119:ee6a53069455 117 const uint8_t FW5 = 0x55;
klauss 99:e80850c51106 118 ///< Tipo para redirecionamento semn tratamento para uma determinada porta UDP pré-configurada.
klauss 121:ee02790d00b7 119
klauss 119:ee6a53069455 120 const uint8_t FW6 = 0x56;
klauss 99:e80850c51106 121 ///< Tipo para redirecionamento semn tratamento para uma determinada porta UDP pré-configurada.
klauss 99:e80850c51106 122
klauss 119:ee6a53069455 123 const uint8_t CB_STATS = 0x07;
klauss 121:ee02790d00b7 124 ///< Tipo de comunicação de estatisticas de rede, enviadas pela CBx
klauss 121:ee02790d00b7 125
klauss 126:1f90756250fb 126 const uint8_t CB_STATS_ACK = 0x07 or BIT7;
klauss 121:ee02790d00b7 127 ///< "ack de resposta" do tiop CB_STATS_ACK
klauss 121:ee02790d00b7 128
klauss 123:1d395b5a4cad 129 const uint16_t BROADCAST_EXT = 0xf0f3;
klauss 121:ee02790d00b7 130 ///< Ramal de broadcast, usado na comunicação Header -> CBx
klauss 99:e80850c51106 131
klauss 119:ee6a53069455 132 const uint8_t DO_NOTHING = 0x7f;
klauss 69:65665afbad5d 133 ///< Representa o tipo de idle, importante para algumas comunicações.
klauss 0:4d17cd9c8f9d 134
klauss 119:ee6a53069455 135 const char MY_IP[] = "192.168.120.171";
klauss 69:65665afbad5d 136 ///< Representa o IP default da Header.
klauss 119:ee6a53069455 137 //#define __MY_IP__ "192.168.2.20?" // Colinas
klauss 119:ee6a53069455 138 //#define __MY_IP__ "192.168.1.200" // Colinas
klauss 119:ee6a53069455 139
klauss 119:ee6a53069455 140 const uint16_t MY_EXT = 820;
klauss 69:65665afbad5d 141 ///< Indica o ramal default da Header.
klauss 119:ee6a53069455 142
klauss 119:ee6a53069455 143 const uint16_t MY_PORT = 5062;
klauss 69:65665afbad5d 144 ///< Representa a porta default da Header.
klauss 28:94aec56c6329 145
klauss 119:ee6a53069455 146 const char SERVER_IP[] = "192.168.120.120";
klauss 69:65665afbad5d 147 ///< Indica o IP defaut do servidor para onde a Header ira encaminhar pedidos de ligação.
klauss 119:ee6a53069455 148 //#define __SERVER_IP__ "192.168.30.25" // Colinas
klauss 29:7246460b73f8 149
klauss 119:ee6a53069455 150 const uint16_t PEER_EXT = 913;
klauss 119:ee6a53069455 151 ///< Estabelece o ramal default para onde a Header ira direcionar os pedidos de ligações.
klauss 119:ee6a53069455 152 //#define __PEER_EXT__ 812 // VZ Producao
klauss 119:ee6a53069455 153 //#define __PEER_EXT__ 813 // VZ Desenvolvimento
klauss 69:65665afbad5d 154
klauss 119:ee6a53069455 155 const uint16_t SERVER_PORT = 5075;
klauss 69:65665afbad5d 156 ///< Indica a porta default do server para onde os pacotes eth serão enviados na negociação SIP.
klauss 119:ee6a53069455 157 //#define __SERVER_PORT__ 5060 // Colinas
klauss 28:94aec56c6329 158
klauss 119:ee6a53069455 159 const char MY_MSK[] = "255.255.255.0";
klauss 69:65665afbad5d 160 ///< Indica a mascara de rede onde a Header se encontra.
klauss 119:ee6a53069455 161 //#define __MY_GTW__ "192.168.2.254" // Colinas
klauss 119:ee6a53069455 162
klauss 119:ee6a53069455 163 const char MY_GTW[] = "192.168.120.1"; // vz
klauss 69:65665afbad5d 164 ///< Indica o IP do Gateway de rede
Cola 20:2d6ab23956e5 165
klauss 119:ee6a53069455 166 const uint16_t RX_CB_IDLE = 300;
klauss 121:ee02790d00b7 167 ///< Tempo maximo ( countdown em segundos ) que a Header espera por algum pacote no lado fibra, deixa de tickar o wdt.
klauss 121:ee02790d00b7 168
klauss 119:ee6a53069455 169 const uint16_t ETH_CONNECT_TIMEOUT = 330;
klauss 121:ee02790d00b7 170 ///< Tempo maximo ( countdown em segundos ) que a Header espera tentando conectar na interface ETH, deixa de tickar o wdt quando chega em zero.
klauss 119:ee6a53069455 171
klauss 119:ee6a53069455 172 const uint16_t RTP_MSG_SIZE = 160;
klauss 121:ee02790d00b7 173 ///< Tamanho em bytes ocupados pelos pacotes de audio no sentido * -> Header -> CBx
klauss 81:3656f00ab3db 174
klauss 78:1353744f01e1 175 extern uint32_t pkg_zero;
klauss 78:1353744f01e1 176 ///< Contador de pacotes contendo somente zeros
klauss 121:ee02790d00b7 177
klauss 78:1353744f01e1 178 extern uint32_t pkg_ckserr;
klauss 69:65665afbad5d 179 ///< Contador de pacotes em que o checksum resultou divergente do calculado/recebido
klauss 121:ee02790d00b7 180
klauss 78:1353744f01e1 181 extern uint32_t pkg_cksok;
klauss 69:65665afbad5d 182 ///< Contador de pacotes em que o checksum resultou o mesmo calculado e o recebido
klauss 0:4d17cd9c8f9d 183
klauss 69:65665afbad5d 184 /**
klauss 69:65665afbad5d 185 * @Synopsis Calcula o checksum do pacote.
klauss 69:65665afbad5d 186 *
klauss 69:65665afbad5d 187 * @param buffer Um ponteiro para a região de memória onde os dados de interesse estão localizados.
klauss 69:65665afbad5d 188 * @param length O numero de elementos que serão considerados no cálculo do checksum
klauss 69:65665afbad5d 189 *
klauss 69:65665afbad5d 190 * @return 0 - caso em que o vetor apontado por buffer estiver setado em NULL. O checksum propriamente
klauss 69:65665afbad5d 191 * calculado caso contrário.
klauss 69:65665afbad5d 192 *
klauss 69:65665afbad5d 193 * Exemplo:
klauss 69:65665afbad5d 194 * @code
klauss 69:65665afbad5d 195 * ...
klauss 69:65665afbad5d 196 * // onde cb_buffer contém os dados vindos do Call_Box, Obs. as posições 4 e 5 contém o MSB e LSB do CC calculado pelo Call_Box.
klauss 126:1f90756250fb 197 * uint16_t cc = ( uint16_t )cb_buffer[ 4 ] << 8 or cb_buffer[ 5 ];
klauss 114:472502b31a12 198 * if( cc != __checksum__( cb_buffer, __CB_BUFFER_SIZE__ ) ){
klauss 69:65665afbad5d 199 * //faça alguma coisa ...
klauss 69:65665afbad5d 200 * }
klauss 69:65665afbad5d 201 * ...
klauss 69:65665afbad5d 202 * @endcode
klauss 69:65665afbad5d 203 */
klauss 121:ee02790d00b7 204 uint16_t vz_checksum ( uint8_t * buffer, size_t length );
klauss 0:4d17cd9c8f9d 205
klauss 0:4d17cd9c8f9d 206 /* incorporar a parte de cc */
klauss 69:65665afbad5d 207 /**
klauss 69:65665afbad5d 208 * @Synopsis Esta é a função responsável por, dado um pacote recebido dos CBx, quebra-lo em ramal( ext ), porta, type e dados.
klauss 69:65665afbad5d 209 *
klauss 69:65665afbad5d 210 * @param ext Um ponteiro para onde sera setado o ramal do CBx que enviou este pacote.
klauss 69:65665afbad5d 211 * @param port Um ponteiro para onde sera setado a porta do CBx que enviou este pacote.
klauss 69:65665afbad5d 212 * @param type Um ponteiro para onde sera setado o type de mensagem enviada pelo CBx.
klauss 69:65665afbad5d 213 * @param cb_buffer O pacote que se deseja decodificar.
klauss 69:65665afbad5d 214 *
klauss 69:65665afbad5d 215 * @return NULL, caso em que o checksum( cc ) calculado não bater com o cc recebido no pacote, retorna NULL também em pacotes do
klauss 69:65665afbad5d 216 * tipo flood, ou no caso em que o pacote recebido para processamento apontar para NULL; em todos esses casos os valores de ext,
klauss 69:65665afbad5d 217 * port e type devem ser desconsiderados para manter a integridade do processamento; retorna um ponteiro para o inicio dos dados
klauss 69:65665afbad5d 218 * enviados pelo CBx e seta ramal, porta e type nos casos em que o pacote recebido for válidado pelo protocolo.
klauss 69:65665afbad5d 219 *
klauss 69:65665afbad5d 220 * Exemplo:
klauss 69:65665afbad5d 221 * @code
klauss 69:65665afbad5d 222 * ...
klauss 69:65665afbad5d 223 * int ext, port, type;
klauss 114:472502b31a12 224 * uint8_t * data, buffer[ __CB_BUFFER_SIZE__ ];
klauss 69:65665afbad5d 225 * //assumindo que os dados vindos do Call_Box estão armazenados em buffer;
klauss 114:472502b31a12 226 * data = __parse_vz_pkg__( &ext, &port, &type, buffer );
klauss 69:65665afbad5d 227 * ...
klauss 69:65665afbad5d 228 * @endcode
klauss 69:65665afbad5d 229 */
klauss 69:65665afbad5d 230
klauss 69:65665afbad5d 231 /**
klauss 69:65665afbad5d 232 * \note Formato do pacote VZ :
klauss 69:65665afbad5d 233 *
klauss 69:65665afbad5d 234 * | E | E | P | P | C | C | T | [ Seq_num | Audio ] | 14[ Clock | Audio ] | [ TS | Audio ] |...|
klauss 69:65665afbad5d 235 *
klauss 69:65665afbad5d 236 * E = Ext = Ramal
klauss 69:65665afbad5d 237 *
klauss 69:65665afbad5d 238 * P = Port = Porta
klauss 69:65665afbad5d 239 *
klauss 69:65665afbad5d 240 * C = Checksum
klauss 69:65665afbad5d 241 *
klauss 69:65665afbad5d 242 * T = Type = Tipo
klauss 69:65665afbad5d 243 *
klauss 69:65665afbad5d 244 * Seq_num = Sequence Number = Numero de sequencia
klauss 69:65665afbad5d 245 *
klauss 69:65665afbad5d 246 * Clock = 14 bytes to sync
klauss 69:65665afbad5d 247 *
klauss 114:472502b31a12 248 * ...= demais __CB_BUFFER_SIZE__ - __VZ_HEADER_OFFSET__ bytes
klauss 69:65665afbad5d 249 *
klauss 69:65665afbad5d 250 */
klauss 121:ee02790d00b7 251 uint8_t * parse_vz_pkg ( int * ext, int * port, volatile uint8_t * type, uint8_t * cb_buffer );
klauss 69:65665afbad5d 252
klauss 69:65665afbad5d 253 /**
klauss 69:65665afbad5d 254 * @Synopsis Função responsavel por montar o pacote para envio para o CBx seguindo o formato do protocolo VZ.
klauss 69:65665afbad5d 255 *
klauss 69:65665afbad5d 256 * @param ext O ramal do CBx destino deste pacote.
klauss 69:65665afbad5d 257 * @param port A porta do CBx destino deste pacote.
klauss 69:65665afbad5d 258 * @param type O tipo do pacote que será enviado para o CBx.
klauss 69:65665afbad5d 259 * @param cb_buffer Os dados que serão colocados nesse pacote.
klauss 69:65665afbad5d 260 * @param seq_num O numero do sequência deste pacote.
klauss 69:65665afbad5d 261 * @param length O tamanho ( em bytes ) dos dados que serão enviados.
klauss 69:65665afbad5d 262 * @param pkg Um ponteiro que recebera o pacote montado e pronto para envio.
klauss 69:65665afbad5d 263 *
klauss 69:65665afbad5d 264 * @return O pacote montado e pronto para envio.
klauss 69:65665afbad5d 265 *
klauss 69:65665afbad5d 266 * Exemplo:
klauss 69:65665afbad5d 267 * @code
klauss 69:65665afbad5d 268 * ...
klauss 69:65665afbad5d 269 * int ext = 1011;
klauss 69:65665afbad5d 270 * port = 1011;
klauss 69:65665afbad5d 271 * type = __REGISTRY__;
klauss 114:472502b31a12 272 * send2callboxes( __build_cb_package__( ext, port, type,
klauss 114:472502b31a12 273 * ( char * )data, cb->get_msg_id(), __CB_BUFFER_SIZE__ - __VZ_HEADER_OFFSET__, write_buffer ) );
klauss 69:65665afbad5d 274 * ...
klauss 69:65665afbad5d 275 * @endcode
klauss 69:65665afbad5d 276 */
klauss 126:1f90756250fb 277 uint8_t * build_cb_package ( const int ext, const int port, const uint8_t type, const char * cb_buffer, const uint8_t seq_num, const int length, uint8_t * pkg );
klauss 69:65665afbad5d 278
klauss 69:65665afbad5d 279 /**
klauss 69:65665afbad5d 280 * @Synopsis Obtém uma referência de clock de um servidor.
klauss 69:65665afbad5d 281 *
klauss 69:65665afbad5d 282 * @param buffer Imprime a referência do relógio nesta posição de memória.
klauss 69:65665afbad5d 283 *
klauss 69:65665afbad5d 284 * \note Por definição de projeto, o relógio ocupa 14 bytes, seguindo o formato
klauss 69:65665afbad5d 285 *
klauss 69:65665afbad5d 286 * | ano | ano | ano | ano | mes | mes | dia | dia | hora | hora | minuto | minuto | segundo | segundo |
klauss 69:65665afbad5d 287 *
klauss 69:65665afbad5d 288 * Exemplo:
klauss 69:65665afbad5d 289 *
klauss 69:65665afbad5d 290 * 20141105101235
klauss 69:65665afbad5d 291 */
klauss 0:4d17cd9c8f9d 292
klauss 121:ee02790d00b7 293 int init_ranges ( void );
klauss 81:3656f00ab3db 294
klauss 122:480c44b0e205 295 /**
klauss 122:480c44b0e205 296 * @Synopsis Converte o current_time do sistema para string.
klauss 122:480c44b0e205 297 *
klauss 122:480c44b0e205 298 * @param buffer Buffer de escrita onde sera preenchido com o current_time no formato VZ
klauss 122:480c44b0e205 299 *
klauss 122:480c44b0e205 300 * Exemplo:
klauss 122:480c44b0e205 301 * @code
klauss 122:480c44b0e205 302 * ...
klauss 122:480c44b0e205 303 * char buffer [ 16 ];
klauss 122:480c44b0e205 304 * print_clock ( buffer );
klauss 122:480c44b0e205 305 * ...
klauss 122:480c44b0e205 306 * @endcode
klauss 122:480c44b0e205 307 */
klauss 122:480c44b0e205 308 void print_clock ( uint8_t * buffer );
klauss 122:480c44b0e205 309
klauss 0:4d17cd9c8f9d 310 #endif