Tải bản đầy đủ (.pdf) (1,194 trang)

TCP IP illustrated, volume II the implementation kho tài liệu training

Bạn đang xem bản rút gọn của tài liệu. Xem và tải ngay bản đầy đủ của tài liệu tại đây (37.98 MB, 1,194 trang )


TCP/IP Illustrated
The Implementation
Volume 2
W. Richard Stevens
Gary R. Wright

Addison-Wesley Professional

i


Addison-Wesley Professional Computing Series
Brian W. Kernighan, Consulting Editor
Matthew H. Austern, Generic Programming and the STL: Using and Extending the C++ Standard Template Library
David R. Butenhof, Programming with POSIX® Threads
Brent Callaghan, NFS Illustrated
Tom Cargill, C++ Programming Style
William R. Cheswick/Steven M. Bellovin/Aviel D. Rubin, Firewalls and Internet Security, Second Edition: Repelling
the Wily Hacker
David A. Curry, UNIX® System Security: A Guide for Users and System Administrators
Stephen C. Dewhurst, C++ Gotchas: Avoiding Common Problems in Coding and Design
Dan Farmer/Wietse Venema, Forensic Discovery
Erich Gamma/Richard Helm/Ralph Johnson/John Vlissides, Design Patterns: Elements of Reusable ObjectOriented Software
Erich Gamma/Richard Helm/Ralph Johnson/John Vlissides, Design Patterns CD: Elements of Reusable ObjectOriented Software
Peter Haggar, Practical Java™ Programming Language Guide
David R. Hanson, C Interfaces and Implementations: Techniques for Creating Reusable Software
Mark Harrison/Michael McLennan, Effective Tcl/Tk Programming: Writing Better Programs with Tcl and Tk
Michi Henning/Steve Vinoski, Advanced CORBA® Programming with C++
Brian W. Kernighan/Rob Pike, The Practice of Programming
S. Keshav, An Engineering Approach to Computer Networking: ATM Networks, the Internet, and the Telephone Network


John Lakos, Large-Scale C++ Software Design
Scott Meyers, Effective C++ CD: 85 Specific Ways to Improve Your Programs and Designs
Scott Meyers, Effective C++, Third Edition: 55 Specific Ways to Improve Your Programs and Designs
Scott Meyers, More Effective C++: 35 New Ways to Improve Your Programs and Designs
Scott Meyers, Effective STL: 50 Specific Ways to Improve Your Use of the Standard Template Library
Robert B. Murray, C++ Strategies and Tactics
David R. Musser/Gillmer J. Derge/Atul Saini, STL Tutorial and Reference Guide, Second Edition:
C++ Programming with the Standard Template Library
John K. Ousterhout, Tcl and the Tk Toolkit
Craig Partridge, Gigabit Networking
Radia Perlman, Interconnections, Second Edition: Bridges, Routers, Switches, and Internetworking Protocols
Stephen A. Rago, UNIX® System V Network Programming
Eric S. Raymond, The Art of UNIX Programming
Marc J. Rochkind, Advanced UNIX Programming, Second Edition
Curt Schimmel, UNIX® Systems for Modern Architectures: Symmetric Multiprocessing and Caching for Kernel Programmers
W. Richard Stevens, TCP/IP Illustrated, Volume 1: The Protocols
W. Richard Stevens, TCP/IP Illustrated, Volume 3: TCP for Transactions, HTTP, NNTP, and the UNIX®
Domain Protocols
W. Richard Stevens/Bill Fenner/Andrew M. Rudoff, UNIX Network Programming Volume 1, Third Edition: The
Sockets Networking API
W. Richard Stevens/Stephen A. Rago, Advanced Programming in the UNIX® Environment, Second Edition
W. Richard Stevens/Gary R. Wright, TCP/IP Illustrated Volumes 1-3 Boxed Set
John Viega/Gary McGraw, Building Secure Software: How to Avoid Security Problems the Right Way
Gary R. Wright/W. Richard Stevens, TCP/IP Illustrated, Volume 2: The Implementation
Ruixi Yuan/W. Timothy Strayer, Virtual Private Networks: Technologies and Solutions

Visit www.awprofessional.com/series/professionalcomputing for more information about these titles.

ii



Table of Contents
Copyright
Preface
Chapter 1. Introduction
Section 1.1. Introduction
Section 1.2. Source Code Presentation
Section 1.3. History
Section 1.4. Application Programming Interfaces
Section 1.5. Example Program
Section 1.6. System Calls and Library Functions
Section 1.7. Network Implementation Overview
Section 1.8. Descriptors
Section 1.9. Mbufs (Memory Buffers) and Output Processing
Section 1.10. Input Processing
Section 1.11. Network Implementation Overview Revisited
Section 1.12. Interrupt Levels and Concurrency
Section 1.13. Source Code Organization
Section 1.14. Test Network
Section 1.15. Summary
Chapter 2. Mbufs: Memory Buffers
Section 2.1. Introduction
Section 2.2. Code Introduction
Section 2.3. Mbuf Definitions
Section 2.4. mbuf Structure
Section 2.5. Simple Mbuf Macros and Functions
Section 2.6. m_devget and m_pullup Functions
Section 2.7. Summary of Mbuf Macros and Functions
Section 2.8. Summary of Net/3 Networking Data Structures
Section 2.9. m_copy and Cluster Reference Counts

Section 2.10. Alternatives
Section 2.11. Summary
Chapter 3. Interface Layer
Section 3.1. Introduction
Section 3.2. Code Introduction
Section 3.3. ifnet Structure
Section 3.4. ifaddr Structure
Section 3.5. sockaddr Structure
Section 3.6. ifnet and ifaddr Specialization
Section 3.7. Network Initialization Overview
Section 3.8. Ethernet Initialization
Section 3.9. SLIP Initialization
Section 3.10. Loopback Initialization
Section 3.11. if_attach Function
Section 3.12. ifinit Function
3.13 Summary
Chapter 4. Interfaces: Ethernet
Section 4.1. Introduction
Section 4.2. Code Introduction
Section 4.3. Ethernet Interface
iii

1
1
1
3
4
4
6
8

9
13
18
21
22
25
26
27
29
29
33
34
35
37
41
48
51
53
57
57
59
59
59
61
70
72
73
75
77
80

83
83
91
93
94
94
95
98


Section 4.4. ioctl System Call
Section 4.5. Summary
Chapter 5. Interfaces: SLIP and Loopback
Section 5.1. Introduction
Section 5.2. Code Introduction
Section 5.3. SLIP Interface
Section 5.4. Loopback Interface
Section 5.5. Summary
Chapter 6. IP Addressing
Section 6.1. Introduction
Section 6.2. Code Introduction
Section 6.3. Interface and Address Summary
Section 6.4. sockaddr_in Structure
Section 6.5. in_ifaddr Structure
Section 6.6. Address Assignment
Section 6.7. Interface ioctl Processing
Section 6.8. Internet Utility Functions
Section 6.9. ifnet Utility Functions
Section 6.10. Summary
Chapter 7. Domains and Protocols

Section 7.1. Introduction
Section 7.2. Code Introduction
Section 7.3. domain Structure
Section 7.4. protosw Structure
Section 7.5. IP domain and protosw Structures
Section 7.6. pffindproto and pffindtype Functions
Section 7.7. pfctlinput Function
Section 7.8. IP Initialization
Section 7.9. sysctl System Call
Section 7.10. Summary
Chapter 8. IP: Internet Protocol
Section 8.1. Introduction
Section 8.2. Code Introduction
Section 8.3. IP Packets
Section 8.4. Input Processing: ipintr Function
Section 8.5. Forwarding: ip_forward Function
Section 8.6. Output Processing: ip_output Function
Section 8.7. Internet Checksum: in_cksum Function
Section 8.8. setsockopt and getsockopt System Calls
Section 8.9. ip_sysctl Function
Section 8.10. Summary
Chapter 9. IP Option Processing
Section 9.1. Introduction
Section 9.2. Code Introduction
Section 9.3. Option Format
Section 9.4. ip_dooptions Function
Section 9.5. Record Route Option
Section 9.6. Source and Record Route Options
iv


115
127
128
128
128
129
149
152
153
153
155
155
157
158
159
176
179
179
180
182
182
182
183
184
187
193
194
195
197
200

202
202
203
205
208
216
224
232
236
241
242
244
244
244
245
246
249
251


Section 9.7. Timestamp Option
Section 9.8. ip_insertoptions Function
Section 9.9. ip_pcbopts Function
Section 9.10. Limitations
Section 9.11. Summary
Chapter 10. IP Fragmentation and Reassembly
Section 10.1. Introduction
Section 10.2. Code Introduction
Section 10.3. Fragmentation
Section 10.4. ip_optcopy Function

Section 10.5. Reassembly
Section 10.6. ip_reass Function
Section 10.7. ip_slowtimo Function
Section 10.8. Summary
Chapter 11. ICMP: Internet Control Message Protocol
Section 11.1. Introduction
Section 11.2. Code Introduction
Section 11.3. icmp Structure
Section 11.4. ICMP protosw Structure
Section 11.5. Input Processing: icmp_input Function
Section 11.6. Error Processing
Section 11.7. Request Processing
Section 11.8. Redirect Processing
Section 11.9. Reply Processing
Section 11.10. Output Processing
Section 11.11. icmp_error Function
Section 11.12. icmp_reflect Function
Section 11.13. icmp_send Function
Section 11.14. icmp_sysctl Function
Section 11.15. Summary
Chapter 12. IP Multicasting
Section 12.1. Introduction
Section 12.2. Code Introduction
Section 12.3. Ethernet Multicast Addresses
Section 12.4. ether_multi Structure
Section 12.5. Ethernet Multicast Reception
Section 12.6. in_multi Structure
Section 12.7. ip_moptions Structure
Section 12.8. Multicast Socket Options
Section 12.9. Multicast TTL Values

Section 12.10. ip_setmoptions Function
Section 12.11. Joining an IP Multicast Group
Section 12.12. Leaving an IP Multicast Group
Section 12.13. ip_getmoptions Function
Section 12.14. Multicast Input Processing: ipintr Function
Section 12.15. Multicast Output Processing: ip_output Function
Section 12.16. Performance Considerations
Section 12.17. Summary
Chapter 13. IGMP: Internet Group Management Protocol
Section 13.1. Introduction
Section 13.2. Code Introduction
v

258
262
266
270
270
272
272
273
274
279
280
283
296
297
299
299
302

305
306
307
311
314
319
321
322
323
327
332
333
334
336
336
338
339
340
342
343
345
346
347
349
354
365
370
372
373
378

378
380
380
381


Section 13.3. igmp Structure
Section 13.4. IGMP protosw Structure
Section 13.5. Joining a Group: igmp_joingroup Function
Section 13.6. igmp_fasttimo Function
Section 13.7. Input Processing: igmp_input Function
Section 13.8. Leaving a Group: igmp_leavegroup Function
Section 13.9. Summary
Chapter 14. IP Multicast Routing
Section 14.1. Introduction
Section 14.2. Code Introduction
Section 14.3. Multicast Output Processing Revisited
Section 14.4. mrouted Daemon
Section 14.5. Virtual Interfaces
Section 14.6. IGMP Revisited
Section 14.7. Multicast Routing
Section 14.8. Multicast Forwarding: ip_mforward Function
Section 14.9. Cleanup: ip_mrouter_done Function
Section 14.10. Summary
Chapter 15. Socket Layer
Section 15.1. Introduction
Section 15.2. Code Introduction
Section 15.3. socket Structure
Section 15.4. System Calls
Section 15.5. Processes, Descriptors, and Sockets

Section 15.6. socket System Call
Section 15.7. getsock and sockargs Functions
Section 15.8. bind System Call
Section 15.9. listen System Call
Section 15.10. tsleep and wakeup Functions
Section 15.11. accept System Call
Section 15.12. sonewconn and soisconnected Functions
Section 15.13. connect System call
Section 15.14. shutdown System Call
Section 15.15. close System Call
Section 15.16. Summary
Chapter 16. Socket I/O
Section 16.1. Introduction
Section 16.2. Code Introduction
Section 16.3. Socket Buffers
Section 16.4. write, writev, sendto, and sendmsg System Calls
Section 16.5. sendmsg System Call
Section 16.6. sendit Function
Section 16.7. sosend Function
Section 16.8. read, readv, recvfrom, and recvmsg System Calls
Section 16.9. recvmsg System Call
Section 16.10. recvit Function
Section 16.11. soreceive Function
Section 16.12. soreceive Code
Section 16.13. select System Call
Section 16.14. Summary
Chapter 17. Socket Options
vi

382

383
384
386
390
394
395
396
396
396
398
399
402
410
416
424
434
435
436
436
437
437
443
447
448
458
460
462
463
465
469

472
476
479
482
484
484
484
485
489
492
494
498
510
511
513
515
520
522
536
550


Section 17.1. Introduction
Section 17.2. Code Introduction
Section 17.3. setsockopt System Call
Section 17.4. getsockopt System Call
Section 17.5. fcntl and ioctl System Calls
Section 17.6. getsockname System Call
Section 17.7. getpeername System Call
Section 17.8. Summary

Chapter 18. Radix Tree Routing Tables
Section 18.1. Introduction
Section 18.2. Routing Table Structure
Section 18.3. Routing Sockets
Section 18.4. Code Introduction
Section 18.5. Radix Node Data Structures
Section 18.6. Routing Structures
Section 18.7. Initialization: route_init and rtable_init Functions
Section 18.8. Initialization: rn_init and rn_inithead Functions
Section 18.9. Duplicate Keys and Mask Lists
Section 18.10. rn_match Function
Section 18.11. rn_search Function
Section 18.12. Summary
Chapter 19. Routing Requests and Routing Messages
Section 19.1. Introduction
Section 19.2. rtalloc and rtalloc1 Functions
Section 19.3. RTFREE Macro and rtfree Function
Section 19.4. rtrequest Function
Section 19.5. rt_setgate Function
Section 19.6. rtinit Function
Section 19.7. rtredirect Function
Section 19.8. Routing Message Structures
Section 19.9. rt_missmsg Function
Section 19.10. rt_ifmsg Function
Section 19.11. rt_newaddrmsg Function
Section 19.12. rt_msg1 Function
Section 19.13. rt_msg2 Function
Section 19.14. sysctl_rtable Function
Section 19.15. sysctl_dumpentry Function
Section 19.16. sysctl_iflist Function

Section 19.17. Summary
Chapter 20. Routing Sockets
Section 20.1. Introduction
Section 20.2. routedomain and protosw Structures
Section 20.3. Routing Control Blocks
Section 20.4. raw_init Function
Section 20.5. route_output Function
Section 20.6. rt_xaddrs Function
Section 20.7. rt_setmetrics Function
Section 20.8. raw_input Function
Section 20.9. route_usrreq Function
Section 20.10. raw_usrreq Function
Section 20.11. raw_attach, raw_detach, and raw_disconnect Functions
vii

550
551
551
557
561
567
568
570
571
571
571
580
581
584
589

592
596
599
603
610
611
613
613
613
616
618
625
628
613
635
639
641
643
645
647
651
657
659
661
663
663
663
664
665
666

681
681
682
684
686
691


Section 20.12. Summary
Chapter 21. ARP: Address Resolution Protocol
Section 21.1. Introduction
Section 21.2. ARP and the Routing Table
Section 21.3. Code Introduction
Section 21.4. ARP Structures
Section 21.5. arpwhohas Function
Section 21.6. arprequest Function
Section 21.7. arpintr Function
Section 21.8. in_arpinput Function
Section 21.9. ARP Timer Functions
Section 21.10. arpresolve Function
Section 21.11. arplookup Function
Section 21.12. Proxy ARP
Section 21.13. arp_rtrequest Function
Section 21.14. ARP and Multicasting
Section 21.15. Summary
Chapter 22. Protocol Control Blocks
Section 22.1. Introduction
Section 22.2. Code Introduction
Section 22.3. inpcb Structure
Section 22.4. in_pcballoc and in_pcbdetach Functions

Section 22.5. Binding, Connecting, and Demultiplexing
Section 22.6. in_pcblookup Function
Section 22.7. in_pcbbind Function
Section 22.8. in_pcbconnect Function
Section 22.9. in_pcbdisconnect Function
Section 22.10. in_setsockaddr and in_setpeeraddr Functions
Section 22.11. in_pcbnotify, in_rtchange, and in_losing Functions
Section 22.12. Implementation Refinements
Section 22.13. Summary
Chapter 23. UDP: User Datagram Protocol
Section 23.1. Introduction
Section 23.2. Code Introduction
Section 23.3. UDP protosw Structure
Section 23.4. UDP Header
Section 23.5. udp_init Function
Section 23.6. udp_output Function
Section 23.7. udp_input Function
Section 23.8. udp_saveopt Function
Section 23.9. udp_ctlinput Function
Section 23.10. udp_usrreq Function
Section 23.11. udp_sysctl Function
Section 23.12. Implementation Refinements
Section 23.13. Summary
Chapter 24. TCP: Transmission Control Protocol
Section 24.1. Introduction
Section 24.2. Code Introduction
Section 24.3. TCP protosw Structure
Section 24.4. TCP Header
Section 24.5. TCP Control Block
viii


693
695
695
695
697
700
702
703
706
707
714
715
720
722
723
730
731
733
733
735
736
737
739
745
749
756
762
762
763

771
772
775
775
775
778
778
780
780
789
801
803
805
812
812
814
817
817
817
821
822
824


Section 24.6. TCP State Transition Diagram
Section 24.7. TCP Sequence Numbers
Section 24.8. tcp_init Function
Section 24.9. Summary
Chapter 25. TCP Timers
Section 25.1. Introduction

Section 25.2. Code Introduction
Section 25.3. tcp_canceltimers Function
Section 25.4. tcp_fasttimo Function
Section 25.5. tcp_slowtimo Function
Section 25.6. tcp_timers Function
Section 25.7. Retransmission Timer Calculations
Section 25.8. tcp_newtcpcb Function
Section 25.9. tcp_setpersist Function
Section 25.10. tcp_xmit_timer Function
Section 25.11. Retransmission Timeout: tcp_timers Function
Section 25.12. An RTT Example
Section 25.13. Summary
Chapter 26. TCP Output
Section 26.1. Introduction
Section 26.2. tcp_output Overview
Section 26.3. Determine if a Segment Should be Sent
Section 26.4. TCP Options
Section 26.5. Window Scale Option
Section 26.6. Timestamp Option
Section 26.7. Send a Segment
Section 26.8. tcp_template Function
Section 26.9. tcp_respond Function
Section 26.10. Summary
Chapter 27. TCP Functions
Section 27.1. Introduction
Section 27.2. tcp_drain Function
Section 27.3. tcp_drop Function
Section 27.4. tcp_close Function
Section 27.5. tcp_mss Function
Section 27.6. tcp_ctlinput Function

Section 27.7. tcp_notify Function
Section 27.8. tcp_quench Function
Section 27.9. TCP_REASS Macro and tcp_reass Function
Section 27.10. tcp_trace Function
Section 27.11. Summary
Chapter 28. TCP Input
Section 28.1. Introduction
Section 28.2. Preliminary Processing
Section 28.3. tcp_dooptions Function
Section 28.4. Header Prediction
Section 28.5. TCP Input: Slow Path Processing
Section 28.6. Initiation of Passive Open, Completion of Active Open
Section 28.7. PAWS: Protection Against Wrapped Sequence Numbers
Section 28.8. Trim Segment so Data is Within Window
Section 28.9. Self-Connects and Simultaneous Opens
ix

826
833
828
836
837
837
838
840
840
841
843
850
852

854
856
862
868
869
871
871
871
873
885
886
887
891
907
909
912
915
915
915
915
917
921
928
929
930
931
941
946
947
949

949
958
961
967
968
978
981
988


Section 28.10. Record Timestamp
Section 28.11. RST Processing
Section 28.12. Summary
Chapter 29. TCP Input (Continued)
Section 29.1. Introduction
Section 29.2. ACK Processing Overview
Section 29.3. Completion of Passive Opens and Simultaneous Opens
Section 29.4. Fast Retransmit and Fast Recovery Algorithms
Section 29.5. ACK Processing
Section 29.6. Update Window Information
Section 29.7. Urgent Mode Processing
Section 29.8. tcp_pulloutofband Function
Section 29.9. Processing of Received Data
Section 29.10. FIN Processing
Section 29.11. Final Processing
Section 29.12. Implementation Refinements
Section 29.13. Header Compression
Section 29.14. Summary
Chapter 30. TCP User Requests
Section 30.1. Introduction

Section 30.2. tcp_usrreq Function
Section 30.3. tcp_attach Function
Section 30.4. tcp_disconnect Function
Section 30.5. tcp_usrclosed Function
Section 30.6. tcp_ctloutput Function
Section 30.7. Summary
Chapter 31. BPF: BSD Packet Filter
Section 31.1. Introduction
Section 31.2. Code Introduction
Section 31.3. bpf_if Structure
Section 31.4. bpf_d Structure
Section 31.5. BPF Input
Section 31.6. BPF Output
Section 31.7. Summary
Chapter 32. Raw IP
Section 32.1. Introduction
Section 32.2. Code Introduction
Section 32.3. Raw IP protosw Structure
Section 32.4. rip_init Function
Section 32.5. rip_input Function
Section 32.6. rip_output Function
Section 32.7. rip_usrreq Function
Section 32.8. rip_ctloutput Function
Section 32.9. Summary
Epilogue
Solutions to Selected Exercises
Chapter 1
Chapter 2
Chapter 3
Chapter 4

Chapter 5
x

990
991
993
995
995
995
996
998
1003
1010
1012
1016
1018
1020
1023
1026
1026
1035
1037
1037
1037
1050
1051
1052
1054
1058
1059

1059
1059
1060
1065
1073
1079
1081
1082
1082
1082
1084
1086
1086
1089
1091
1096
1098
1100
1102


Chapter 6
Chapter 7
Chapter 8
Chapter 9
Chapter 10
Chapter 11
Chapter 12
Chapter 13
Chapter 14

Chapter 15
Chapter 16
Chapter 17
Chapter 18
Chapter 19
Chapter 20
Chapter 21
Chapter 22
Chapter 23
Chapter 24
Chapter 25
Chapter 26
Chapter 27
Chapter 28
Chapter 29
Chapter 30
Chapter 31
Chapter 32
Source Code Availability
URLs: Uniform Resource Locators
4.4BSD-Lite
Operating Systems that Run the 4.4BSD-Lite Networking Software
RFCs
GNU Software
PPP Software
mrouted Software
ISODE Software
RFC 1122 Compliance
Section C.1. Link-Layer Requirements
Section C.2. IP Requirements

Section C.3. IP Options Requirements
Section C.4. IP Fragmentation and Reassembly Requirements
Section C.5. ICMP Requirements
Section C.6. Multicasting Requirements
Section C.7. IGMP Requirements
Section C.8. Routing Requirements
Section C.9. ARP Requirements
Section C.10. UDP Requirements
Section C.11. TCP Requirements
Bibliography

xi

1127

1129

1157


Many of the designations used by manufacturers and sellers to distinguish their products are claimed
as trademarks. Where those designations appear in this book, and we were aware of a trademark
claim, the designations have been printed in initial capital letters or in all capitals.
The programs and applications presented in this book have been included for their instructional value.
They have been tested with care, but are not guaranteed for any particular purpose. The publisher does
not offer any warranties or representations, nor does it accept any liabilities with respect to the
programs or applications.
The publisher offers discounts on this book when ordered in quantity for special sales. For more
information please contact:
Pearson Education Corporate Sales Division

One Lake Street
Upper Saddle River, NJ 07458
(800) 382-3419

Visit AW on the Web: www.awl.com/cseng/
Library of Congress Cataloging-in-Publication Data
(Revised for vol. 2)
Stevens, W. Richard.
TCP/IP illustrated.
(Addison-Wesley professional computing series)
Vol. 2 by Gary R. Wright, W. Richard Stevens.
Includes bibliographical references and indexes.
Contents: v. 1. The protocols – v.2. The
implementation
1. TCP/IP (Computer network protocol) I Wright,
Gary R..,
II. Title.
III. Series.
TK5105.55.S74 1994
004.6'2
93–40000
ISBN 0-201-63346-9 (v.l)
ISBN 0-201-63354-X (v.2)
The BSD Daemon used on the cover of this book is reproduced with the permission of Marshall Kirk
McKusick.
Copyright © 1995 by Addison-Wesley. All rights reserved. No part of this publication may be
reproduced, stored in a retrieval system, or transmitted, in any form, or by any means, electronic,
mechanical, photocopying, recording, or other-wise, without the prior consent of the publisher. Printed
in the United States of America. Published simultaneously in Canada.
Text printed on recycled and acid-free paper.

ISBN 0-201-63354-X
23 2425262728 CRW 09 08 07
23rd Printing

January 2008

xii


Dedication
To my parents and my sister,
for their love and support.
—G.R.W.
To my parents,
for the gift of an education,
and the example of a work ethic.
—W.R.S.

xiii


Preface
Introduction
This book describes and presents the source code for the common reference implementation of
TCP/IP: the implementation from the Computer Systems Research Group (CSRG) at the University of
California at Berkeley. Historically this has been distributed with the 4.x BSD system (Berkeley
Software Distribution). This implementation was first released in 1982 and has survived many
significant changes, much fine tuning, and numerous ports to other Unix and non-Unix systems. This
is not a toy implementation, but the foundation for TCP/IP implementations that are run daily on
hundreds of thousands of systems worldwide. This implementation also provides router functionality,

letting us show the differences between a host implementation of TCP/IP and a router.
We describe the implementation and present the entire source code for the kernel implementation of
TCP/IP, approximately 15,000 lines of C code. The version of the Berkeley code described in this text
is the 4.4BSD-Lite release. This code was made publicly available in April 1994, and it contains
numerous networking enhancements that were added to the 4.3BSD Tahoe release in 1988, the
4.3BSD Reno release in 1990, and the 4.4BSD release in 1993. (Appendix B describes how to obtain
this source code.) The 4.4BSD release provides the latest TCP/IP features, such as multicasting and
long fat pipe support (for high-bandwidth, long-delay paths). Figure 1.1 (p. 4) provides additional
details of the various releases of the Berkeley networking code.
This book is intended for anyone wishing to understand how the TCP/IP protocols are implemented:
programmers writing network applications, system administrators responsible for maintaining
computer systems and networks utilizing TCP/IP, and any programmer interested in understanding
how a large body of nontrivial code fits into a real operating system.

xiv


Organization of the Book
The following figure shows the various protocols and subsystems that are covered. The italic numbers
by each box indicate the chapters in which that topic is described.

We take a bottom-up approach to the TCP/IP protocol suite, starting at the data-link layer, then the
network layer (IP, ICMP, IGMP, IP routing, and multicast routing), followed by the socket layer, and
finishing with the transport layer (UDP, TCP, and raw IP).

xv


Intended Audience
This book assumes a basic understanding of how the TCP/IP protocols work. Readers unfamiliar with

TCP/IP should consult the first volume in this series, [Stevens 1994], for a thorough description of the
TCP/IP protocol suite. This earlier volume is referred to throughout the current text as Volume 1. The
current text also assumes a basic understanding of operating system principles.
We describe the implementation of the protocols using a data-structures approach. That is, in addition
to the source code presentation, each chapter contains pictures and descriptions of the data structures
used and maintained by the source code. We show how these data structures fit into the other data
structures used by TCP/IP and the kernel. Heavy use is made of diagrams throughout the text—there
are over 250 diagrams.
This data-structures approach allows readers to use the book in various ways. Those interested in all
the implementation details can read the entire text from start to finish, following through all the source
code. Others might want to understand how the protocols are implemented by understanding all the
data structures and reading all the text, but not following through all the source code.
We anticipate that many readers are interested in specific portions of the book and will want to go
directly to those chapters. Therefore many forward and backward references are provided throughout
the text, along with a thorough index, to allow individual chapters to be studied by themselves. The
inside back covers contain an alphabetical cross-reference of all the functions and macros described in
the book and the starting page number of the description. Exercises are provided at the end of the
chapters; most solutions are in Appendix A to maximize the usefulness of the text as a self-study
reference.

xvi


Source Code Copyright
All of the source code presented in this book, other than Figures 1.2 and 8.27, is from the 4.4BSD-Lite
distribution. This software is publicly available through many sources (Appendix B).
All of this source code contains the following copyright notice.

/*
* Copyright (c) 1982, 1986, 1988, 1990, 1993, 1994

*
The Regents of the University of California. All
rights reserved.
*
* Redistribution and use in source and binary forms, with
or without
* modification, are permitted provided that the following
conditions
* are met:
* 1. Redistributions of source code must retain the above
copyright
*
notice, this list of conditions and the following
disclaimer.
* 2. Redistributions in binary form must reproduce the
above copyright
*
notice, this list of conditions and the following
disclaimer in the
*
documentation and/or other materials provided with
the distribution.
* 3. All advertising materials mentioning features or use
of this software
*
must display the following acknowledgement:
*
This product includes software developed by the
University of
*

California, Berkeley and its contributors.
* 4. Neither the name of the University nor the names of
its contributors
*
may be used to endorse or promote products derived
from this software
*
without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND
CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR
CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
SUBSTITUTE GOODS
xvii


* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
ARISING IN ANY WAY

* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF
* SUCH DAMAGE.
*/

xviii


Acknowledgments
We thank the technical reviewers who read the manuscript and provided important feedback on a tight
timetable: Ragnvald Blindheim, Jon Crowcroft, Sally Floyd, Glen Glater, John Gulbenkian, Don
Hering, Mukesh Kacker, Berry Kercheval, Brian W. Kernighan, Ulf Kieber, Mark Laubach, Steven
McCanne, Craig Partridge, Vern Paxson, Steve Rago, Chakravardhi Ravi, Peter Salus, Doug Schmidt,
Keith Sklower, Ian Lance Taylor, and G. N. Ananda Vardhana. A special thanks to the consulting
editor, Brian Kernighan, for his rapid, thorough, and helpful reviews throughout the course of the
project, and for his continued encouragement and support.
Our thanks (again) to the National Optical Astronomy Observatories (NOAO), especially Sidney
Wolff, Richard Wolff, and Steve Grandi, for providing access to their networks and hosts. Our thanks
also to the U.C. Berkeley CSRG: Keith Bostic and Kirk McKusick provided access to the latest
4.4BSD system, and Keith Sklower provided the modifications to the 4.4BSD-Lite software to run
under BSD/386 V1.1.
G.R.W. wishes to thank John Wait, for several years of gentle prodding; Dave Schaller, for his
encouragement; and Jim Hogue, for his support during the writing and production of this book.
W.R.S. thanks his family, once again, for enduring another "small" book project. Thank you Sally,
Bill, Ellen, and David.
The hardwork, professionalism, and support of the team at Addison-Wesley has made the authors' job
that much easier. In particular, we wish to thank John Wait for his guidance and Kim Dawley for her
creative ideas.
Camera-ready copy of the book was produced by the authors. It is only fitting that a book describing
an industrial-strength software system be produced with an industrial-strength text processing system.

Therefore one of the authors chose to use the Groff package written by James Clark, and the other
author agreed begrudgingly.
We welcome electronic mail from any readers with comments, suggestions, or bug fixes: Each author will gladly blame the other for any remaining errors.
Gary R. Wright
/>Middletown, Connecticut
November 1994

W. Richard Stevens
/>Tucson, Arizona

xix


Structure Definitions
arpcom

80

arphdr

682

bpf_d

1033

bpf_hdr

1029


bpf_if

1029

cmsghdr

482

domain

187

ether_arp

682

ether_header

102

ether_multi

342

icmp

308

ifaddr


73

ifa_msghdr

622

ifconf

117

if_msghdr

622

ifnet

67

ifqueue

71

ifreq

117

igmp

384


in_addr

160

in_aliasreq

174

in_ifaddr

161

in_multi

345

inpcb

716

iovec

481

ip

211

ipasfrag


287

ip_moptions

347

ip_mreq

356

ipoption

265

ipovly

760

ipq

286

ip_srcrt

258

ip_timestamp

262


xx


le_softc

80

lgrplctl

411

linger

542

llinfo_arp

682

mbuf

38

mrt

419

mrtctl

420


msghdr

482

osockaddr

75

pdevinit

78

protosw

188

radix_mask

578

radix_node

575

radix_node_head

574

rawcb


647

route

220

route_cb

625

rt_addrinfo

623

rtentry

579

rt_metrics

580

rt_msghdr

622

selinfo

531


sl_softc

83

sockaddr

75

sockaddr_dl

87

sockaddr_in

160

sockaddr_inarp

701

sockbuf

476

socket

438

socket_args


444

sockproto

626

sysent

443

tcpcb

804

tcp_debug

916

tcphdr

801

tcpiphdr

803

timeval

106


xxi


udphdr

759

udpiphdr

759

uio

485

vif

406

vifctl

407

walkarg

632

xxii



Function and Macro Definitions
accept

458

add_lgrp

413

add_mrt

422

add_vif

408

arpintr

687

arplookup

702

arprequest

685


arpresolve

697

arp_rtrequest

705

arptfree

696

arptimer

695

arpwhohas

683

bind

454

bpfattach

1031

bpf_attachd


1040

bpfioctl

1035

bpfopen

1034

bpfread

1044

bpf_setif

1038

bpf_tap

1041

bpfwrite

1047

catchpacket

1042


connect

466

del_lgrp

414

del_mrt

421

del_vif

410

domaininit

194

dtom

46

ether_addmulti

364

ether_delmulti


370

ether_ifattach

92

ether_input

104

ETHER_LOOKUP_MULTI

344

ETHER_MAP_IP_MULTICAST

342

ether_output

108

xxiii


fcntl

550

getpeername


556

getsock

452

getsockname

555

getsockopt

545

grplst_member

415

icmp_error

325

icmp_input

311

icmp_reflect

330


icmp_send

333

icmp_sysctl

334

ifa_ifwithaddr

182

ifa_ifwithaf

182

ifa_ifwithdstaddr

182

ifa_ifwithnet

182

ifa_ifwithroute

182

ifaof_ifpforaddr


182

if_attach

88

ifconf

118

IF_DEQUEUE

72

if_down

123

IF_DROP

72

IF_ENQUEUE

72

ifinit

93


ifioctl

116

IF_PREPEND

72

if_qflush

72

IF_QFULL

72

if_slowtimo

93

ifunit

182

if_up

123

igmp_fasttimo


389

igmp_input

392

igmp_joingroup

386

igmp_leavegroup

395

IGMP_RANDOM_DELAY

387

igmp_sendreport

390

in_addmulti

359

in_arpinput

689


xxiv


×