NetworkAdapter.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. /*
  2. * Copyright (c) 2021, the SerenityOS developers.
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/OwnPtr.h>
  8. #include <Kernel/Bus/PCI/Access.h>
  9. #include <Kernel/Bus/PCI/Device.h>
  10. #include <Kernel/IOWindow.h>
  11. #include <Kernel/Interrupts/IRQHandler.h>
  12. #include <Kernel/Net/NetworkAdapter.h>
  13. #include <Kernel/Random.h>
  14. namespace Kernel {
  15. class NE2000NetworkAdapter final : public NetworkAdapter
  16. , public PCI::Device
  17. , public IRQHandler {
  18. public:
  19. static ErrorOr<LockRefPtr<NE2000NetworkAdapter>> try_to_initialize(PCI::DeviceIdentifier const&);
  20. virtual ~NE2000NetworkAdapter() override;
  21. virtual void send_raw(ReadonlyBytes) override;
  22. virtual bool link_up() override
  23. {
  24. // Pure NE2000 doesn't seem to have a link status indicator, so
  25. // just assume that it's up.
  26. return true;
  27. }
  28. virtual i32 link_speed() override
  29. {
  30. // Can only do 10mbit..
  31. return 10;
  32. }
  33. virtual bool link_full_duplex() override { return true; }
  34. virtual StringView purpose() const override { return class_name(); }
  35. virtual StringView device_name() const override { return class_name(); }
  36. private:
  37. NE2000NetworkAdapter(PCI::Address, u8, NonnullOwnPtr<IOWindow> registers_io_window, NonnullOwnPtr<KString>);
  38. virtual bool handle_irq(RegisterState const&) override;
  39. virtual StringView class_name() const override { return "NE2000NetworkAdapter"sv; }
  40. int ram_test();
  41. void reset();
  42. void rdma_read(size_t address, Bytes payload);
  43. void rdma_write(size_t address, ReadonlyBytes payload);
  44. void receive();
  45. void out8(u16 address, u8 data);
  46. void out16(u16 address, u16 data);
  47. u8 in8(u16 address);
  48. u16 in16(u16 address);
  49. NonnullOwnPtr<IOWindow> m_registers_io_window;
  50. int m_ring_read_ptr;
  51. u8 m_interrupt_line { 0 };
  52. MACAddress m_mac_address;
  53. EntropySource m_entropy_source;
  54. WaitQueue m_wait_queue;
  55. };
  56. }