Nowe posty

Autor Wątek: Funkcja aktualizacji elementu mapu usługi BPF zwraca dziwny błąd.  (Przeczytany 1437 razy)

Offline notgnucy

  • Users
  • Stały bywalec
  • ***
  • Wiadomości: 111
    • Zobacz profil
Niestety, ale funckja BPF_MAP_UPDATE_ELEMENT usługi bpf, zwraca operation not supported. MAP_

   
attr.map_fd = map_fd_read;
    attr.value = (__u64)&em_read.perf_monitor_fd;
    attr.key = (__u64)&key_zero;
    attr.flags = BPF_ANY;

    if (-1 == syscall(SYS_bpf, BPF_MAP_UPDATE_ELEM, &attr, sizeof(attr))) {

        perror("2.Unable to setup map: unable to set perf fd as map element");
        exit(1);
    }

Mapę tworzę tak:
memset(&attr, 0, sizeof(attr));
    attr.key_size = 4;
    attr.map_type = BPF_MAP_TYPE_PERF_EVENT_ARRAY;
    attr.value_size = 4;
    attr.max_entries = 1;

    map_fd_read = syscall(SYS_bpf, BPF_MAP_CREATE, &attr, sizeof(attr));

    if (-1 == map_fd_read) {
        perror("ERROR: Unable to create map");
        exit(1);
    }

Program BPF działa, ale BPF_FUNC_perf_event_output zwraca błąd.
Pytanie: czemu aktualizacja elementu zwraca, że operacja jest nieobsługiwana? Szukałem w internecie, i nie znalazłem. :-(

Offline Paweł Kraszewski

  • Administrator
  • Guru
  • *****
  • Wiadomości: 3087
  • Lenistwo jest matką potrzeby = babcią wynalazku
    • Zobacz profil
Odp: Funkcja aktualizacji elementu mapu usługi BPF zwraca dziwny błąd.
« Odpowiedź #1 dnia: 2023-02-24, 08:17:36 »
Taki strzał całkowicie w ciemno:

attr.key_size = 4;
               ^^^
               
attr.key = (__u64)&key_zero;
            ^^^^^

OTOH 4 pewnie odnosi się do rozmiaru key_zero, choć w testach w źródle kernela jest wszędzie .key_size = 8... 
« Ostatnia zmiana: 2023-02-24, 09:26:20 wysłana przez Paweł Kraszewski »
Paweł Kraszewski
~Arch/Void/Gentoo/FreeBSD/OpenBSD/Specjalizowane customy

Offline notgnucy

  • Users
  • Stały bywalec
  • ***
  • Wiadomości: 111
    • Zobacz profil
Odp: Funkcja aktualizacji elementu mapu usługi BPF zwraca dziwny błąd.
« Odpowiedź #2 dnia: 2023-02-24, 15:14:12 »
Taki strzał całkowicie w ciemno:

attr.key_size = 4;
               ^^^
               
attr.key = (__u64)&key_zero;
            ^^^^^

OTOH 4 pewnie odnosi się do rozmiaru key_zero, choć w testach w źródle kernela jest wszędzie .key_size = 8...

To nie jest błąd. Podawany jest wskaźnik na klucz, bo klucz ma rozmiar definiowany przez użytkownika. Unika się w ten sposób różnych problemów, jak obcięcia, promocji, itd. Przynajmniej ja tak zrozumiałem. Po podstawieniu 0 pod pole klucz, funkcja zwraca błąd niepoprawny adres (BAD ADDRESS). Generalnie, to jakby ta zmienna była typu (załóżmy) unsigned char, a ty chciałbyś mieć klucz long long unsigned int, to byłby problem. Fakt, że w dokumentacji jest napisane, że tablica musi mieć klucze czterobajtowe niczego chyba nie zmienia, bo mapa może być przeróżnego typu.