diff options
| author | Norbert van Bolhuis <nvbolhuis@aimvalley.nl> | 2014-01-10 04:22:37 -0500 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2014-01-13 17:45:59 -0500 |
| commit | 7e11daa7c19ec319fa4b750fd249a18957f17797 (patch) | |
| tree | 57227f64774c356c4643e35d4de97faddb34217b | |
| parent | 6daaf0de2f3170206f57e7881adfbd8682cdd7fb (diff) | |
packet: doc: describe PACKET_MMAP with one packet socket for rx and tx
Document how to use one AF_PACKET mmap socket for RX and TX.
Signed-off-by: Norbert van Bolhuis <nvbolhuis@aimvalley.nl>
Signed-off-by: Daniel Borkmann <dborkman@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
| -rw-r--r-- | Documentation/networking/packet_mmap.txt | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/Documentation/networking/packet_mmap.txt b/Documentation/networking/packet_mmap.txt index 723bf3d33a6e..91ffe1d9e8ca 100644 --- a/Documentation/networking/packet_mmap.txt +++ b/Documentation/networking/packet_mmap.txt | |||
| @@ -98,6 +98,11 @@ by the kernel. | |||
| 98 | The destruction of the socket and all associated resources | 98 | The destruction of the socket and all associated resources |
| 99 | is done by a simple call to close(fd). | 99 | is done by a simple call to close(fd). |
| 100 | 100 | ||
| 101 | Similarly as without PACKET_MMAP, it is possible to use one socket | ||
| 102 | for capture and transmission. This can be done by mapping the | ||
| 103 | allocated RX and TX buffer ring with a single mmap() call. | ||
| 104 | See "Mapping and use of the circular buffer (ring)". | ||
| 105 | |||
| 101 | Next I will describe PACKET_MMAP settings and its constraints, | 106 | Next I will describe PACKET_MMAP settings and its constraints, |
| 102 | also the mapping of the circular buffer in the user process and | 107 | also the mapping of the circular buffer in the user process and |
| 103 | the use of this buffer. | 108 | the use of this buffer. |
| @@ -414,6 +419,19 @@ tp_block_size/tp_frame_size frames there will be a gap between | |||
| 414 | the frames. This is because a frame cannot be spawn across two | 419 | the frames. This is because a frame cannot be spawn across two |
| 415 | blocks. | 420 | blocks. |
| 416 | 421 | ||
| 422 | To use one socket for capture and transmission, the mapping of both the | ||
| 423 | RX and TX buffer ring has to be done with one call to mmap: | ||
| 424 | |||
| 425 | ... | ||
| 426 | setsockopt(fd, SOL_PACKET, PACKET_RX_RING, &foo, sizeof(foo)); | ||
| 427 | setsockopt(fd, SOL_PACKET, PACKET_TX_RING, &bar, sizeof(bar)); | ||
| 428 | ... | ||
| 429 | rx_ring = mmap(0, size * 2, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0); | ||
| 430 | tx_ring = rx_ring + size; | ||
| 431 | |||
| 432 | RX must be the first as the kernel maps the TX ring memory right | ||
| 433 | after the RX one. | ||
| 434 | |||
| 417 | At the beginning of each frame there is an status field (see | 435 | At the beginning of each frame there is an status field (see |
| 418 | struct tpacket_hdr). If this field is 0 means that the frame is ready | 436 | struct tpacket_hdr). If this field is 0 means that the frame is ready |
| 419 | to be used for the kernel, If not, there is a frame the user can read | 437 | to be used for the kernel, If not, there is a frame the user can read |
