Programowanie > C/C++

Funkcja aktualizacji elementu mapu usługi BPF zwraca dziwny błąd.

(1/1)

:
Niestety, ale funckja BPF_MAP_UPDATE_ELEMENT usługi bpf, zwraca operation not supported. MAP_

   
--- Kod: ---
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);
    }
--- Koniec kodu ---

Mapę tworzę tak:

--- Kod: ---
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);
    }
--- Koniec kodu ---

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. :-(

Paweł Kraszewski:
Taki strzał całkowicie w ciemno:


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

--- Koniec kodu ---

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

:

--- Cytat: Paweł Kraszewski w 2023-02-24, 08:17:36 ---Taki strzał całkowicie w ciemno:


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

--- Koniec kodu ---

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

--- Koniec cytatu ---

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.

Nawigacja

[0] Indeks wiadomości

Idź do wersji pełnej