Page MenuHomeFreeBSD

if_ovpn: allow peer lookup by vpn4/vpn6 address
ClosedPublic

Authored by kp on Dec 5 2022, 4:31 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 3:20 AM
Unknown Object (File)
Tue, Jan 7, 1:54 PM
Unknown Object (File)
Tue, Jan 7, 1:18 PM
Unknown Object (File)
Sat, Dec 28, 10:35 AM
Unknown Object (File)
Dec 13 2024, 2:26 AM
Unknown Object (File)
Dec 9 2024, 1:39 PM
Unknown Object (File)
Dec 2 2024, 4:57 PM
Unknown Object (File)
Nov 21 2024, 6:34 AM

Details

Summary

Introduce two more RB_TREEs so that we can look up peers by their peer
id (already present) or vpn4 or vpn6 address.
This removes the last linear scan of the peer list.

Sponsored by: Rubicon Communications, LLC ("Netgate")

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 48623
Build 45509: arc lint + arc unit

Event Timeline

zlei added inline comments.
sys/net/if_ovpn.c
299

memcmp might be overweight here.

306

I'd like to use clang / gcc extension __uint128_t to simplify and make the compare performant, but it seems kernel is not ready for it yet ( not available from sys/_stdint.h ).

Maybe just leave as is or convert to two compare of uint64_t .

1688

Compiler is smart :)

1702

Ditto.

Assign IP address directly, rather than memcpy()

This revision was not accepted when it landed; it landed in state Needs Review.Dec 14 2022, 5:50 AM
This revision was automatically updated to reflect the committed changes.