Mercurial > archived > louis > epitech > mq > rathaxes
annotate rathaxes_samples_e1000_split_set_up_device.patch @ 122:52402232483f
WIP on the split up of e1000::set_up_device
author | Louis Opter <louis@lse.epita.fr> |
---|---|
date | Sun, 28 Jul 2013 02:50:43 -0700 |
parents | 6f600f83a763 |
children | 518d9c8ac70c |
rev | line source |
---|---|
121
6f600f83a763
WIP, fix Ethernet::Device::alloc_rx_skbuff
Louis Opter <louis@lse.epita.fr>
parents:
diff
changeset
|
1 # HG changeset patch |
122
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
2 # Parent d62a08753da7cec4d44246b747ff79847d9b4238 |
121
6f600f83a763
WIP, fix Ethernet::Device::alloc_rx_skbuff
Louis Opter <louis@lse.epita.fr>
parents:
diff
changeset
|
3 rathaxes: split and refactor e1000::set_up_device in {Rx,Tx}Ring methods |
6f600f83a763
WIP, fix Ethernet::Device::alloc_rx_skbuff
Louis Opter <louis@lse.epita.fr>
parents:
diff
changeset
|
4 |
6f600f83a763
WIP, fix Ethernet::Device::alloc_rx_skbuff
Louis Opter <louis@lse.epita.fr>
parents:
diff
changeset
|
5 diff --git a/rathaxes/samples/e1000/e1000.blt b/rathaxes/samples/e1000/e1000.blt |
6f600f83a763
WIP, fix Ethernet::Device::alloc_rx_skbuff
Louis Opter <louis@lse.epita.fr>
parents:
diff
changeset
|
6 --- a/rathaxes/samples/e1000/e1000.blt |
6f600f83a763
WIP, fix Ethernet::Device::alloc_rx_skbuff
Louis Opter <louis@lse.epita.fr>
parents:
diff
changeset
|
7 +++ b/rathaxes/samples/e1000/e1000.blt |
122
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
8 @@ -1,4 +1,4 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
9 -with e1000, Ethernet, Socket, PCI, LKM, Log, Builtin |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
10 +with e1000, Ethernet, Socket, DMA, PCI, LKM, Log, Builtin |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
11 { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
12 template type e1000::RxDescriptor() |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
13 { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
14 @@ -96,8 +96,163 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
15 { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
16 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
17 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
18 + chunk Ethernet::adapter_init_rx(Ethernet::Device rtx_ether_ctx) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
19 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
20 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
21 + ${e1000::Context.ref} hw_ctx = &${rtx_ether_ctx}->hw_ctx; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
22 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
23 + /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
24 + * Receive initialization (section 14.4): |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
25 + * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
26 + * 1. Program the receive address, in RAL/RAH; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
27 + * 2. Initialize the Multicast Table Array; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
28 + * 3. Program the interrupt mask register (done in |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
29 + * e1000::activate_device_interruption); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
30 + * 4. Allocate the receive descriptor ring and map it to make it |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
31 + * accessible by the device; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
32 + * 5. Write the start address of the ring in RDBAL/RDBAH and set |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
33 + * RDLEN (Receive Descriptor Length) to the size of the ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
34 + * 6. Set the RDH/RDT (Receive Descriptor Head/Tail) indexes to the |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
35 + * beginning and end of the ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
36 + * 7. Make sure that RCTL.BSIZE and .BSEX are at 0 to configure the |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
37 + * receive buffer size to 2048 bytes (e1000::rx_buffer_len). |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
38 + * 8. Set RCTL.EN to enable the receiver. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
39 + * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
40 + * The ugly casts here are caused by the lack of CNorm unstrict. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
41 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
42 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
43 + int i; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
44 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
45 + /* 1. Program the receive address */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
46 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
47 + /* (We should use uint{32,16}_t but CNorm doesn't know them yet) */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
48 + rtx_e1000_register_write32(hw_ctx, E1000_RAL, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
49 + *(unsigned int *)(${rtx_ether_ctx.dev_addr})); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
50 + /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
51 + * The 16 upper bits of RAH also store the AS bits (which should be |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
52 + * 0) and the AV bit (should be 1 to set the address as valid). |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
53 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
54 + rtx_e1000_register_write32(hw_ctx, E1000_RAH, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
55 + *(unsigned short *)(&${rtx_ether_ctx.dev_addr}[4])); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
56 + rtx_e1000_register_set32(hw_ctx, E1000_RAH, E1000_RAH_AV); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
57 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
58 + ${Log::info("adapter_init_rx: receive address programmed")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
59 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
60 + /* 2. Initialize the MTA */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
61 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
62 + for (i = 0; i != 128; ++i) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
63 + rtx_e1000_register_write32(hw_ctx, E1000_MTA + i * 4, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
64 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
65 + ${Log::info("adapter_init_rx: MTA init done")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
66 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
67 + /* 4. Setup the receive descriptor ring */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
68 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
69 + /* Allocate the descriptors */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
70 + hw_ctx->rx_ring.size = ${config.rx_ring_size} * sizeof(*hw_ctx->rx_ring.base); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
71 + hw_ctx->rx_ring.size = ALIGN(hw_ctx->rx_ring.size, 4096); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
72 + hw_ctx->rx_ring.base = dma_alloc_coherent( |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
73 + ${rtx_ether_ctx.device}, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
74 + hw_ctx->rx_ring.size, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
75 + &hw_ctx->rx_ring.dma_base, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
76 + GFP_KERNEL); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
77 + /* XXX |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
78 + * The first arg is recognized as Ethernet::Device instead of |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
79 + * Device::AbstractDevice. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
80 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
81 + hw_ctx->rx_ring.base = ${DMA::alloc_coherent( |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
82 + rtx_ether_ctx.device, local.hw_ctx.rx_ring.size, local.hw_ctx.rx_ring.dma_base.dma_handle |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
83 + )}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
84 + if (!hw_ctx->rx_ring.base) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
85 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
86 + ${Log::info("adapter_init_rx: cannot allocate the descriptors for the rx ring")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
87 + goto err_rx_ring_alloc; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
88 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
89 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
90 + ${Log::info("adapter_init_rx: rx descriptors allocated")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
91 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
92 + /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
93 + * Allocate the skbuffs, map them for DMA, and write their address |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
94 + * in the corresponding descriptor. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
95 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
96 + for (i = 0; i != ${config.rx_ring_size}; ++i) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
97 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
98 + // XXX #46: ${Socket::SKBuff.ref} skbuff = ${rtx_ether_ctx.net_device.alloc_rx_skbuff(config.rx_buffer_len)}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
99 + ${Socket::AbstractSKBuff.ref} k_sk_buff = (${Socket::AbstractSKBuff.ref})netdev_alloc_skb( |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
100 + ${rtx_ether_ctx.net_device.k_net_dev}, ${config.rx_buffer_len} |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
101 + ); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
102 + if (!k_sk_buff) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
103 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
104 + ${Log::info("adapter_init_rx: cannot allocate a skbuff for the rx ring")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
105 + goto err_skbuffs_alloc; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
106 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
107 + ${Socket::SKBuff.ref} skbuff = &hw_ctx->rx_ring.skbuffs[i]; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
108 + // XXX breaks rtxGen: ${local.skbuff.init(local.k_sk_buff)}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
109 + skbuff->skbuff = k_sk_buff; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
110 + skbuff->dma_handle = 0; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
111 + // XXX #46: ${local.skbuff.map_from(rtx_ether_ctx.device)}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
112 + if (rtx_socket_skbuff_map(${local.skbuff}, ${rtx_ether_ctx.device}, RTX_DMA_FROM_DEVICE)) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
113 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
114 + ${Log::info("adapter_init_rx: cannot dma-map a skbuff for the rx ring")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
115 + goto err_skbuffs_map; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
116 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
117 + hw_ctx->rx_ring.base[i].buff_addr = cpu_to_le64(${local.skbuff.sk_buff}); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
118 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
119 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
120 + ${Log::info("adapter_init_rx: skbuffs allocated")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
121 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
122 + /* 5. Save the emplacement and the size of the ring in RDBA/RDLEN */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
123 + rtx_e1000_register_write32(hw_ctx, E1000_RDBAL, hw_ctx->rx_ring.dma_base & 0xffffffff); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
124 + rtx_e1000_register_write32(hw_ctx, E1000_RDBAH, hw_ctx->rx_ring.dma_base >> 32); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
125 + rtx_e1000_register_write32(hw_ctx, E1000_RDLEN, hw_ctx->rx_ring.size); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
126 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
127 + /* 6. Setup RDH/RDT */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
128 + rtx_e1000_register_write32(hw_ctx, E1000_RDH, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
129 + rtx_e1000_register_write32(hw_ctx, E1000_RDT, ${config.rx_ring_size} - 1); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
130 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
131 + /* 7. Configure the buffer size, */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
132 + rtx_e1000_register_set32(hw_ctx, E1000_RCTL, E1000_RCTL_BSIZE_${config.rx_buffer_len}); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
133 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
134 + /* 8. Enable the receiver */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
135 + rtx_e1000_register_set32(hw_ctx, E1000_RCTL, E1000_RCTL_EN); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
136 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
137 + ${Log::info("adapter_init_rx: receive registers configured and receiver enabled")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
138 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
139 + /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
140 + * XXX: We can't return here since we are not in a function but |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
141 + * in a chunk of code (injected in a function). |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
142 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
143 + goto init_rx_ok; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
144 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
145 + err_skbuffs_alloc: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
146 + while (i--) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
147 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
148 + dma_unmap_single( |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
149 + ${rtx_ether_ctx.device}, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
150 + hw_ctx->rx_ring.skbuffs[i].dma_handle, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
151 + ${config.rx_buffer_len}, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
152 + DMA_FROM_DEVICE); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
153 + err_skbuffs_map: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
154 + /* XXX leaking cast: */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
155 + dev_kfree_skb((struct sk_buff *)hw_ctx->rx_ring.skbuffs[i].skbuff); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
156 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
157 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
158 + dma_free_coherent(${rtx_ether_ctx.device}, hw_ctx->rx_ring.size, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
159 + hw_ctx->rx_ring.base, hw_ctx->rx_ring.dma_base); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
160 + err_rx_ring_alloc: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
161 + /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
162 + * XXX: Likewise, if there is something else to rollback in the |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
163 + * enclosing function, this won't be done. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
164 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
165 + return -ENOMEM; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
166 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
167 + init_rx_ok: (void)0; /* NOP, to make this a valid label. */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
168 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
169 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
170 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
171 map |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
172 { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
173 + size: ((${self}).size); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
174 + dma_base: ((${self}).dma_base); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
175 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
176 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
177 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
178 @@ -208,7 +363,62 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
179 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
180 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
181 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
182 - method clean() |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
183 + chunk Ethernet::adapter_init_tx(Ethernet::Device rtx_ether_ctx) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
184 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
185 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
186 + ${e1000::Context.ref} hw_ctx = &${rtx_ether_ctx}->hw_ctx; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
187 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
188 + /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
189 + * Transmission initialization (section 14.5): |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
190 + * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
191 + * 1. Allocate the transmit descriptors ring and map it to make it |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
192 + * accessible by the device; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
193 + * 2. Write the start address of the ring in TDBAL/TDBAH and set |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
194 + * TDLEN to the size of the ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
195 + * 3. Set the TDH/TDT indexes to the beginning and end of the ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
196 + * 4. Set TCTL.PSP to pad short packets and TCTL.EN to enable the |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
197 + * transmitter. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
198 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
199 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
200 + /* 1. Allocate the tx ring */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
201 + hw_ctx->tx_ring.size = ${config.tx_ring_size} * sizeof(*hw_ctx->tx_ring.base); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
202 + hw_ctx->tx_ring.size = ALIGN(hw_ctx->tx_ring.size, 4096); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
203 + hw_ctx->tx_ring.base = dma_alloc_coherent( |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
204 + ${rtx_ether_ctx.device}, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
205 + hw_ctx->tx_ring.size, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
206 + &hw_ctx->tx_ring.dma_base, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
207 + GFP_KERNEL); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
208 + if (!hw_ctx->rx_ring.base) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
209 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
210 + ${Log::info("adapter_init_tx: cannot allocate the descriptors for the tx ring")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
211 + /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
212 + * XXX: If there is something else to rollback in the enclosing |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
213 + * function, this won't be done. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
214 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
215 + return -ENOMEM; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
216 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
217 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
218 + ${Log::info("adapter_init_tx: tx descriptors allocated")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
219 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
220 + /* 2. Save the emplacement and the size of the ring in TDBA/TDLEN */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
221 + rtx_e1000_register_write32(hw_ctx, E1000_TDBAL, hw_ctx->tx_ring.dma_base & 0xffffffff); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
222 + rtx_e1000_register_write32(hw_ctx, E1000_TDBAH, hw_ctx->tx_ring.dma_base >> 32); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
223 + rtx_e1000_register_write32(hw_ctx, E1000_TDLEN, hw_ctx->tx_ring.size); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
224 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
225 + /* 3. Setup TDH/TDT to zero: the queue is empty */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
226 + rtx_e1000_register_write32(hw_ctx, E1000_TDH, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
227 + rtx_e1000_register_write32(hw_ctx, E1000_TDT, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
228 + hw_ctx->tx_ring.head = 0; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
229 + hw_ctx->tx_ring.tail = 0; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
230 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
231 + /* 4. Set TCTL.PSP and enable the transmitter */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
232 + rtx_e1000_register_set32(hw_ctx, E1000_TCTL, E1000_TCTL_PSP|E1000_TCTL_EN); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
233 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
234 + ${Log::info("adapter_init_tx: transmit registers configured and transmitter enabled")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
235 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
236 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
237 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
238 + method clean() |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
239 { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
240 rtx_e1000_tx_ring_clean(${self}); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
241 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
242 @@ -247,9 +457,8 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
243 { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
244 int bars; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
245 unsigned char /* __iomem */ *ioaddr; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
246 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
247 - ${e1000::RxRing} rx_ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
248 - ${e1000::TxRing} tx_ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
249 + ${e1000::RxRing.scalar} rx_ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
250 + ${e1000::TxRing.scalar} tx_ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
251 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
252 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
253 chunk Ethernet::HardwareContext() |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
254 @@ -309,10 +518,53 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
255 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
256 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
257 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
258 + chunk Ethernet::adapter_setup(Ethernet::Device rtx_ether_ctx) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
259 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
260 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
261 + ${e1000::Context.ref} hw_ctx = &${rtx_ether_ctx}->hw_ctx; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
262 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
263 + /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
264 + * "General Configuration" (section 14.3): |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
265 + * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
266 + * - CTRL.ASDE/CTRL.SLU: Let the PHY handle the speed detection & |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
267 + * negociation; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
268 + * - CTRL.LRST/FRCSPD: Unset them to initiate the auto-negociation; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
269 + * - CTRL.PHY_RST: Unset it; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
270 + * - CTRL.ILOS: Unset it (ILOS is Invert Loss Of Signal); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
271 + * - CTRL.VME: Make sure it's not set to disable VLAN support; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
272 + * - Set the control flow registers to 0; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
273 + * - Finally, initialize all the statistic registers from |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
274 + * E1000_CRCERRS to E1000_TSCTFC. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
275 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
276 + rtx_e1000_register_set32(hw_ctx, E1000_CTRL, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
277 + E1000_CMD_ASDE | |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
278 + E1000_CMD_SLU); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
279 + rtx_e1000_register_unset32(hw_ctx, E1000_CTRL, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
280 + E1000_CMD_LRST | |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
281 + E1000_CMD_FRCSPD | |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
282 + E1000_CMD_PHY_RST | |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
283 + E1000_CMD_ILOS | |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
284 + E1000_CMD_VME); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
285 + rtx_e1000_register_write32(hw_ctx, E1000_FCAH, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
286 + rtx_e1000_register_write32(hw_ctx, E1000_FCAL, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
287 + rtx_e1000_register_write32(hw_ctx, E1000_FCT, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
288 + rtx_e1000_register_write32(hw_ctx, E1000_FCTTV, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
289 + /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
290 + * XXX: Using int i clashes with another int i from the |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
291 + * "parent" chunk: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
292 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
293 + for (int j = 0; j != 64; ++j) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
294 + rtx_e1000_register_write32(hw_ctx, E1000_CRCERRS + j * 4, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
295 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
296 + ${Log::info("adapter_setup: general configuration done")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
297 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
298 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
299 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
300 map |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
301 { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
302 + rx_ring: ((${self})->rx_ring); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
303 + //tx_ring: ((${self})->tx_ring); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
304 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
305 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
306 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
307 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
308 template type e1000::Register() |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
309 @@ -615,269 +867,6 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
310 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
311 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
312 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
313 - /* TODO: refactor |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
314 - * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
315 - * Split into two method methods: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
316 - * - e1000::RxRing::init_rx() |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
317 - * - e1000::TxRing::init_tx() |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
318 - * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
319 - * Also it should use the new methods in Socket::SKbuff. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
320 - */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
321 - template sequence set_up_device(Ethernet::Device rtx_ether_ctx) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
322 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
323 - chunk ::CALL() |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
324 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
325 - /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
326 - * This part is documented in the Intel Gigabit Ethernet Controller |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
327 - * Software Developper manual. (You can find it in the doc/hardware |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
328 - * directory). |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
329 - * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
330 - * Since this part is actually completely device specific it should |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
331 - * not be written here. (but in the front-end). |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
332 - */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
333 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
334 - /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
335 - * shortcut hw_ctx... maybe we should directly take an |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
336 - * e1000::Context? (but we would need to make it point back to |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
337 - * the struct net_device) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
338 - */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
339 - ${e1000::Context.ref} hw_ctx; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
340 - hw_ctx = &${rtx_ether_ctx}->hw_ctx; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
341 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
342 - /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
343 - * "General Configuration" (section 14.3): |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
344 - * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
345 - * - CTRL.ASDE/CTRL.SLU: Let the PHY handle the speed detection & |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
346 - * negociation; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
347 - * - CTRL.LRST/FRCSPD: Unset them to initiate the auto-negociation; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
348 - * - CTRL.PHY_RST: Unset it; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
349 - * - CTRL.ILOS: Unset it (ILOS is Invert Loss Of Signal); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
350 - * - CTRL.VME: Make sure it's not set to disable VLAN support; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
351 - * - Set the control flow registers to 0; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
352 - * - Finally, initialize all the statistic registers from |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
353 - * E1000_CRCERRS to E1000_TSCTFC. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
354 - */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
355 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
356 - int i; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
357 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
358 - rtx_e1000_register_set32(hw_ctx, E1000_CTRL, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
359 - E1000_CMD_ASDE | |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
360 - E1000_CMD_SLU); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
361 - rtx_e1000_register_unset32(hw_ctx, E1000_CTRL, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
362 - E1000_CMD_LRST | |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
363 - E1000_CMD_FRCSPD | |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
364 - E1000_CMD_PHY_RST | |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
365 - E1000_CMD_ILOS | |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
366 - E1000_CMD_VME); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
367 - rtx_e1000_register_write32(hw_ctx, E1000_FCAH, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
368 - rtx_e1000_register_write32(hw_ctx, E1000_FCAL, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
369 - rtx_e1000_register_write32(hw_ctx, E1000_FCT, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
370 - rtx_e1000_register_write32(hw_ctx, E1000_FCTTV, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
371 - for (i = 0; i != 64; ++i) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
372 - rtx_e1000_register_write32(hw_ctx, E1000_CRCERRS + i * 4, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
373 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
374 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
375 - ${Log::info("setup_device: general configuration done")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
376 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
377 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
378 - /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
379 - * Receive initialization (section 14.4): |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
380 - * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
381 - * 1. Program the receive address, in RAL/RAH; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
382 - * 2. Initialize the Multicast Table Array; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
383 - * 3. Program the interrupt mask register (done in |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
384 - * e1000::activate_device_interruption); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
385 - * 4. Allocate the receive descriptor ring and map it to make it |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
386 - * accessible by the device; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
387 - * 5. Write the start address of the ring in RDBAL/RDBAH and set |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
388 - * RDLEN (Receive Descriptor Length) to the size of the ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
389 - * 6. Set the RDH/RDT (Receive Descriptor Head/Tail) indexes to the |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
390 - * beginning and end of the ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
391 - * 7. Make sure that RCTL.BSIZE and .BSEX are at 0 to configure the |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
392 - * receive buffer size to 2048 bytes (e1000::rx_buffer_len). |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
393 - * 8. Set RCTL.EN to enable the receiver. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
394 - * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
395 - * The ugly casts here are caused by the lack of CNorm unstrict. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
396 - */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
397 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
398 - /* 1. Program the receive address */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
399 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
400 - /* (We should use uint{32,16}_t but CNorm doesn't know them yet) */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
401 - rtx_e1000_register_write32(hw_ctx, E1000_RAL, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
402 - *(unsigned int *)(${rtx_ether_ctx.dev_addr})); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
403 - /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
404 - * The 16 upper bits of RAH also store the AS bits (which should be |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
405 - * 0) and the AV bit (should be 1 to set the address as valid). |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
406 - */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
407 - rtx_e1000_register_write32(hw_ctx, E1000_RAH, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
408 - *(unsigned short *)(&${rtx_ether_ctx.dev_addr}[4])); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
409 - rtx_e1000_register_set32(hw_ctx, E1000_RAH, E1000_RAH_AV); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
410 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
411 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
412 - ${Log::info("setup_device: receive address programmed")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
413 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
414 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
415 - /* 2. Initialize the MTA */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
416 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
417 - for (i = 0; i != 128; ++i) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
418 - rtx_e1000_register_write32(hw_ctx, E1000_MTA + i * 4, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
419 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
420 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
421 - ${Log::info("setup_device: MTA init done")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
422 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
423 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
424 - /* 4. Setup the receive descriptor ring */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
425 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
426 - /* Allocate the descriptors */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
427 - hw_ctx->rx_ring.size = ${config.rx_ring_size} * sizeof(*hw_ctx->rx_ring.base); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
428 - hw_ctx->rx_ring.size = ALIGN(hw_ctx->rx_ring.size, 4096); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
429 - hw_ctx->rx_ring.base = dma_alloc_coherent( |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
430 - ${rtx_ether_ctx.device}, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
431 - hw_ctx->rx_ring.size, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
432 - &hw_ctx->rx_ring.dma_base, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
433 - GFP_KERNEL); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
434 - if (!hw_ctx->rx_ring.base) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
435 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
436 - ${Log::info("cannot allocate the descriptors for the rx ring")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
437 - goto err_rx_ring_alloc; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
438 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
439 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
440 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
441 - ${Log::info("setup_device: rx descriptors allocated")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
442 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
443 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
444 - /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
445 - * Allocate the skbuffs, map them for DMA, and write their address |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
446 - * in the corresponding descriptor. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
447 - */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
448 - for (i = 0; i != ${config.rx_ring_size}; ++i) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
449 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
450 - hw_ctx->rx_ring.skbuffs[i].skbuff = (${Socket::AbstractSKBuff}*)netdev_alloc_skb( |
121
6f600f83a763
WIP, fix Ethernet::Device::alloc_rx_skbuff
Louis Opter <louis@lse.epita.fr>
parents:
diff
changeset
|
451 - ${rtx_ether_ctx.net_device.k_net_dev}, /* XXX: .k_net_dev isn't expanded here */ |
122
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
452 - ${config.rx_buffer_len}); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
453 - if (!hw_ctx->rx_ring.skbuffs[i].skbuff) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
454 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
455 - ${Log::info("cannot allocate a skbuff for the rx ring")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
456 - goto err_skbuffs_alloc; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
457 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
458 - hw_ctx->rx_ring.skbuffs[i].dma_handle = dma_map_single( |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
459 - ${rtx_ether_ctx.device}, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
460 - (struct sk_buff *)hw_ctx->rx_ring.skbuffs[i].skbuff, /* XXX leaking cast */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
461 - ${config.rx_buffer_len}, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
462 - DMA_FROM_DEVICE); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
463 - int dma_error = dma_mapping_error(${rtx_ether_ctx.device}, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
464 - hw_ctx->rx_ring.skbuffs[i].dma_handle); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
465 - if (dma_error) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
466 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
467 - ${Log::info("cannot dma-map a skbuff for the rx ring")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
468 - goto err_skbuffs_map; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
469 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
470 - hw_ctx->rx_ring.base[i].buff_addr = cpu_to_le64( |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
471 - hw_ctx->rx_ring.skbuffs[i].skbuff); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
472 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
473 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
474 - ${Log::info("setup_device: skbuffs allocated")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
475 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
476 - /* 5. Save the emplacement and the size of the ring in RDBA/RDLEN */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
477 - rtx_e1000_register_write32(hw_ctx, E1000_RDBAL, hw_ctx->rx_ring.dma_base & 0xffffffff); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
478 - rtx_e1000_register_write32(hw_ctx, E1000_RDBAH, hw_ctx->rx_ring.dma_base >> 32); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
479 - rtx_e1000_register_write32(hw_ctx, E1000_RDLEN, hw_ctx->rx_ring.size); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
480 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
481 - /* 6. Setup RDH/RDT */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
482 - rtx_e1000_register_write32(hw_ctx, E1000_RDH, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
483 - rtx_e1000_register_write32(hw_ctx, E1000_RDT, ${config.rx_ring_size} - 1); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
484 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
485 - /* 7. Configure the buffer size, */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
486 - rtx_e1000_register_set32(hw_ctx, E1000_RCTL, E1000_RCTL_BSIZE_${config.rx_buffer_len}); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
487 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
488 - /* 8. Enable the receiver */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
489 - rtx_e1000_register_set32(hw_ctx, E1000_RCTL, E1000_RCTL_EN); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
490 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
491 - ${Log::info("setup_device: receive registers configured and receiver enabled")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
492 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
493 - /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
494 - * Transmission initialization (section 14.5): |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
495 - * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
496 - * 1. Allocate the transmit descriptors ring and map it to make it |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
497 - * accessible by the device; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
498 - * 2. Write the start address of the ring in TDBAL/TDBAH and set |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
499 - * TDLEN to the size of the ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
500 - * 3. Set the TDH/TDT indexes to the beginning and end of the ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
501 - * 4. Set TCTL.PSP to pad short packets and TCTL.EN to enable the |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
502 - * transmitter. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
503 - */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
504 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
505 - /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
506 - * XXX: at this point we must be careful to not fuck up with i, or |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
507 - * we are going go have surprises in `err_skbuffs_alloc`. Maybe it's |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
508 - * time to separate the rx and tx initialization in two functions. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
509 - */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
510 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
511 - /* 1. Allocate the tx ring */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
512 - hw_ctx->tx_ring.size = ${config.tx_ring_size} * sizeof(*hw_ctx->tx_ring.base); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
513 - hw_ctx->tx_ring.size = ALIGN(hw_ctx->tx_ring.size, 4096); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
514 - hw_ctx->tx_ring.base = dma_alloc_coherent( |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
515 - ${rtx_ether_ctx.device}, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
516 - hw_ctx->tx_ring.size, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
517 - &hw_ctx->tx_ring.dma_base, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
518 - GFP_KERNEL); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
519 - if (!hw_ctx->rx_ring.base) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
520 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
521 - ${Log::info("cannot allocate the descriptors for the tx ring")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
522 - goto err_tx_ring_alloc; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
523 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
524 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
525 - ${Log::info("setup_device: tx descriptors allocated")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
526 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
527 - /* 2. Save the emplacement and the size of the ring in TDBA/TDLEN */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
528 - rtx_e1000_register_write32(hw_ctx, E1000_TDBAL, hw_ctx->tx_ring.dma_base & 0xffffffff); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
529 - rtx_e1000_register_write32(hw_ctx, E1000_TDBAH, hw_ctx->tx_ring.dma_base >> 32); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
530 - rtx_e1000_register_write32(hw_ctx, E1000_TDLEN, hw_ctx->tx_ring.size); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
531 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
532 - /* 3. Setup TDH/TDT to zero: the queue is empty */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
533 - rtx_e1000_register_write32(hw_ctx, E1000_TDH, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
534 - rtx_e1000_register_write32(hw_ctx, E1000_TDT, 0); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
535 - hw_ctx->tx_ring.head = 0; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
536 - hw_ctx->tx_ring.tail = 0; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
537 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
538 - /* 4. Set TCTL.PSP and enable the transmitter */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
539 - rtx_e1000_register_set32(hw_ctx, E1000_TCTL, E1000_TCTL_PSP|E1000_TCTL_EN); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
540 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
541 - ${Log::info("transmit registers configured and transmitter enabled")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
542 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
543 - /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
544 - * XXX: We can't return here since we are not in a function but in |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
545 - * a chunk of code (injected in a function). |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
546 - */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
547 - goto ok; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
548 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
549 - err_tx_ring_alloc: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
550 - /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
551 - * Likewise, always the same problem with error handling, we don't |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
552 - * know where we are at in the "parent context": |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
553 - */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
554 - err_skbuffs_alloc: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
555 - while (i--) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
556 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
557 - dma_unmap_single( |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
558 - ${rtx_ether_ctx.device}, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
559 - hw_ctx->rx_ring.skbuffs[i].dma_handle, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
560 - ${config.rx_buffer_len}, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
561 - DMA_FROM_DEVICE); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
562 - err_skbuffs_map: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
563 - /* XXX leaking cast: */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
564 - dev_kfree_skb((struct sk_buff *)hw_ctx->rx_ring.skbuffs[i].skbuff); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
565 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
566 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
567 - dma_free_coherent(${rtx_ether_ctx.device}, hw_ctx->rx_ring.size, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
568 - hw_ctx->rx_ring.base, hw_ctx->rx_ring.dma_base); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
569 - err_rx_ring_alloc: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
570 - return -ENOMEM; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
571 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
572 - ok: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
573 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
574 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
575 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
576 /* TODO: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
577 * |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
578 * Refactor into two methods (one in RxRing and one in TxRing) and make use |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
579 diff --git a/rathaxes/samples/e1000/e1000.rti b/rathaxes/samples/e1000/e1000.rti |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
580 --- a/rathaxes/samples/e1000/e1000.rti |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
581 +++ b/rathaxes/samples/e1000/e1000.rti |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
582 @@ -1,23 +1,10 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
583 -interface e1000 : Socket, Ethernet, PCI, LKM, Builtin |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
584 +interface e1000 : Socket, Ethernet, DMA, PCI, LKM, Builtin |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
585 { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
586 required variable Builtin::number rx_ring_size; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
587 required variable Builtin::number tx_ring_size; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
588 required variable Builtin::number rx_buffer_len; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
589 required variable Builtin::number tx_max_data_per_desc; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
590 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
591 - provided type Context |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
592 - { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
593 - chunk Ethernet::HardwareContext(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
594 - decl data_types(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
595 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
596 - /* Callbacks/Hooks which should probably be in the front-end: */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
597 - chunk Ethernet::adapter_init_context(Ethernet::Device, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
598 - Builtin::number, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
599 - Builtin::symbol); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
600 - chunk Ethernet::adapter_reset(Ethernet::Device); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
601 - chunk Ethernet::adapter_load_mac_address(Ethernet::Device); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
602 - } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
603 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
604 provided type RxDescriptor |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
605 { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
606 chunk LKM::includes(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
607 @@ -35,6 +22,32 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
608 { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
609 decl data_types(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
610 method init(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
611 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
612 + /* XXX: Callback that should be in the front-end: */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
613 + chunk Ethernet::adapter_init_rx(Ethernet::Device); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
614 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
615 + attribute DMA::DMAHandle.scalar dma_base; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
616 + attribute Builtin::number.scalar size; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
617 + } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
618 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
619 + provided type Context |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
620 + { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
621 + chunk Ethernet::HardwareContext(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
622 + decl data_types(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
623 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
624 + /* XXX: |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
625 + * These callbacks/Hooks which should probably be in the front-end. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
626 + * Also, I'm not too happy about the names, it's difficult to make |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
627 + * the difference between the probe and open parts. |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
628 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
629 + chunk Ethernet::adapter_init_context(Ethernet::Device, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
630 + Builtin::number, |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
631 + Builtin::symbol); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
632 + chunk Ethernet::adapter_reset(Ethernet::Device); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
633 + chunk Ethernet::adapter_load_mac_address(Ethernet::Device); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
634 + chunk Ethernet::adapter_setup(Ethernet::Device); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
635 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
636 + attribute RxRing.scalar rx_ring; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
637 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
638 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
639 provided type TxRing |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
640 @@ -44,6 +57,9 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
641 decl data_types(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
642 method init(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
643 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
644 + /* XXX: Callback that should be in the front-end: */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
645 + chunk Ethernet::adapter_init_tx(Ethernet::Device); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
646 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
647 /* Clean the ring (i.e: move the head closer to the tail): */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
648 method clean(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
649 /* Return the number of clean descriptors left in the ring: */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
650 diff --git a/rathaxes/samples/e1000/ethernet.blt b/rathaxes/samples/e1000/ethernet.blt |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
651 --- a/rathaxes/samples/e1000/ethernet.blt |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
652 +++ b/rathaxes/samples/e1000/ethernet.blt |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
653 @@ -170,6 +170,9 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
654 ${Log::info("Cannot register the interrupt handler")}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
655 return error; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
656 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
657 + ${pointcut Ethernet::adapter_setup(local.rtx_ether_ctx)}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
658 + ${pointcut Ethernet::adapter_init_rx(local.rtx_ether_ctx)}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
659 + ${pointcut Ethernet::adapter_init_tx(local.rtx_ether_ctx)}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
660 ${pointcut ::IMPLEMENTATION(local.rtx_ether_ctx)}; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
661 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
662 return 0; |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
663 diff --git a/rathaxes/samples/e1000/ethernet.rti b/rathaxes/samples/e1000/ethernet.rti |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
664 --- a/rathaxes/samples/e1000/ethernet.rti |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
665 +++ b/rathaxes/samples/e1000/ethernet.rti |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
666 @@ -52,6 +52,15 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
667 provided chunk LKM::includes(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
668 provided chunk LKM::prototypes(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
669 provided chunk LKM::code(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
670 + |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
671 + /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
672 + * For e1000, this part is documented in the Intel Gigabit Ethernet |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
673 + * Controller Software Developper manual. (You can find it in the |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
674 + * doc/hardware directory). |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
675 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
676 + provided pointcut Ethernet::adapter_setup(Ethernet::Device); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
677 + provided pointcut Ethernet::adapter_init_rx(Ethernet::Device); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
678 + provided pointcut Ethernet::adapter_init_tx(Ethernet::Device); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
679 } |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
680 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
681 required sequence send(Ethernet::Device, Socket::AbstractSKBuff) |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
682 diff --git a/rathaxes/samples/e1000/lkm.rtx b/rathaxes/samples/e1000/lkm.rtx |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
683 --- a/rathaxes/samples/e1000/lkm.rtx |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
684 +++ b/rathaxes/samples/e1000/lkm.rtx |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
685 @@ -4,10 +4,6 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
686 { |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
687 Log::info("opening the device"); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
688 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
689 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
690 - e1000::set_up_device(dev); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
691 - Log::info("device activated"); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
692 - |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
693 e1000::activate_device_interruption(dev); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
694 Log::info("interruption enabled"); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
695 |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
696 diff --git a/rathaxes/samples/e1000/socket.rti b/rathaxes/samples/e1000/socket.rti |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
697 --- a/rathaxes/samples/e1000/socket.rti |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
698 +++ b/rathaxes/samples/e1000/socket.rti |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
699 @@ -15,6 +15,10 @@ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
700 decl data_types(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
701 method init(Socket::AbstractSKBuff); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
702 method dump_infos(); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
703 + /* |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
704 + * map_to and map_from return a non-zero value on failure (which |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
705 + * doesn't correspond to an errno value): |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
706 + */ |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
707 method map_to(Device::AbstractDevice); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
708 method map_from(Device::AbstractDevice); |
52402232483f
WIP on the split up of e1000::set_up_device
Louis Opter <louis@lse.epita.fr>
parents:
121
diff
changeset
|
709 method unmap_to_and_free(Device::AbstractDevice); |