maybe final version hdlc
This commit is contained in:
parent
800f48bc11
commit
4a658848dd
@ -20,12 +20,12 @@ void init_hdlc_client(struct Client* client, int connecting_frame_timeout){
|
|||||||
connecting_frame_timeout_bf = connecting_frame_timeout;
|
connecting_frame_timeout_bf = connecting_frame_timeout;
|
||||||
client->current_index_frame = 20;
|
client->current_index_frame = 20;
|
||||||
|
|
||||||
// client->current_state_hdlc.control_escape = 0;
|
client->current_state_hdlc.control_escape = 0;
|
||||||
// client->current_state_hdlc.fcs = FCS_INIT_VALUE;
|
client->current_state_hdlc.fcs = FCS_INIT_VALUE;
|
||||||
// client->current_state_hdlc.start_index = -1;
|
client->current_state_hdlc.start_index = -1;
|
||||||
// client->current_state_hdlc.end_index = -1;
|
client->current_state_hdlc.end_index = -1;
|
||||||
// client->current_state_hdlc.src_index = 0;
|
client->current_state_hdlc.src_index = 0;
|
||||||
// client->current_state_hdlc.dest_index = 0;
|
client->current_state_hdlc.dest_index = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void hdlc_connect(struct Client* client){
|
void hdlc_connect(struct Client* client){
|
||||||
@ -36,7 +36,7 @@ void hdlc_connect(struct Client* client){
|
|||||||
client->current_index_frame = client->frameS.seq_no;
|
client->current_index_frame = client->frameS.seq_no;
|
||||||
}
|
}
|
||||||
|
|
||||||
int hdlc_send_data(struct Client* client, uint8_t* data, size_t data_len){
|
int hdlc_send_data(struct Client* client, uint8_t data[], size_t data_len){
|
||||||
if (client->state != READY_STATE){
|
if (client->state != READY_STATE){
|
||||||
return ERR_INVALID_STATE;
|
return ERR_INVALID_STATE;
|
||||||
}
|
}
|
||||||
@ -49,7 +49,7 @@ int hdlc_send_data(struct Client* client, uint8_t* data, size_t data_len){
|
|||||||
|
|
||||||
client->frameI.seq_no = 0;
|
client->frameI.seq_no = 0;
|
||||||
client->frameI.frame = I_FRAME;
|
client->frameI.frame = I_FRAME;
|
||||||
client->data_i_frame = *data;
|
client->data_i_frame = data;
|
||||||
client->len_data_i_frame = data_len;
|
client->len_data_i_frame = data_len;
|
||||||
client->current_index_frame = client->frameI.seq_no;
|
client->current_index_frame = client->frameI.seq_no;
|
||||||
|
|
||||||
@ -59,7 +59,7 @@ int hdlc_send_data(struct Client* client, uint8_t* data, size_t data_len){
|
|||||||
|
|
||||||
int hdlc_get_raw_frame(struct Client *client, uint8_t* buffer, size_t lenBuffer) {
|
int hdlc_get_raw_frame(struct Client *client, uint8_t* buffer, size_t lenBuffer) {
|
||||||
if(client->state == RECIVING){
|
if(client->state == RECIVING){
|
||||||
int ret = hdlc_frame_data(client->frameI, &client->data_i_frame,
|
int ret = hdlc_frame_data(&client->frameI, client->data_i_frame,
|
||||||
client->len_data_i_frame, buffer, &lenBuffer);
|
client->len_data_i_frame, buffer, &lenBuffer);
|
||||||
if (ret < 0){
|
if (ret < 0){
|
||||||
printf("err in get_frame: %d\n", ret);
|
printf("err in get_frame: %d\n", ret);
|
||||||
@ -67,7 +67,7 @@ int hdlc_get_raw_frame(struct Client *client, uint8_t* buffer, size_t lenBuffer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (client->state == CONNECTING){
|
if (client->state == CONNECTING){
|
||||||
int ret = hdlc_frame_data(client->frameS, NULL, 0, buffer, &lenBuffer);
|
int ret = hdlc_frame_data(&client->frameS, NULL, 0, buffer, &lenBuffer);
|
||||||
|
|
||||||
if (ret < 0){
|
if (ret < 0){
|
||||||
printf("err in get_frame: %d\n", ret);
|
printf("err in get_frame: %d\n", ret);
|
||||||
@ -75,7 +75,7 @@ int hdlc_get_raw_frame(struct Client *client, uint8_t* buffer, size_t lenBuffer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (client->state == DISCONNECTING){
|
if (client->state == DISCONNECTING){
|
||||||
int ret = hdlc_frame_data(client->frame_rej, NULL, 0, buffer, &lenBuffer);
|
int ret = hdlc_frame_data(&client->frame_rej, NULL, 0, buffer, &lenBuffer);
|
||||||
|
|
||||||
if (ret < 0){
|
if (ret < 0){
|
||||||
printf("err in get_frame: %d\n", ret);
|
printf("err in get_frame: %d\n", ret);
|
||||||
@ -89,7 +89,7 @@ int hdlc_decode_recived_raw_data(struct Client* client, uint8_t* buffer, size_t
|
|||||||
hdlc_control_t recv_control;
|
hdlc_control_t recv_control;
|
||||||
uint8_t recive[len_buffer];
|
uint8_t recive[len_buffer];
|
||||||
|
|
||||||
int ret = hdlc_get_data(&recv_control, buffer, len_buffer, &recive,
|
int ret = hdlc_get_data_with_state(&client->current_state_hdlc,&recv_control, buffer, len_buffer, recive,
|
||||||
&len_buffer);
|
&len_buffer);
|
||||||
|
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
@ -108,8 +108,11 @@ int hdlc_decode_recived_raw_data(struct Client* client, uint8_t* buffer, size_t
|
|||||||
client->state = READY_STATE;
|
client->state = READY_STATE;
|
||||||
break;
|
break;
|
||||||
case I_FRAME:
|
case I_FRAME:
|
||||||
*recived_data = buffer[3];
|
for (int i = 0; i < sizeof(recive)-2; i++){
|
||||||
*len_recived_data = sizeof(buffer[3]);
|
recived_data[i] = recive[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
*len_recived_data = sizeof(recive)-2;
|
||||||
break;
|
break;
|
||||||
case S_FRAME_NACK:
|
case S_FRAME_NACK:
|
||||||
client->state = DISCONNECTING;
|
client->state = DISCONNECTING;
|
||||||
|
@ -18,10 +18,10 @@ struct Client{
|
|||||||
enum HDLCState state;
|
enum HDLCState state;
|
||||||
int connecting_frame_timeout; //-1
|
int connecting_frame_timeout; //-1
|
||||||
uint8_t current_index_frame;
|
uint8_t current_index_frame;
|
||||||
//hdlc_state_t current_state_hdlc;
|
hdlc_state_t current_state_hdlc;
|
||||||
hdlc_control_t frameS;
|
hdlc_control_t frameS;
|
||||||
hdlc_control_t frameI;
|
hdlc_control_t frameI;
|
||||||
uint8_t data_i_frame;
|
uint8_t* data_i_frame;
|
||||||
size_t len_data_i_frame;
|
size_t len_data_i_frame;
|
||||||
// hdlc_control_t frame3;
|
// hdlc_control_t frame3;
|
||||||
// hdlc_control_t frame4;
|
// hdlc_control_t frame4;
|
||||||
@ -31,7 +31,7 @@ struct Client{
|
|||||||
//название функций
|
//название функций
|
||||||
void init_hdlc_client(struct Client* client, int connecting_frame_timeout);
|
void init_hdlc_client(struct Client* client, int connecting_frame_timeout);
|
||||||
void hdlc_connect(struct Client* client);
|
void hdlc_connect(struct Client* client);
|
||||||
int hdlc_send_data(struct Client* client, uint8_t* data, size_t data_len);
|
int hdlc_send_data(struct Client* client, uint8_t data[], size_t data_len);
|
||||||
int hdlc_get_raw_frame(struct Client *client, uint8_t* buffer, size_t lenBuffer);
|
int hdlc_get_raw_frame(struct Client *client, uint8_t* buffer, size_t lenBuffer);
|
||||||
//принимает буффер с уарта
|
//принимает буффер с уарта
|
||||||
int hdlc_decode_recived_raw_data(struct Client* client, uint8_t* buffer, size_t len_buffer, uint8_t* recived_data, size_t* len_recived_data);
|
int hdlc_decode_recived_raw_data(struct Client* client, uint8_t* buffer, size_t len_buffer, uint8_t* recived_data, size_t* len_recived_data);
|
||||||
|
@ -122,7 +122,8 @@ int hdlc_get_data(hdlc_control_t *control, uint8_t *src,
|
|||||||
|
|
||||||
//int hdlc_get_data_with_state(hdlc_state_t *state, hdlc_control_t *control, const char *src,
|
//int hdlc_get_data_with_state(hdlc_state_t *state, hdlc_control_t *control, const char *src,
|
||||||
// unsigned int src_len, char *dest, unsigned int *dest_len)
|
// unsigned int src_len, char *dest, unsigned int *dest_len)
|
||||||
int hdlc_get_data_with_state(hdlc_state_t *state, hdlc_control_t *control, uint8_t *src,
|
int
|
||||||
|
hdlc_get_data_with_state(hdlc_state_t *state, hdlc_control_t *control, uint8_t *src,
|
||||||
size_t src_len, uint8_t *dest, size_t *dest_len){
|
size_t src_len, uint8_t *dest, size_t *dest_len){
|
||||||
int ret;
|
int ret;
|
||||||
char value;
|
char value;
|
||||||
|
28
hdlc/main.c
28
hdlc/main.c
@ -1,42 +1,40 @@
|
|||||||
//#include "hdlc.h"
|
//#include "hdlc.h"
|
||||||
|
#include "stdio.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
|
|
||||||
int main(){
|
int main(){
|
||||||
struct Client hdlc;
|
struct Client hdlc;
|
||||||
init_hdlc_client(&hdlc, 200);
|
init_hdlc_client(&hdlc, 200);
|
||||||
hdlc_control_t frame;
|
hdlc_connect(&hdlc);
|
||||||
hdlc_connect(&hdlc, &frame);
|
|
||||||
uint8_t buffer_for_ex[20];
|
uint8_t buffer_for_ex[20];
|
||||||
uint8_t fake_buffer;
|
uint8_t fake_buffer;
|
||||||
hdlc_get_raw_frame(&hdlc, &frame, &buffer_for_ex, sizeof(buffer_for_ex));
|
hdlc_get_raw_frame(&hdlc, buffer_for_ex, sizeof(buffer_for_ex));
|
||||||
|
|
||||||
for (int i = 0; i < 200; i++){
|
for (int i = 0; i < 200; i++){
|
||||||
int z = hdlc_timeout_handler(&hdlc, 1);
|
int z = hdlc_timeout_handler(&hdlc, 1);
|
||||||
hdlc_decode_recived_raw_data(&hdlc, &fake_buffer, sizeof(fake_buffer), 0, 0);
|
hdlc_decode_recived_raw_data(&hdlc, &fake_buffer, sizeof(fake_buffer), 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
hdlc_get_raw_frame(&hdlc, &frame, &buffer_for_ex, sizeof(buffer_for_ex));
|
hdlc_get_raw_frame(&hdlc, buffer_for_ex, sizeof(buffer_for_ex));
|
||||||
int i = hdlc_decode_recived_raw_data(&hdlc, &buffer_for_ex, sizeof(buffer_for_ex), 0, 0);
|
int i = hdlc_decode_recived_raw_data(&hdlc, buffer_for_ex, sizeof(buffer_for_ex), 0, 0);
|
||||||
if (i < 0){
|
if (i < 0){
|
||||||
printf("err connect: %d\n", i);
|
printf("err connect: %d\n", i);
|
||||||
}
|
}
|
||||||
|
|
||||||
hdlc_control_t frame_data;
|
uint8_t data[] = {32, 233, 132, 102, 12, 12, 44, 121, 34};
|
||||||
uint8_t data = 33;
|
hdlc_send_data(&hdlc, data, sizeof(data));
|
||||||
hdlc_send_data(&hdlc, &frame_data, &data, sizeof(data));
|
uint8_t buffer_for_ex_data[20];
|
||||||
uint8_t buffer_for_ex_data[7];
|
|
||||||
|
|
||||||
hdlc_get_raw_frame(&hdlc, &frame_data, &buffer_for_ex_data, sizeof(buffer_for_ex_data));
|
hdlc_get_raw_frame(&hdlc, buffer_for_ex_data, 20);
|
||||||
|
|
||||||
//printf("first_ex:%d\n", buffer_for_ex_data[0]);
|
//printf("first_ex:%d\n", buffer_for_ex_data[0]);
|
||||||
uint8_t recived_data;
|
uint8_t recivedData[] = {};
|
||||||
size_t len_recived_data;
|
size_t len_recived_data = 0;
|
||||||
int x = hdlc_decode_recived_raw_data(&hdlc, &buffer_for_ex_data, sizeof(buffer_for_ex_data), &recived_data, &len_recived_data);
|
int x = hdlc_decode_recived_raw_data(&hdlc, buffer_for_ex_data, 20, recivedData, &len_recived_data);
|
||||||
if (x < 0){
|
if (x < 0){
|
||||||
printf("err send: %d\n", x);
|
printf("err send: %d\n", x);
|
||||||
}
|
}
|
||||||
printf("recived data: %d\n", recived_data);
|
printf("recived data: %d\n", recivedData[1]);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user