From 8c5fbb9878281056cf900c402203758fd9428992 Mon Sep 17 00:00:00 2001 From: Martin Pieuchot Date: Tue, 18 Mar 2014 09:01:12 +0000 Subject: Split route(9) into various manuals to make it easier to complete/improve its content. With inputs from jmc@ and schwarze@ --- share/man/man9/Makefile | 22 +++--- share/man/man9/route.9 | 146 ++------------------------------------- share/man/man9/rt_timer_add.9 | 85 +++++++++++++++++++++++ share/man/man9/rtable_add.9 | 81 ++++++++++++++++++++++ share/man/man9/rtlabel_id2name.9 | 65 +++++++++++++++++ 5 files changed, 249 insertions(+), 150 deletions(-) create mode 100644 share/man/man9/rt_timer_add.9 create mode 100644 share/man/man9/rtable_add.9 create mode 100644 share/man/man9/rtlabel_id2name.9 (limited to 'share/man/man9') diff --git a/share/man/man9/Makefile b/share/man/man9/Makefile index a24c99083e4..dbc139654ca 100644 --- a/share/man/man9/Makefile +++ b/share/man/man9/Makefile @@ -1,4 +1,4 @@ -# $OpenBSD: Makefile,v 1.202 2014/03/14 10:47:21 dlg Exp $ +# $OpenBSD: Makefile,v 1.203 2014/03/18 09:01:11 mpi Exp $ # $NetBSD: Makefile,v 1.4 1996/01/09 03:23:01 thorpej Exp $ # Makefile for section 9 (kernel function and variable) manual pages. @@ -25,7 +25,8 @@ MAN= altq.9 aml_evalnode.9 atomic_add_int.9 atomic_cas_uint.9 \ panic.9 pci_conf_read.9 pci_intr_map.9 pfind.9 physio.9 pmap.9 \ pool.9 powerhook_establish.9 ppsratecheck.9 printf.9 psignal.9 \ radio.9 arc4random.9 rasops.9 ratecheck.9 resettodr.9 rssadapt.9 \ - route.9 rwlock.9 sensor_attach.9 \ + route.9 rt_timer_add.9 rtable_add.9 rtlabel_id2name.9 rwlock.9 \ + sensor_attach.9 \ shutdownhook_establish.9 tsleep.9 spl.9 startuphook_establish.9 \ socreate.9 sosplice.9 style.9 syscall.9 systrace.9 sysctl_int.9 \ task_add.9 tc_init.9 time.9 timeout.9 tvtohz.9 uiomove.9 uvm.9 \ @@ -313,14 +314,15 @@ MLINKS+=route.9 rt_lookup.9 route.9 rtalloc.9 \ route.9 rtalloc_noclone.9 route.9 rtalloc1.9 \ route.9 rtfree.9 route.9 rtrequest1.9 \ route.9 rt_setgate.9 route.9 rtredirect.9 \ - route.9 rtdeletemsg.9 route.9 rtable_exists.9 \ - route.9 rtable_add.9 route.9 rtable_l2.9 \ - route.9 rtable_l2set.9 route.9 rt_gettable.9 \ - route.9 rt_timer_queue_create.9 route.9 rt_timer_add.9 \ - route.9 rt_timer_queue_change.9 route.9 rt_timer_queue_destroy.9 \ - route.9 rt_timer_count.9 route.9 rt_timer_remove_all.9 \ - route.9 rtlabel_name2id.9 route.9 rtlabel_id2name.9 \ - route.9 rtlabel_id2sa.9 route.9 rtlabel_unref.9 + route.9 rtdeletemsg.9 +MLINKS+=rtable_add.9 rtable_exists.9 rtable_add.9 rtable_l2.9 \ + rtable_add.9 rtable_l2set.9 rtable_add.9 rt_gettable.9 +MLINKS+=rt_timer_add.9 rt_timer_queue_create.9 \ + rt_timer_add.9 rt_timer_queue_change.9 \ + rt_timer_add.9 rt_timer_queue_destroy.9 \ + rt_timer_add.9 rt_timer_count.9 rt_timer_add.9 rt_timer_remove_all.9 +MLINKS+=rtlabel_id2name.9 rtlabel_name2id.9 \ + rtlabel_id2name.9 rtlabel_id2sa.9 rtlabel_id2name.9 rtlabel_unref.9 MLINKS+=rwlock.9 rw_init.9 rwlock.9 rw_enter.9 rwlock.9 rw_exit.9 \ rwlock.9 rw_enter_read.9 rwlock.9 rw_enter_write.9 \ rwlock.9 rw_exit_read.9 rwlock.9 rw_exit_write.9 \ diff --git a/share/man/man9/route.9 b/share/man/man9/route.9 index 1b01aec3770..42e879d22c3 100644 --- a/share/man/man9/route.9 +++ b/share/man/man9/route.9 @@ -1,4 +1,4 @@ -.\" $OpenBSD: route.9,v 1.8 2014/01/22 06:25:52 claudio Exp $ +.\" $OpenBSD: route.9,v 1.9 2014/03/18 09:01:11 mpi Exp $ .\" .\" Copyright (c) 2011 Bret S. Lambert .\" All rights reserved. @@ -15,7 +15,7 @@ .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. .\" -.Dd $Mdocdate: January 22 2014 $ +.Dd $Mdocdate: March 18 2014 $ .Dt ROUTE 9 .Os .Sh NAME @@ -46,38 +46,6 @@ "struct rtentry **rtp" "u_int rdomain" .Ft int .Fn rtdeletemsg "struct rtentry *rt" "u_int tableid" -.Ft int -.Fn rtable_exists "u_int id" -.Ft int -.Fn rtable_add "u_int id" -.Ft u_int -.Fn rtable_l2 "u_int id" -.Ft void -.Fn rtable_l2set "u_int id" "u_int parent" -.Ft struct radix_node_head * -.Fn rt_gettable "sa_family_t af" "u_int id" -.Ft struct rttimer_queue * -.Fn rt_timer_queue_create "u_int timeout" -.Ft int -.Fn rt_timer_add "struct rtentry *rt" \ -"void (*func)(struct rtentry *, struct rttimer *)" \ -"struct rttimer_queue *queue" "u_int rtableid" -.Ft void -.Fn rt_timer_queue_change "struct rttimer_queue *rtq" "long timeout" -.Ft void -.Fn rt_timer_queue_destroy "struct rttimer_queue *rtq" "int destroy" -.Ft unsigned long -.Fn rt_timer_count "struct rttimer_queue *rtq" -.Ft void -.Fn rt_timer_remove_all "struct rtentry *rt" -.Ft u_int16_t -.Fn rtlabel_name2id "char *name" -.Ft const char * -.Fn rtlabel_id2name "u_int16_t id" -.Ft struct sockaddr * -.Fn rtlabel_id2sa "u_int16_t labelid" "struct sockaddr_rtlabel *sa_rl" -.Ft void -.Fn rtlabel_unref "u_int16_t id" .Bd -literal struct rt_addrinfo { int rti_addrs; @@ -102,7 +70,6 @@ struct rt_addrinfo { #define RTAX_MAX 11 /* size of array to allocate */ .Ed .Sh DESCRIPTION -.Ss Route Entries Routing entries describe the routes to be taken by packets in a router. .Bl -tag -width Ds .It Fn rt_lookup "struct sockaddr *dst" "struct sockaddr *mask" "u_int tableid" @@ -178,88 +145,6 @@ freeing it if the reference count drops to 0. A macro which calls .Fn rtfree . .El -.Ss Routing Tables and Domains -Routing tables contain layer 2 and 3 forwarding information. -Each address family in use will have its own routing table. -Routing domains are a way of logically segmenting a router among multiple -networks and may contain more than one routing table. -.Bl -tag -width Ds -.It Fn rtable_exists "u_int id" -Return -.Fa 1 -if table with ID -.Fa id -exists, -.Fa 0 -otherwise. -.It Fn rtable_add "u_int id" -Add table with ID of -.Fa id -to routing domain -.Fa 0 . -.It Fn rtable_l2 "u_int id" -Get the routing domain of table with ID of -.Fa id . -.It Fn rtable_l2set "u_int id" "u_int parent" -Place table with ID of -.Fa id -under the routing domain with ID of -.Fa parent . -.El -.Ss Route Timer Queues -Route timer queues provide a method of queueing routing-related actions to be -triggered once per second. -.Bl -tag -width Ds -.It Fn rt_timer_queue_create "u_int timeout" -Create a timer queue with a timeout of -.Fa timeout -seconds. -.It Fn rt_timer_add "struct rtentry *rt" \ -"void (*func)(struct rtentry *, struct rttimer *)" \ -"struct rttimer_queue *queue" "u_int rtableid" -Schedule -.Fa func -to be called on -.Fa rt -using the timeout of -.Fa queue . -If -.Fa rt -already has a call to -.Fa func -scheduled on any timer queue, it will be replaced with the new invocation. -.It Fn rt_timer_queue_change "struct rttimer_queue *rtq" "long timeout" -Set timeout for -.Fa rtq -to -.Fa timeout -seconds. -.It Fn rt_timer_remove_all "struct rtentry *rt" -Remove all timeouts associated with -.Fa rt -from all routing timer queues. -.El -.Ss Route Labels -Route labels are arbitrary data appended to routes and can be acted upon by -.Xr pf 4 . -.Bl -tag -width Ds -.It Fn rtlabel_name2id "char *name" -Return numerical ID of the route label named -.Fa name , -creating the label if it does not already exist. -.It Fn rtlabel_id2name "u_int16_t id" -Return the string name of the route label with ID -.Fa id . -.It Fn rtlabel_id2sa "u_int16_t labelid" "struct sockaddr_rtlabel *sa_rl" -Populate -.Fa sa_rl -with the data from the route label specified by -.Fa labelid . -.It Fn rtlabel_unref "u_int16_t id" -Remove a reference to the route label with ID -.Fa id , -freeing the label if the reference count drops to 0. -.El .Sh RETURN VALUES .Fn rtrequest1 may fail with: @@ -320,31 +205,12 @@ could be found. .Fa rt is a multipath route that conflicts with existing multipath route. .El -.Pp -.Fn rtable_add -may fail with: -.Pp -.Bl -tag -width Er -compact -.It Bq Er EEXIST -A table with ID of -.Fa id -already exists. -.It Bq Er ENOMEM -Memory could not be allocated to extend the list of routing domains. -.El -.Pp -.Fn rt_timer_add -may fail with -.Er ENOBUFS -if memory could not be allocated for the timeout. -.Pp -.Fn rtlabel_name2id -returns -.Fa 0 -if it was unable to create a route label. .Sh SEE ALSO .Xr route 4 , -.Xr route 8 +.Xr route 8 , +.Xr rt_timer_add 9 , +.Xr rtable_add 9 , +.Xr rtlabel_id2name 9 .Sh BUGS The current route entry reference counting code, while not incorrect, is also likely not correct either. diff --git a/share/man/man9/rt_timer_add.9 b/share/man/man9/rt_timer_add.9 new file mode 100644 index 00000000000..6a7d134b288 --- /dev/null +++ b/share/man/man9/rt_timer_add.9 @@ -0,0 +1,85 @@ +.\" $OpenBSD: rt_timer_add.9,v 1.1 2014/03/18 09:01:11 mpi Exp $ +.\" +.\" Copyright (c) 2011 Bret S. Lambert +.\" All rights reserved. +.\" +.\" Permission to use, copy, modify, and distribute this software for any +.\" purpose with or without fee is hereby granted, provided that the above +.\" copyright notice and this permission notice appear in all copies. +.\" +.\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +.\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +.\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +.\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +.\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +.\" +.Dd $Mdocdate: March 18 2014 $ +.Dt RT_TIMER_ADD 9 +.Os +.Sh NAME +.Nm rt_timer_add , +.Nm rt_timer_count , +.Nm rt_timer_remove_all , +.Nm rt_timer_queue_create , +.Nm rt_timer_queue_change , +.Nm rt_timer_queue_destroy +.Nd route timer queues interface +.Sh SYNOPSIS +.In net/route.h +.Ft int +.Fn rt_timer_add "struct rtentry *rt" \ +"void (*func)(struct rtentry *, struct rttimer *)" \ +"struct rttimer_queue *queue" "u_int rtableid" +.Ft unsigned long +.Fn rt_timer_count "struct rttimer_queue *rtq" +.Ft void +.Fn rt_timer_remove_all "struct rtentry *rt" +.Ft struct rttimer_queue * +.Fn rt_timer_queue_create "u_int timeout" +.Ft void +.Fn rt_timer_queue_change "struct rttimer_queue *rtq" "long timeout" +.Ft void +.Fn rt_timer_queue_destroy "struct rttimer_queue *rtq" "int destroy" +.Sh DESCRIPTION +Route timer queues provide a method of queueing routing-related actions to be +triggered once per second. +.Bl -tag -width Ds +.It Fn rt_timer_add "struct rtentry *rt" \ +"void (*func)(struct rtentry *, struct rttimer *)" \ +"struct rttimer_queue *queue" "u_int rtableid" +Schedule +.Fa func +to be called on +.Fa rt +using the timeout of +.Fa queue . +If +.Fa rt +already has a call to +.Fa func +scheduled on any timer queue, it will be replaced with the new invocation. +.It Fn rt_timer_queue_create "u_int timeout" +Create a timer queue with a timeout of +.Fa timeout +seconds. +.It Fn rt_timer_queue_change "struct rttimer_queue *rtq" "long timeout" +Set timeout for +.Fa rtq +to +.Fa timeout +seconds. +.It Fn rt_timer_remove_all "struct rtentry *rt" +Remove all timeouts associated with +.Fa rt +from all routing timer queues. +.El +.Sh RETURN VALUES +.Fn rt_timer_add +may fail with +.Er ENOBUFS +if memory could not be allocated for the timeout. +.Sh SEE ALSO +.Xr route 4 , +.Xr route 9 diff --git a/share/man/man9/rtable_add.9 b/share/man/man9/rtable_add.9 new file mode 100644 index 00000000000..c38a4edcc0f --- /dev/null +++ b/share/man/man9/rtable_add.9 @@ -0,0 +1,81 @@ +.\" $OpenBSD: rtable_add.9,v 1.1 2014/03/18 09:01:11 mpi Exp $ +.\" +.\" Copyright (c) 2011 Bret S. Lambert +.\" All rights reserved. +.\" +.\" Permission to use, copy, modify, and distribute this software for any +.\" purpose with or without fee is hereby granted, provided that the above +.\" copyright notice and this permission notice appear in all copies. +.\" +.\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +.\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +.\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +.\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +.\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +.\" +.Dd $Mdocdate: March 18 2014 $ +.Dt RTABLE_ADD 9 +.Os +.Sh NAME +.Nm rtable_add , +.Nm rtable_exists , +.Nm rtable_l2 , +.Nm rtable_l2set +.Nd routing tables and routing domains interface +.Sh SYNOPSIS +.In net/route.h +.Ft int +.Fn rtable_add "u_int id" +.Ft int +.Fn rtable_exists "u_int id" +.Ft u_int +.Fn rtable_l2 "u_int id" +.Ft void +.Fn rtable_l2set "u_int id" "u_int parent" +.Ft struct radix_node_head * +.Fn rt_gettable "sa_family_t af" "u_int id" +.Sh DESCRIPTION +Routing tables contain layer 2 and 3 forwarding information. +Each address family in use will have its own routing table. +Routing domains are a way of logically segmenting a router among multiple +networks and may contain more than one routing table. +.Bl -tag -width Ds +.It Fn rtable_exists "u_int id" +Return +.Fa 1 +if table with ID +.Fa id +exists, +.Fa 0 +otherwise. +.It Fn rtable_add "u_int id" +Add table with ID of +.Fa id +to routing domain +.Fa 0 . +.It Fn rtable_l2 "u_int id" +Get the routing domain of table with ID of +.Fa id . +.It Fn rtable_l2set "u_int id" "u_int parent" +Place table with ID of +.Fa id +under the routing domain with ID of +.Fa parent . +.El +.Sh RETURN VALUES +.Fn rtable_add +may fail with: +.Pp +.Bl -tag -width Er -compact +.It Bq Er EEXIST +A table with ID of +.Fa id +already exists. +.It Bq Er ENOMEM +Memory could not be allocated to extend the list of routing domains. +.El +.Sh SEE ALSO +.Xr route 4 , +.Xr route 8 diff --git a/share/man/man9/rtlabel_id2name.9 b/share/man/man9/rtlabel_id2name.9 new file mode 100644 index 00000000000..f3046042a33 --- /dev/null +++ b/share/man/man9/rtlabel_id2name.9 @@ -0,0 +1,65 @@ +.\" $OpenBSD: rtlabel_id2name.9,v 1.1 2014/03/18 09:01:11 mpi Exp $ +.\" +.\" Copyright (c) 2011 Bret S. Lambert +.\" All rights reserved. +.\" +.\" Permission to use, copy, modify, and distribute this software for any +.\" purpose with or without fee is hereby granted, provided that the above +.\" copyright notice and this permission notice appear in all copies. +.\" +.\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +.\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +.\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +.\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +.\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +.\" +.Dd $Mdocdate: March 18 2014 $ +.Dt RTLABEL_ID2NAME 9 +.Os +.Sh NAME +.Nm rtlabel_id2name , +.Nm rtlabel_id2sa , +.Nm rtlabel_name2id , +.Nm rtlabel_unref +.Nd manipulate route labels +.Sh SYNOPSIS +.In net/route.h +.Fn rtlabel_id2name "u_int16_t id" +.Ft struct sockaddr * +.Fn rtlabel_id2sa "u_int16_t labelid" "struct sockaddr_rtlabel *sa_rl" +.Ft u_int16_t +.Fn rtlabel_name2id "char *name" +.Ft const char * +.Ft void +.Fn rtlabel_unref "u_int16_t id" +.Sh DESCRIPTION +Route labels are arbitrary data appended to routes and can be acted upon by +.Xr pf 4 . +.Bl -tag -width Ds +.It Fn rtlabel_name2id "char *name" +Return numerical ID of the route label named +.Fa name , +creating the label if it does not already exist. +.It Fn rtlabel_id2name "u_int16_t id" +Return the string name of the route label with ID +.Fa id . +.It Fn rtlabel_id2sa "u_int16_t labelid" "struct sockaddr_rtlabel *sa_rl" +Populate +.Fa sa_rl +with the data from the route label specified by +.Fa labelid . +.It Fn rtlabel_unref "u_int16_t id" +Remove a reference to the route label with ID +.Fa id , +freeing the label if the reference count drops to 0. +.El +.Sh RETURN VALUES +.Fn rtlabel_name2id +returns +.Fa 0 +if it was unable to create a route label. +.Sh SEE ALSO +.Xr route 4 , +.Xr route 9 -- cgit v1.2.3