1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- /*
- * Copyright (c) 2021, the SerenityOS developers.
- *
- * SPDX-License-Identifier: BSD-2-Clause
- */
- #pragma once
- #include <AK/OwnPtr.h>
- #include <Kernel/Bus/PCI/Access.h>
- #include <Kernel/Bus/PCI/Device.h>
- #include <Kernel/IOWindow.h>
- #include <Kernel/Interrupts/IRQHandler.h>
- #include <Kernel/Net/NetworkAdapter.h>
- #include <Kernel/Random.h>
- namespace Kernel {
- class NE2000NetworkAdapter final : public NetworkAdapter
- , public PCI::Device
- , public IRQHandler {
- public:
- static ErrorOr<LockRefPtr<NE2000NetworkAdapter>> try_to_initialize(PCI::DeviceIdentifier const&);
- virtual ~NE2000NetworkAdapter() override;
- virtual void send_raw(ReadonlyBytes) override;
- virtual bool link_up() override
- {
- // Pure NE2000 doesn't seem to have a link status indicator, so
- // just assume that it's up.
- return true;
- }
- virtual i32 link_speed() override
- {
- // Can only do 10mbit..
- return 10;
- }
- virtual bool link_full_duplex() override { return true; }
- virtual StringView purpose() const override { return class_name(); }
- virtual StringView device_name() const override { return class_name(); }
- private:
- NE2000NetworkAdapter(PCI::Address, u8, NonnullOwnPtr<IOWindow> registers_io_window, NonnullOwnPtr<KString>);
- virtual bool handle_irq(RegisterState const&) override;
- virtual StringView class_name() const override { return "NE2000NetworkAdapter"sv; }
- int ram_test();
- void reset();
- void rdma_read(size_t address, Bytes payload);
- void rdma_write(size_t address, ReadonlyBytes payload);
- void receive();
- void out8(u16 address, u8 data);
- void out16(u16 address, u16 data);
- u8 in8(u16 address);
- u16 in16(u16 address);
- NonnullOwnPtr<IOWindow> m_registers_io_window;
- int m_ring_read_ptr;
- u8 m_interrupt_line { 0 };
- MACAddress m_mac_address;
- EntropySource m_entropy_source;
- WaitQueue m_wait_queue;
- };
- }
|