|
|
|
/*
|
|
|
|
Vendor Reset - Vendor Specific Reset
|
|
|
|
Copyright (C) 2020 Geoffrey McRae <geoff@hostfission.com>
|
|
|
|
Copyright (C) 2020 Adam Madsen <adam@ajmadsen.com>
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify it under
|
|
|
|
the terms of the GNU General Public License as published by the Free Software
|
|
|
|
Foundation; either version 2 of the License, or (at your option) any later
|
|
|
|
version.
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License along with
|
|
|
|
this program; if not, write to the Free Software Foundation, Inc., 59 Temple
|
|
|
|
Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _H_VENDOR_RESET_DEV
|
|
|
|
#define _H_VENDOR_RESET_DEV
|
|
|
|
|
|
|
|
#include <linux/pci.h>
|
|
|
|
|
|
|
|
struct vendor_reset_cfg;
|
|
|
|
|
|
|
|
struct vendor_reset_dev
|
|
|
|
{
|
|
|
|
const struct vendor_reset_cfg *cfg;
|
|
|
|
struct pci_dev *pdev;
|
|
|
|
unsigned long info;
|
|
|
|
|
|
|
|
int reset_ret;
|
|
|
|
|
|
|
|
void *vendor_private;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct vendor_reset_ver
|
|
|
|
{
|
|
|
|
unsigned int major;
|
|
|
|
unsigned int minor;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct vendor_reset_ops
|
|
|
|
{
|
|
|
|
/* version of the reset operations for logging */
|
|
|
|
const struct vendor_reset_ver version;
|
|
|
|
/* called when the kernel is probing for a working reset function */
|
|
|
|
int (*probe)(const struct vendor_reset_cfg *, struct pci_dev *);
|
|
|
|
/* any pre-reset ops to do, i.e., common code between devices */
|
|
|
|
int (*pre_reset)(struct vendor_reset_dev *);
|
|
|
|
/* the reset method for the device at the specified address */
|
|
|
|
int (*reset)(struct vendor_reset_dev *);
|
|
|
|
/* any post-reset ops to do, i.e., common code between devices */
|
|
|
|
int (*post_reset)(struct vendor_reset_dev *);
|
|
|
|
};
|
|
|
|
|
|
|
|
struct vendor_reset_cfg
|
|
|
|
{
|
|
|
|
/* the vendor ID */
|
|
|
|
unsigned int vendor;
|
|
|
|
|
|
|
|
/* the device ID or PCI_ANY_ID to match all devices for the vendor */
|
|
|
|
unsigned int device;
|
|
|
|
|
|
|
|
/* the reset operations */
|
|
|
|
const struct vendor_reset_ops * ops;
|
|
|
|
|
|
|
|
/* device type for combined ops */
|
|
|
|
unsigned long info;
|
|
|
|
|
|
|
|
/* device type string for print */
|
|
|
|
const char * info_str;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* search the device table for the specified vendor and device id and return it */
|
|
|
|
const struct vendor_reset_cfg * vendor_reset_cfg_find(unsigned int vendor,
|
|
|
|
unsigned int device);
|
|
|
|
|
|
|
|
/* perform the device reset */
|
|
|
|
long vendor_reset_dev_locked(const struct vendor_reset_cfg *cfg,
|
|
|
|
struct pci_dev *dev);
|
|
|
|
long vendor_reset_dev(const struct vendor_reset_cfg *cfg, struct pci_dev *dev);
|
|
|
|
|
|
|
|
#define vr_info(vdev, fmt, arg...) \
|
|
|
|
pci_info ((vdev)->pdev, "%s: " fmt, (vdev)->cfg->info_str, ##arg)
|
|
|
|
|
|
|
|
#define vr_warn(vdev, fmt, arg...) \
|
|
|
|
pci_warn ((vdev)->pdev, "%s: " fmt, (vdev)->cfg->info_str, ##arg)
|
|
|
|
|
|
|
|
#define vr_err(vdev, fmt, arg...) \
|
|
|
|
pci_err ((vdev)->pdev, "%s: " fmt, (vdev)->cfg->info_str, ##arg)
|
|
|
|
|
|
|
|
#define vr_debug(vdev, fmt, arg...) \
|
|
|
|
pci_debug((vdev)->pdev, "%s: " fmt, (vdev)->cfg->info_str, ##arg)
|
|
|
|
|
|
|
|
#endif
|