mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-24 04:20:03 +07:00
bcb63314e2
Drop the FSF's postal address from the source code files that typically contain mostly the license text. Of the 628 removed instances, 578 are outdated. The patch has been created with the following command without manual edits: git grep -l "675 Mass Ave\|59 Temple Place\|51 Franklin St" -- \ drivers/media/ include/media|while read i; do i=$i perl -e ' open(F,"< $ENV{i}"); $a=join("", <F>); $a =~ s/[ \t]*\*\n.*You should.*\n.*along with.*\n.*(\n.*USA.*$)?\n//m && $a =~ s/(^.*)Or, (point your browser to) /$1To obtain the license, $2\n$1/m; close(F); open(F, "> $ENV{i}"); print F $a; close(F);'; done Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
110 lines
3.4 KiB
C
110 lines
3.4 KiB
C
/*
|
|
* Framework for ISA radio drivers.
|
|
* This takes care of all the V4L2 scaffolding, allowing the ISA drivers
|
|
* to concentrate on the actual hardware operation.
|
|
*
|
|
* Copyright (C) 2012 Hans Verkuil <hans.verkuil@cisco.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* version 2 as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* General Public License for more details.
|
|
*/
|
|
|
|
#ifndef _RADIO_ISA_H_
|
|
#define _RADIO_ISA_H_
|
|
|
|
#include <linux/isa.h>
|
|
#include <linux/pnp.h>
|
|
#include <linux/videodev2.h>
|
|
#include <media/v4l2-device.h>
|
|
#include <media/v4l2-ctrls.h>
|
|
|
|
struct radio_isa_driver;
|
|
struct radio_isa_ops;
|
|
|
|
/* Core structure for radio ISA cards */
|
|
struct radio_isa_card {
|
|
const struct radio_isa_driver *drv;
|
|
struct v4l2_device v4l2_dev;
|
|
struct v4l2_ctrl_handler hdl;
|
|
struct video_device vdev;
|
|
struct mutex lock;
|
|
const struct radio_isa_ops *ops;
|
|
struct { /* mute/volume cluster */
|
|
struct v4l2_ctrl *mute;
|
|
struct v4l2_ctrl *volume;
|
|
};
|
|
/* I/O port */
|
|
int io;
|
|
|
|
/* Card is in stereo audio mode */
|
|
bool stereo;
|
|
/* Current frequency */
|
|
u32 freq;
|
|
};
|
|
|
|
struct radio_isa_ops {
|
|
/* Allocate and initialize a radio_isa_card struct */
|
|
struct radio_isa_card *(*alloc)(void);
|
|
/* Probe whether a card is present at the given port */
|
|
bool (*probe)(struct radio_isa_card *isa, int io);
|
|
/* Special card initialization can be done here, this is called after
|
|
* the standard controls are registered, but before they are setup,
|
|
* thus allowing drivers to add their own controls here. */
|
|
int (*init)(struct radio_isa_card *isa);
|
|
/* Set mute and volume. */
|
|
int (*s_mute_volume)(struct radio_isa_card *isa, bool mute, int volume);
|
|
/* Set frequency */
|
|
int (*s_frequency)(struct radio_isa_card *isa, u32 freq);
|
|
/* Set stereo/mono audio mode */
|
|
int (*s_stereo)(struct radio_isa_card *isa, bool stereo);
|
|
/* Get rxsubchans value for VIDIOC_G_TUNER */
|
|
u32 (*g_rxsubchans)(struct radio_isa_card *isa);
|
|
/* Get the signal strength for VIDIOC_G_TUNER */
|
|
u32 (*g_signal)(struct radio_isa_card *isa);
|
|
};
|
|
|
|
/* Top level structure needed to instantiate the cards */
|
|
struct radio_isa_driver {
|
|
struct isa_driver driver;
|
|
#ifdef CONFIG_PNP
|
|
struct pnp_driver pnp_driver;
|
|
#endif
|
|
const struct radio_isa_ops *ops;
|
|
/* The module_param_array with the specified I/O ports */
|
|
int *io_params;
|
|
/* The module_param_array with the radio_nr values */
|
|
int *radio_nr_params;
|
|
/* Whether we should probe for possible cards */
|
|
bool probe;
|
|
/* The list of possible I/O ports */
|
|
const int *io_ports;
|
|
/* The size of that list */
|
|
int num_of_io_ports;
|
|
/* The region size to request */
|
|
unsigned region_size;
|
|
/* The name of the card */
|
|
const char *card;
|
|
/* Card can capture stereo audio */
|
|
bool has_stereo;
|
|
/* The maximum volume for the volume control. If 0, then there
|
|
is no volume control possible. */
|
|
int max_volume;
|
|
};
|
|
|
|
int radio_isa_match(struct device *pdev, unsigned int dev);
|
|
int radio_isa_probe(struct device *pdev, unsigned int dev);
|
|
int radio_isa_remove(struct device *pdev, unsigned int dev);
|
|
#ifdef CONFIG_PNP
|
|
int radio_isa_pnp_probe(struct pnp_dev *dev,
|
|
const struct pnp_device_id *dev_id);
|
|
void radio_isa_pnp_remove(struct pnp_dev *dev);
|
|
#endif
|
|
|
|
#endif
|