NE2000NetworkAdapter.h 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  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/IO.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 RefPtr<NE2000NetworkAdapter> try_to_initialize(PCI::Address);
  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()
  29. {
  30. // Can only do 10mbit..
  31. return 10;
  32. }
  33. virtual bool link_full_duplex() { return true; }
  34. virtual StringView purpose() const override { return class_name(); }
  35. private:
  36. NE2000NetworkAdapter(PCI::Address, u8 irq);
  37. virtual bool handle_irq(const RegisterState&) override;
  38. virtual StringView class_name() const override { return "NE2000NetworkAdapter"sv; }
  39. int ram_test();
  40. void reset();
  41. void rdma_read(size_t address, Bytes payload);
  42. void rdma_write(size_t address, ReadonlyBytes payload);
  43. void receive();
  44. void out8(u16 address, u8 data);
  45. void out16(u16 address, u16 data);
  46. u8 in8(u16 address);
  47. u16 in16(u16 address);
  48. IOAddress m_io_base;
  49. int m_ring_read_ptr;
  50. u8 m_interrupt_line { 0 };
  51. MACAddress m_mac_address;
  52. EntropySource m_entropy_source;
  53. WaitQueue m_wait_queue;
  54. };
  55. }