1.\" Copyright (c) 1996 2.\" Mike Pritchard <mpp@FreeBSD.org>. All rights reserved. 3.\" 4.\" Redistribution and use in source and binary forms, with or without 5.\" modification, are permitted provided that the following conditions 6.\" are met: 7.\" 1. Redistributions of source code must retain the above copyright 8.\" notice, this list of conditions and the following disclaimer. 9.\" 2. Redistributions in binary form must reproduce the above copyright 10.\" notice, this list of conditions and the following disclaimer in the 11.\" documentation and/or other materials provided with the distribution. 12.\" 3. All advertising materials mentioning features or use of this software 13.\" must display the following acknowledgement: 14.\" This product includes software developed by Mike Pritchard. 15.\" 4. Neither the name of the author nor the names of its contributors 16.\" may be used to endorse or promote products derived from this software 17.\" without specific prior written permission. 18.\" 19.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 20.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 23.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29.\" SUCH DAMAGE. 30.\" 31.\" $FreeBSD$ 32.\" 33.Dd November 12, 2004 34.Dt MOUSED 8 35.Os 36.Sh NAME 37.Nm moused 38.Nd pass mouse data to the console driver 39.Sh SYNOPSIS 40.Nm 41.Op Fl DPRacdfs 42.Op Fl I Ar file 43.Op Fl F Ar rate 44.Op Fl r Ar resolution 45.Op Fl S Ar baudrate 46.Op Fl VH Op Fl U Ar distance 47.Op Fl a Ar X Ns Op , Ns Ar Y 48.Op Fl C Ar threshold 49.Op Fl m Ar N=M 50.Op Fl w Ar N 51.Op Fl z Ar target 52.Op Fl t Ar mousetype 53.Op Fl l Ar level 54.Op Fl 3 Op Fl E Ar timeout 55.Op Fl T Ar distance Ns Op , Ns Ar time Ns Op , Ns Ar after 56.Fl p Ar port 57.Pp 58.Nm 59.Op Fl Pd 60.Fl p Ar port 61.Fl i Ar info 62.Sh DESCRIPTION 63The 64.Nm 65utility and the console driver work together to support 66mouse operation in the text console and user programs. 67They virtualize the mouse and provide user programs with mouse data 68in the standard format 69(see 70.Xr sysmouse 4 ) . 71.Pp 72The mouse daemon listens to the specified port for mouse data, 73interprets and then passes it via ioctls to the console driver. 74The mouse daemon 75reports translation movement, button press/release 76events and movement of the roller or the wheel if available. 77The roller/wheel movement is reported as 78.Dq Z 79axis movement. 80.Pp 81The console driver will display the mouse pointer on the screen 82and provide cut and paste functions if the mouse pointer is enabled 83in the virtual console via 84.Xr vidcontrol 1 . 85If 86.Xr sysmouse 4 87is opened by the user program, the console driver also passes the mouse 88data to the device so that the user program will see it. 89.Pp 90If the mouse daemon receives the signal 91.Dv SIGHUP , 92it will reopen the mouse port and reinitialize itself. Useful if 93the mouse is attached/detached while the system is suspended. 94.Pp 95If the mouse daemon receives the signal 96.Dv SIGUSR1 , 97it will stop passing mouse events. Sending the signal 98.Dv SIGUSR1 99again will resume passing mouse events. Useful if your typing on a laptop is 100interrupted by accidentally touching the mouse pad. 101.Pp 102The following options are available: 103.Bl -tag -width indent 104.It Fl 3 105Emulate the third (middle) button for 2-button mice. 106It is emulated 107by pressing the left and right physical buttons simultaneously. 108.It Fl C Ar threshold 109Set double click speed as the maximum interval in msec between button clicks. 110Without this option, the default value of 500 msec will be assumed. 111This option will have effect only on the cut and paste operations 112in the text mode console. 113The user program which is reading mouse data 114via 115.Xr sysmouse 4 116will not be affected. 117.It Fl D 118Lower DTR on the serial port. 119This option is valid only if 120.Ar mousesystems 121is selected as the protocol type. 122The DTR line may need to be dropped for a 3-button mouse 123to operate in the 124.Ar mousesystems 125mode. 126.It Fl E Ar timeout 127When the third button emulation is enabled 128(see above), 129the 130.Nm 131utility waits 132.Ar timeout 133msec at most before deciding whether two buttons are being pressed 134simultaneously. 135The default timeout is 100 msec. 136.It Fl F Ar rate 137Set the report rate (reports/sec) of the device if supported. 138.It Fl H 139Enable 140.Dq Horizontal Virtual Scrolling . 141With this option set, holding the middle mouse 142button down will cause motion to be interpreted as 143horizontal scrolling. 144Use the 145.Fl U 146option to set the distance the mouse must move before the scrolling mode is 147activated. 148This option may be used with or without the 149.Fl V 150option. 151.It Fl I Ar file 152Write the process id of the 153.Nm 154utility in the specified file. 155Without this option, the process id will be stored in 156.Pa /var/run/moused.pid . 157.It Fl P 158Do not start the Plug and Play COM device enumeration procedure 159when identifying the serial mouse. 160If this option is given together with the 161.Fl i 162option, the 163.Nm 164utility will not be able to print useful information for the serial mouse. 165.It Fl R 166Lower RTS on the serial port. 167This option is valid only if 168.Ar mousesystems 169is selected as the protocol type by the 170.Fl t 171option below. 172It is often used with the 173.Fl D 174option above. 175Both RTS and DTR lines may need to be dropped for 176a 3-button mouse to operate in the 177.Ar mousesystems 178mode. 179.It Fl S Ar baudrate 180Select the baudrate for the serial port (1200 to 9600). 181Not all serial mice support this option. 182.It Fl T Ar distance Ns Op , Ns Ar time Ns Op , Ns Ar after 183Terminate drift. 184Use this option if mouse pointer slowly wanders when mouse is not moved. 185Movements up to 186.Ar distance 187(for example 4) pixels (X+Y) in 188.Ar time 189msec (default 500) are ignored, except during 190.Ar after 191msec (default 4000) since last real mouse movement. 192.It Fl V 193Enable 194.Dq Virtual Scrolling . 195With this option set, holding the middle mouse 196button down will cause motion to be interpreted as scrolling. 197Use the 198.Fl U 199option to set the distance the mouse must move before the scrolling mode is 200activated. 201.It Fl U Ar distance 202When 203.Dq Virtual Scrolling 204is enabled, the 205.Fl U 206option can be used to set the 207.Ar distance 208(in pixels) that the mouse must move before the scrolling 209mode is activated. 210The default 211.Ar distance 212is 3 pixels. 213.It Fl a Ar X Ns Op , Ns Ar Y 214Accelerate or decelerate the mouse input. 215This is a linear acceleration only. 216Values less than 1.0 slow down movement, values greater than 1.0 speed it 217up. 218Specifying only one value sets the acceleration for both axes. 219.It Fl c 220Some mice report middle button down events 221as if the left and right buttons are being pressed. 222This option handles this. 223.It Fl d 224Enable debugging messages. 225.It Fl f 226Do not become a daemon and instead run as a foreground process. 227Useful for testing and debugging. 228.It Fl i Ar info 229Print specified information and quit. 230Available pieces of 231information are: 232.Pp 233.Bl -tag -compact -width modelxxx 234.It Ar port 235Port (device file) name, i.e.\& 236.Pa /dev/cuad0 , 237.Pa /dev/mse0 238and 239.Pa /dev/psm0 . 240.It Ar if 241Interface type: serial, bus, inport or ps/2. 242.It Ar type 243Protocol type. 244It is one of the types listed under the 245.Fl t 246option below or 247.Ar sysmouse 248if the driver supports the 249.Ar sysmouse 250data format standard. 251.It Ar model 252Mouse model. 253The 254.Nm 255utility may not always be able to identify the model. 256.It Ar all 257All of the above items. 258Print port, interface, type and model in this order 259in one line. 260.El 261.Pp 262If the 263.Nm 264utility cannot determine the requested information, it prints 265.Dq Li unknown 266or 267.Dq Li generic . 268.It Fl l Ar level 269Specifies at which level 270.Nm 271should operate the mouse driver. 272Refer to 273.Sx Operation Levels 274in 275.Xr psm 4 276for more information on this. 277.It Fl m Ar N=M 278Assign the physical button 279.Ar M 280to the logical button 281.Ar N . 282You may specify as many instances of this option as you like. 283More than one physical button may be assigned to a logical button at the 284same time. 285In this case the logical button will be down, 286if either of the assigned physical buttons is held down. 287Do not put space around 288.Ql = . 289.It Fl p Ar port 290Use 291.Ar port 292to communicate with the mouse. 293.It Fl r Ar resolution 294Set the resolution of the device; in Dots Per Inch, or 295.Ar low , 296.Ar medium-low , 297.Ar medium-high 298or 299.Ar high . 300This option may not be supported by all the device. 301.It Fl s 302Select a baudrate of 9600 for the serial line. 303Not all serial mice support this option. 304.It Fl t Ar type 305Specify the protocol type of the mouse attached to the port. 306You may explicitly specify a type listed below, or use 307.Ar auto 308to let the 309.Nm 310utility automatically select an appropriate protocol for the given 311mouse. 312If you entirely omit this option in the command line, 313.Fl t Ar auto 314is assumed. 315Under normal circumstances, 316you need to use this option only if the 317.Nm 318utility is not able to detect the protocol automatically 319(see 320.Sx "Configuring Mouse Daemon" ) . 321.Pp 322Note that if a protocol type is specified with this option, the 323.Fl P 324option above is implied and Plug and Play COM device enumeration 325procedure will be disabled. 326.Pp 327Also note that if your mouse is attached to the PS/2 mouse port, you should 328always choose 329.Ar auto 330or 331.Ar ps/2 , 332regardless of the brand and model of the mouse. 333Likewise, if your 334mouse is attached to the bus mouse port, choose 335.Ar auto 336or 337.Ar busmouse . 338Serial mouse protocols will not work with these mice. 339.Pp 340For the USB mouse, the protocol must be 341.Ar auto . 342No other protocol will work with the USB mouse. 343.Pp 344Valid types for this option are 345listed below. 346.Pp 347For the serial mouse: 348.Bl -tag -compact -width mousesystemsxxx 349.It Ar microsoft 350Microsoft serial mouse protocol. 351Most 2-button serial mice use this protocol. 352.It Ar intellimouse 353Microsoft IntelliMouse protocol. 354Genius NetMouse, 355.Tn ASCII 356Mie Mouse, 357Logitech MouseMan+ and FirstMouse+ use this protocol too. 358Other mice with a roller/wheel may be compatible with this protocol. 359.It Ar mousesystems 360MouseSystems 5-byte protocol. 3613-button mice may use this protocol. 362.It Ar mmseries 363MM Series mouse protocol. 364.It Ar logitech 365Logitech mouse protocol. 366Note that this is for old Logitech models. 367.Ar mouseman 368or 369.Ar intellimouse 370should be specified for newer models. 371.It Ar mouseman 372Logitech MouseMan and TrackMan protocol. 373Some 3-button mice may be compatible 374with this protocol. 375Note that MouseMan+ and FirstMouse+ use 376.Ar intellimouse 377protocol rather than this one. 378.It Ar glidepoint 379ALPS GlidePoint protocol. 380.It Ar thinkingmouse 381Kensington ThinkingMouse protocol. 382.It Ar mmhitab 383Hitachi tablet protocol. 384.It Ar x10mouseremote 385X10 MouseRemote. 386.It Ar kidspad 387Genius Kidspad and Easypad protocol. 388.It Ar versapad 389Interlink VersaPad protocol. 390.El 391.It Ar gtco_digipad 392GTCO Digipad protocol. 393.Pp 394For the bus and InPort mouse: 395.Bl -tag -compact -width mousesystemsxxx 396.It Ar busmouse 397This is the only protocol type available for 398the bus and InPort mouse and should be specified for any bus mice 399and InPort mice, regardless of the brand. 400.El 401.Pp 402For the PS/2 mouse: 403.Bl -tag -compact -width mousesystemsxxx 404.It Ar ps/2 405This is the only protocol type available for the PS/2 mouse 406and should be specified for any PS/2 mice, regardless of the brand. 407.El 408.Pp 409For the USB mouse, 410.Ar auto 411is the only protocol type available for the USB mouse 412and should be specified for any USB mice, regardless of the brand. 413.It Fl w Ar N 414Make the physical button 415.Ar N 416act as the wheel mode button. 417While this button is pressed, X and Y axis movement is reported to be zero 418and the Y axis movement is mapped to Z axis. 419You may further map the Z axis movement to virtual buttons by the 420.Fl z 421option below. 422.It Fl z Ar target 423Map Z axis (roller/wheel) movement to another axis or to virtual buttons. 424Valid 425.Ar target 426maybe: 427.Bl -tag -compact -width x__ 428.It Ar x 429.It Ar y 430X or Y axis movement will be reported when the Z axis movement is detected. 431.It Ar N 432Report down events for the virtual buttons 433.Ar N 434and 435.Ar N+1 436respectively when negative and positive Z axis movement 437is detected. 438There do not need to be physical buttons 439.Ar N 440and 441.Ar N+1 . 442Note that mapping to logical buttons is carried out after mapping 443from the Z axis movement to the virtual buttons is done. 444.It Ar N1 N2 445Report down events for the virtual buttons 446.Ar N1 447and 448.Ar N2 449respectively when negative and positive Z axis movement 450is detected. 451.It Ar N1 N2 N3 N4 452This is useful for the mouse with two wheels of which 453the second wheel is used to generate horizontal scroll action, 454and for the mouse which has a knob or a stick which can detect 455the horizontal force applied by the user. 456.Pp 457The motion of the second wheel will be mapped to the buttons 458.Ar N3 , 459for the negative direction, and 460.Ar N4 , 461for the positive direction. 462If the buttons 463.Ar N3 464and 465.Ar N4 466actually exist in this mouse, their actions will not be detected. 467.Pp 468Note that horizontal movement or second roller/wheel movement may not 469always be detected, 470because there appears to be no accepted standard as to how it is encoded. 471.Pp 472Note also that some mice think left is the negative horizontal direction; 473others may think otherwise. 474Moreover, there are some mice whose two wheels are both mounted vertically, 475and the direction of the second vertical wheel does not match the 476first one. 477.El 478.El 479.Ss Configuring Mouse Daemon 480The first thing you need to know is the interface type 481of the mouse you are going to use. 482It can be determined by looking at the connector of the mouse. 483The serial mouse has a D-Sub female 9- or 25-pin connector. 484The bus and InPort mice have either a D-Sub male 9-pin connector 485or a round DIN 9-pin connector. 486The PS/2 mouse is equipped with a small, round DIN 6-pin connector. 487Some mice come with adapters with which the connector can 488be converted to another. 489If you are to use such an adapter, 490remember the connector at the very end of the mouse/adapter pair is 491what matters. 492The USB mouse has a flat rectangular connector. 493.Pp 494The next thing to decide is a port to use for the given interface. 495For the bus, InPort and PS/2 mice, there is little choice: 496the bus and InPort mice always use 497.Pa /dev/mse0 , 498and the PS/2 mouse is always at 499.Pa /dev/psm0 . 500There may be more than one serial port to which the serial 501mouse can be attached. 502Many people often assign the first, built-in 503serial port 504.Pa /dev/cuad0 505to the mouse. 506You can attach multiple USB mice to your system or to your USB hub. 507They are accessible as 508.Pa /dev/ums0 , /dev/ums1 , 509and so on. 510.Pp 511You may want to create a symbolic link 512.Pa /dev/mouse 513pointing to the real port to which the mouse is connected, so that you 514can easily distinguish which is your 515.Dq mouse 516port later. 517.Pp 518The next step is to guess the appropriate protocol type for the mouse. 519The 520.Nm 521utility may be able to automatically determine the protocol type. 522Run the 523.Nm 524utility with the 525.Fl i 526option and see what it says. 527If the command can identify 528the protocol type, no further investigation is necessary on your part. 529You may start the daemon without explicitly specifying a protocol type 530(see 531.Sx EXAMPLES ) . 532.Pp 533The command may print 534.Ar sysmouse 535if the mouse driver supports this protocol type. 536.Pp 537Note that the 538.Dv type 539and 540.Dv model 541printed by the 542.Fl i 543option do not necessarily match the product name of the pointing device 544in question, but they may give the name of the device with which it is 545compatible. 546.Pp 547If the 548.Fl i 549option yields nothing, you need to specify a protocol type to the 550.Nm 551utility by the 552.Fl t 553option. 554You have to make a guess and try. 555There is rule of thumb: 556.Pp 557.Bl -enum -compact -width 1.X 558.It 559The bus and InPort mice always use 560.Ar busmouse 561protocol regardless of the brand of the mouse. 562.It 563The 564.Ar ps/2 565protocol should always be specified for the PS/2 mouse 566regardless of the brand of the mouse. 567.It 568You must specify the 569.Ar auto 570protocol for the USB mouse. 571.It 572Most 2-button serial mice support the 573.Ar microsoft 574protocol. 575.It 5763-button serial mice may work with the 577.Ar mousesystems 578protocol. 579If it does not, it may work with the 580.Ar microsoft 581protocol although 582the third (middle) button will not function. 5833-button serial mice may also work with the 584.Ar mouseman 585protocol under which the third button may function as expected. 586.It 5873-button serial mice may have a small switch to choose between 588.Dq MS 589and 590.Dq PC , 591or 592.Dq 2 593and 594.Dq 3 . 595.Dq MS 596or 597.Dq 2 598usually mean the 599.Ar microsoft 600protocol. 601.Dq PC 602or 603.Dq 3 604will choose the 605.Ar mousesystems 606protocol. 607.It 608If the mouse has a roller or a wheel, it may be compatible with the 609.Ar intellimouse 610protocol. 611.El 612.Pp 613To test if the selected protocol type is correct for the given mouse, 614enable the mouse pointer in the current virtual console, 615.Pp 616.Dl vidcontrol -m on 617.Pp 618start the mouse daemon in the foreground mode, 619.Pp 620.Dl moused -f -p Ar _selected_port_ -t Ar _selected_protocol_ 621.Pp 622and see if the mouse pointer travels correctly 623according to the mouse movement. 624Then try cut & paste features by 625clicking the left, right and middle buttons. 626Type ^C to stop 627the command. 628.Ss Multiple Mice 629As many instances of the mouse daemon as the number of mice attached to 630the system may be run simultaneously; one 631instance for each mouse. 632This is useful if the user wants to use the built-in PS/2 pointing device 633of a laptop computer while on the road, but wants to use a serial 634mouse when s/he attaches the system to the docking station in the office. 635Run two mouse daemons and tell the application program 636(such as the 637.Tn "X\ Window System" ) 638to use 639.Xr sysmouse 4 , 640then the application program will always see mouse data from either mouse. 641When the serial mouse is not attached, the corresponding mouse daemon 642will not detect any movement or button state change and the application 643program will only see mouse data coming from the daemon for the 644PS/2 mouse. 645In contrast when both mice are attached and both of them 646are moved at the same time in this configuration, 647the mouse pointer will travel across the screen just as if movement of 648the mice is combined all together. 649.Sh FILES 650.Bl -tag -width /dev/consolectl -compact 651.It Pa /dev/consolectl 652device to control the console 653.It Pa /dev/mse%d 654bus and InPort mouse driver 655.It Pa /dev/psm%d 656PS/2 mouse driver 657.It Pa /dev/sysmouse 658virtualized mouse driver 659.It Pa /dev/ttyv%d 660virtual consoles 661.It Pa /dev/ums%d 662USB mouse driver 663.It Pa /var/run/moused.pid 664process id of the currently running 665.Nm 666utility 667.It Pa /var/run/MouseRemote 668UNIX-domain stream socket for X10 MouseRemote events 669.El 670.Sh EXAMPLES 671.Dl moused -p /dev/cuad0 -i type 672.Pp 673Let the 674.Nm 675utility determine the protocol type of the mouse at the serial port 676.Pa /dev/cuad0 . 677If successful, the command will print the type, otherwise it will say 678.Dq Li unknown . 679.Pp 680.Dl moused -p /dev/cuad0 681.Dl vidcontrol -m on 682.Pp 683If the 684.Nm 685utility is able to identify the protocol type of the mouse at the specified 686port automatically, you can start the daemon without the 687.Fl t 688option and enable the mouse pointer in the text console as above. 689.Pp 690.Dl moused -p /dev/mouse -t microsoft 691.Dl vidcontrol -m on 692.Pp 693Start the mouse daemon on the serial port 694.Pa /dev/mouse . 695The protocol type 696.Ar microsoft 697is explicitly specified by the 698.Fl t 699option. 700.Pp 701.Dl moused -p /dev/mouse -m 1=3 -m 3=1 702.Pp 703Assign the physical button 3 (right button) to the logical button 1 704(logical left) and the physical button 1 (left) to the logical 705button 3 (logical right). 706This will effectively swap the left and right buttons. 707.Pp 708.Dl moused -p /dev/mouse -t intellimouse -z 4 709.Pp 710Report negative Z axis movement (i.e., mouse wheel) as the button 4 pressed 711and positive Z axis movement (i.e., mouse wheel) as the button 5 pressed. 712.Pp 713If you add 714.Pp 715.Dl ALL ALL = NOPASSWD: /usr/bin/killall -USR1 moused 716.Pp 717to your 718.Pa /usr/local/etc/sudoers 719file, and bind 720.Pp 721.Dl killall -USR1 moused 722.Pp 723to a key in your window manager, you can suspend mouse events on your laptop if 724you keep brushing over the mouse pad while typing. 725.Sh CAVEATS 726The 727.Nm 728utility does not currently work with the alternative console driver 729.Xr pcvt 4 . 730.Pp 731Many pad devices behave as if the first (left) button were pressed if 732the user 733.Dq taps 734the surface of the pad. 735In contrast, some ALPS GlidePoint and Interlink VersaPad models 736treat the tapping action 737as fourth button events. 738Use the option 739.Dq Fl m Li 1=4 740for these models 741to obtain the same effect as the other pad devices. 742.Pp 743Cut and paste functions in the virtual console assume that there 744are three buttons on the mouse. 745The logical button 1 (logical left) selects a region of text in the 746console and copies it to the cut buffer. 747The logical button 3 (logical right) extends the selected region. 748The logical button 2 (logical middle) pastes the selected text 749at the text cursor position. 750If the mouse has only two buttons, the middle, `paste' button 751is not available. 752To obtain the paste function, use the 753.Fl 3 754option to emulate the middle button, or use the 755.Fl m 756option to assign the physical right button to the logical middle button: 757.Dq Fl m Li 2=3 . 758.Sh SEE ALSO 759.Xr kill 1 , 760.Xr vidcontrol 1 , 761.Xr keyboard 4 , 762.Xr mse 4 , 763.Xr pcvt 4 , 764.Xr psm 4 , 765.Xr screen 4 , 766.Xr sysmouse 4 , 767.Xr ums 4 768.Sh STANDARDS 769The 770.Nm 771utility partially supports 772.Dq Plug and Play External COM Device Specification 773in order to support PnP serial mice. 774However, due to various degrees of conformance to the specification by 775existing serial mice, it does not strictly follow the version 1.0 of the 776standard. 777Even with this less strict approach, 778it may not always determine an appropriate protocol type 779for the given serial mouse. 780.Sh HISTORY 781The 782.Nm 783utility first appeared in 784.Fx 2.2 . 785.Sh AUTHORS 786.An -nosplit 787The 788.Nm 789utility was written by 790.An Michael Smith Aq msmith@FreeBSD.org . 791This manual page was written by 792.An Mike Pritchard Aq mpp@FreeBSD.org . 793The command and manual page have since been updated by 794.An Kazutaka Yokota Aq yokota@FreeBSD.org . 795