mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-24 02:12:09 -05:00
Kernel: Convert IPv4 socket list from HashTable to IntrusiveList
There was no reason whatsoever to use a HashTable here. IntrusiveList removes all the heap allocations and does everything more efficiently.
This commit is contained in:
parent
a154faebb7
commit
7063303022
3 changed files with 17 additions and 10 deletions
|
@ -26,13 +26,13 @@
|
|||
|
||||
namespace Kernel {
|
||||
|
||||
static Singleton<ProtectedValue<HashTable<IPv4Socket*>>> s_table;
|
||||
static Singleton<ProtectedValue<IPv4Socket::List>> s_all_sockets;
|
||||
|
||||
using BlockFlags = Thread::FileDescriptionBlocker::BlockFlags;
|
||||
|
||||
ProtectedValue<HashTable<IPv4Socket*>>& IPv4Socket::all_sockets()
|
||||
ProtectedValue<IPv4Socket::List>& IPv4Socket::all_sockets()
|
||||
{
|
||||
return *s_table;
|
||||
return *s_all_sockets;
|
||||
}
|
||||
|
||||
OwnPtr<DoubleBuffer> IPv4Socket::create_receive_buffer()
|
||||
|
@ -79,14 +79,14 @@ IPv4Socket::IPv4Socket(int type, int protocol, NonnullOwnPtr<DoubleBuffer> recei
|
|||
}
|
||||
|
||||
all_sockets().with_exclusive([&](auto& table) {
|
||||
table.set(this);
|
||||
table.append(*this);
|
||||
});
|
||||
}
|
||||
|
||||
IPv4Socket::~IPv4Socket()
|
||||
{
|
||||
all_sockets().with_exclusive([&](auto& table) {
|
||||
table.remove(this);
|
||||
table.remove(*this);
|
||||
});
|
||||
}
|
||||
|
||||
|
|
|
@ -31,8 +31,6 @@ public:
|
|||
static KResultOr<NonnullRefPtr<Socket>> create(int type, int protocol);
|
||||
virtual ~IPv4Socket() override;
|
||||
|
||||
static ProtectedValue<HashTable<IPv4Socket*>>& all_sockets();
|
||||
|
||||
virtual KResult close() override;
|
||||
virtual KResult bind(Userspace<const sockaddr*>, socklen_t) override;
|
||||
virtual KResult connect(FileDescription&, Userspace<const sockaddr*>, socklen_t, ShouldBlock = ShouldBlock::Yes) override;
|
||||
|
@ -131,6 +129,13 @@ private:
|
|||
BufferMode m_buffer_mode { BufferMode::Packets };
|
||||
|
||||
OwnPtr<KBuffer> m_scratch_buffer;
|
||||
|
||||
IntrusiveListNode<IPv4Socket> m_list_node;
|
||||
|
||||
public:
|
||||
using List = IntrusiveList<IPv4Socket, RawPtr<IPv4Socket>, &IPv4Socket::m_list_node>;
|
||||
|
||||
static ProtectedValue<IPv4Socket::List>& all_sockets();
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -224,9 +224,11 @@ void handle_icmp(EthernetFrameHeader const& eth, IPv4Packet const& ipv4_packet,
|
|||
|
||||
{
|
||||
NonnullRefPtrVector<IPv4Socket> icmp_sockets;
|
||||
IPv4Socket::all_sockets().for_each_shared([&](const auto& socket) {
|
||||
if (socket->protocol() == (unsigned)IPv4Protocol::ICMP)
|
||||
icmp_sockets.append(*socket);
|
||||
IPv4Socket::all_sockets().with_exclusive([&](auto& sockets) {
|
||||
for (auto& socket : sockets) {
|
||||
if (socket.protocol() == (unsigned)IPv4Protocol::ICMP)
|
||||
icmp_sockets.append(socket);
|
||||
}
|
||||
});
|
||||
for (auto& socket : icmp_sockets)
|
||||
socket.did_receive(ipv4_packet.source(), 0, { &ipv4_packet, sizeof(IPv4Packet) + ipv4_packet.payload_size() }, packet_timestamp);
|
||||
|
|
Loading…
Add table
Reference in a new issue