2018-06-27 16:53:55 +03:00
|
|
|
.\" $NetBSD: radio.4,v 1.15 2018/06/27 13:53:55 wiz Exp $
|
2002-01-02 01:09:42 +03:00
|
|
|
.\" $RuOBSD: radio.4,v 1.4 2001/10/26 05:38:43 form Exp $
|
|
|
|
.\" $OpenBSD: radio.4,v 1.3 2001/12/05 10:58:54 mickey Exp $
|
|
|
|
.\"
|
|
|
|
.\" Copyright (c) 2001 Vladimir Popov
|
|
|
|
.\" 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.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
|
|
.\" BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 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.
|
|
|
|
.\"
|
|
|
|
.Dd October 20, 2001
|
|
|
|
.Dt RADIO 4
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm radio
|
|
|
|
.Nd device-independent radio driver layer
|
|
|
|
.Sh SYNOPSIS
|
2002-01-02 01:14:05 +03:00
|
|
|
.Cd "radio* at az?"
|
2002-01-06 05:53:54 +03:00
|
|
|
.Cd "radio* at bktr?"
|
2011-03-27 16:45:28 +04:00
|
|
|
.Cd "radio* at gtp?"
|
2002-01-02 01:14:05 +03:00
|
|
|
.Cd "radio* at rt?"
|
|
|
|
.Cd "radio* at rtii?"
|
|
|
|
.Cd "radio* at sf2r?"
|
2018-06-27 16:51:21 +03:00
|
|
|
.Cd "radio* at slurm?"
|
2002-01-02 06:24:52 +03:00
|
|
|
.Cd "radio* at udsbr?"
|
2002-01-02 01:09:42 +03:00
|
|
|
.Pp
|
2003-04-16 17:34:34 +04:00
|
|
|
.In sys/types.h
|
|
|
|
.In sys/ioctl.h
|
|
|
|
.In sys/radioio.h
|
2002-01-02 01:09:42 +03:00
|
|
|
.Sh DESCRIPTION
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
driver provides support for various FM radio cards.
|
|
|
|
It provides an uniform programming interface layer above different underlying
|
|
|
|
radio hardware drivers.
|
|
|
|
.Pp
|
|
|
|
For radio tuner controlling there is a single device file available:
|
|
|
|
.Pa /dev/radio .
|
|
|
|
.Pp
|
|
|
|
The following
|
|
|
|
.Xr ioctl 2
|
|
|
|
commands are supported:
|
|
|
|
.Pp
|
|
|
|
.Bl -tag -width indent -compact
|
|
|
|
.It Dv RIOCSSRCH (int)
|
|
|
|
This command assumes that a signal search is required and gives direction
|
2003-12-16 14:31:04 +03:00
|
|
|
of search to the driver \- 0 to search down and any non-zero value to search up.
|
2002-01-02 01:09:42 +03:00
|
|
|
.It Dv RIOCGINFO (struct radio_info)
|
2003-12-16 14:31:04 +03:00
|
|
|
.It Dv RIOCSINFO (struct radio_info)
|
2002-01-02 01:09:42 +03:00
|
|
|
Get or set the current hardware device information into the struct radio_info
|
|
|
|
structure.
|
|
|
|
.Bd -literal
|
|
|
|
struct radio_info {
|
|
|
|
int mute;
|
|
|
|
int volume;
|
|
|
|
int stereo;
|
|
|
|
int rfreq; /* reference frequency */
|
|
|
|
int lock; /* locking field strength */
|
2005-12-26 22:40:14 +03:00
|
|
|
uint32_t freq; /* in kHz */
|
|
|
|
uint32_t caps; /* card capabilities */
|
2017-07-04 00:28:48 +03:00
|
|
|
#define RADIO_CAPS_DETECT_STEREO (1<<0)
|
|
|
|
#define RADIO_CAPS_DETECT_SIGNAL (1<<1)
|
|
|
|
#define RADIO_CAPS_SET_MONO (1<<2)
|
|
|
|
#define RADIO_CAPS_HW_SEARCH (1<<3)
|
|
|
|
#define RADIO_CAPS_HW_AFC (1<<4)
|
|
|
|
#define RADIO_CAPS_REFERENCE_FREQ (1<<5)
|
|
|
|
#define RADIO_CAPS_LOCK_SENSITIVITY (1<<6)
|
|
|
|
#define RADIO_CARD_TYPE (0xFF<<16)
|
2005-12-26 22:40:14 +03:00
|
|
|
uint32_t info;
|
2017-07-04 00:28:48 +03:00
|
|
|
#define RADIO_INFO_STEREO (1<<0)
|
|
|
|
#define RADIO_INFO_SIGNAL (1<<1)
|
2002-01-02 01:09:42 +03:00
|
|
|
};
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Va mute
|
|
|
|
field is a boolean.
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Va volume
|
|
|
|
field holds the card volume information and can be at most 255.
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Va stereo
|
|
|
|
field is a boolean.
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Va rfreq
|
|
|
|
holds information about the card reference frequency (not all cards support
|
|
|
|
this feature).
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Va lock
|
|
|
|
field holds information about the card locking field strength during
|
|
|
|
an automatic search for cards that support this feature.
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Va freq
|
|
|
|
field is the frequency in kHz the card is tuned to.
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Va caps
|
|
|
|
field is read-only and describes the card capabilities.
|
|
|
|
The capabilities can have following values:
|
|
|
|
.Bl -tag -width indent -compact
|
|
|
|
.It Dv RADIO_CAPS_DETECT_STEREO
|
|
|
|
The device can determine is it tuned to a stereo signal.
|
|
|
|
.It Dv RADIO_CAPS_DETECT_SIGNAL
|
|
|
|
The device can determine is it tuned or not.
|
|
|
|
.It Dv RADIO_CAPS_SET_MONO
|
|
|
|
The device capable to forcible set its output to mono.
|
|
|
|
.It Dv RADIO_CAPS_HW_SEARCH
|
|
|
|
The device can do hardware search.
|
|
|
|
.It Dv RADIO_CAPS_HW_AFC
|
|
|
|
The device has an internal hardware automatic frequency control.
|
|
|
|
.It Dv RADIO_CAPS_REFERENCE_FREQ
|
|
|
|
The device allow to change the reference frequency of a received signal.
|
|
|
|
.It Dv RADIO_CAPS_LOCK_SENSITIVITY
|
|
|
|
The device allow to change the station lock sensitivity used during search
|
|
|
|
operation.
|
2003-12-16 14:31:04 +03:00
|
|
|
.It Dv RADIO_CARD_TYPE
|
2002-01-02 01:09:42 +03:00
|
|
|
Some cards have several different incarnations.
|
|
|
|
This allow to determine the variant of the card.
|
|
|
|
Currently not used.
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Va info
|
2003-12-16 14:31:04 +03:00
|
|
|
field is read-only and describes the current state of the card \-
|
|
|
|
tuned/not tuned, stereo signal/mono signal.
|
2002-01-02 01:09:42 +03:00
|
|
|
.Bl -tag -width indent -compact
|
|
|
|
.It Dv RADIO_INFO_STEREO
|
|
|
|
Informs whether the device receives a stereo or mono signal.
|
2003-12-16 14:31:04 +03:00
|
|
|
.It Dv RADIO_INFO_SIGNAL
|
|
|
|
Informs whether the device receives a valid signal or noise.
|
2002-01-02 01:09:42 +03:00
|
|
|
.El
|
|
|
|
.El
|
|
|
|
.Sh FILES
|
|
|
|
.Bl -tag -width /dev/radio -compact
|
|
|
|
.It Pa /dev/radio
|
|
|
|
.El
|
|
|
|
.Sh SEE ALSO
|
2002-01-02 01:10:28 +03:00
|
|
|
.Xr radioctl 1 ,
|
2002-01-02 01:09:42 +03:00
|
|
|
.Xr ioctl 2 ,
|
|
|
|
.Xr az 4 ,
|
2002-01-06 05:53:54 +03:00
|
|
|
.Xr bktr 4 ,
|
2011-03-27 16:45:28 +04:00
|
|
|
.Xr gtp 4 ,
|
2002-01-02 01:09:42 +03:00
|
|
|
.Xr rt 4 ,
|
|
|
|
.Xr rtii 4 ,
|
2002-01-02 06:24:52 +03:00
|
|
|
.Xr sf2r 4 ,
|
|
|
|
.Xr udsbr 4
|
2002-01-02 01:09:42 +03:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
device driver appeared in
|
|
|
|
.Ox 3.0
|
|
|
|
and
|
|
|
|
.Nx 1.6 .
|
2002-01-02 01:54:11 +03:00
|
|
|
.Sh AUTHORS
|
2018-06-27 16:53:55 +03:00
|
|
|
.An -nosplit
|
2002-01-02 01:54:11 +03:00
|
|
|
The
|
|
|
|
.Nm
|
2018-06-27 16:53:55 +03:00
|
|
|
driver was written by
|
|
|
|
.An Vladimir Popov
|
|
|
|
and
|
|
|
|
.An Maxim Tsyplakov
|
|
|
|
for
|
2018-06-27 16:51:21 +03:00
|
|
|
.Ox
|
|
|
|
and ported to
|
|
|
|
.Nx
|
2018-06-27 16:53:55 +03:00
|
|
|
by
|
|
|
|
.An Lennart Augustsson .
|
2002-01-02 01:54:11 +03:00
|
|
|
The man page was written by Vladimir Popov.
|