Re: модуль lapbether
От: Pavel515  
Дата: 08.04.19 06:33
Оценка:
Здравствуйте

Вот настал момент поделиться результатом
Не сразу и не быстро получилось адаптировать код x25tap для ядра 3.10

Основываясь на результатах https://switch-case.ru/51655676, только автор шел от broadcat к unicast, а я наоборот, изменения в коде x25tap:

(основные моменты)

в функции static void x25tap_rx_skb(struct sk_buff *skb)
при вызове функции kfree_skb(принятого skb) зависает с перегрузкой.
При передаче skb в пространство x25 в принимающей функции (x25_dev.c)
(int x25_lapb_receive_frame(struct sk_buff *skb, struct net_device *dev,
struct packet_type *ptype, struct net_device *orig_dev)

при выполнении skb_copy копия выполняется, но адрес skb и data внутри skb не меняется!!!!!, а размер данных обнуляется, поэтому pskb_may_pull возвращаяе FALSE), возвращаясь к x25tap_rx_skb(struct sk_buff *skb)
создаю новый буфер skb и копирую в него данные из буфера net_link
    if((__skb = dev_alloc_skb(skb->len)) == NULL)
    {
        printk(KERN_INFO "%s : dev_alloc_skb(%d) == NULL\n", dev->name,skb->len);
        return;
    }

    if (skb->data[0] == 0) {
        x25tap->stats.rx_packets++;
        x25tap->stats.rx_bytes += len;
    }

    dptr = skb_put(__skb,skb->len);
    memcpy(dptr,skb->data,skb->len);



Изменения в xotd — две функции
int writenls(struct xot_device* dev, unsigned char *packet, int len);
int readnls(struct xot_device* dev, unsigned char *packet, int len);
с изменением структуры struct xot_device* dev
...
    struct iovec iov;
    struct msghdr msg;
    int nls;        /* The x25tap device it talks to. */ вместо tap (для удобства)
...


добавлением заголовка
struct nl_header {
    struct nlmsghdr nlh;
    u_int16_t length;
};


и изменением буферов в функциях void *outbound(void *arg)
...
    unsigned char nls_packet[sizeof(struct nl_header) + MAX_PKT_LEN + 4];
    unsigned char *full_packet = nls_packet + (sizeof(struct nl_header) - sizeof(struct xot_header)) + 1;
//    unsigned char full_packet[sizeof(struct xot_header) + MAX_PKT_LEN];
    struct xot_header *header = (struct xot_header *)full_packet;
    unsigned char *packet = full_packet + sizeof(*header);
    unsigned char *tap_packet = packet - 1;


и void *inbound(void *arg)
...
    unsigned char nls_packet[sizeof(struct nl_header) + MAX_PKT_LEN + 1 + 4];
    unsigned char *tap_packet = nls_packet + sizeof(struct nl_header);
//    unsigned char tap_packet[MAX_PKT_LEN + 1];
    unsigned char *packet = tap_packet + 1;



паралельно при переходе к 64 битной версии в функции void *outbound(void *arg)
...
unsigned char *packet = full_packet + sizeof(*header);
...
nread += sizeof(*header);

не было * (разыменования) в 32 — битной версии размер указателя равен размеру заголовка, а 64 битной указатель становится размером 8, а заголовок остается 4

Ну вот, кажется и всё!
http://files.rsdn.org/45405/x25tap.c
http://files.rsdn.org/45405/xotd.c

С уважением, Павел
Если хочешь выиграть в лотерею, то купи, хотя-бы лотерейный билет. (В.Мэгре)
 
Подождите ...
Wait...
Пока на собственное сообщение не было ответов, его можно удалить.