The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]



"Модуль lapbether"
Версия для распечатки Пред. тема | След. тема
Форум Программирование под UNIX
Исходное сообщение [ Отслеживать ]

. "Модуль lapbether" +/
Сообщение от Pavel515 (ok), 08-Апр-19, 09:25 
Здравствуйте

Вот настал момент поделиться результатом
Не сразу и не быстро получилось адаптировать код 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

С уважением, Павел

Ответить | Правка | Наверх | Cообщить модератору

Оглавление
Модуль lapbether, Pavel515, 06-Мрт-19, 18:11  [смотреть все]
Форумы | Темы | Пред. тема | След. тема



Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру