| .. | .. |
|---|
| 1 | +// SPDX-License-Identifier: GPL-2.0-or-later |
|---|
| 1 | 2 | /* |
|---|
| 2 | 3 | Copyright (C) 2004 - 2009 Ivo van Doorn <IvDoorn@gmail.com> |
|---|
| 3 | 4 | <http://rt2x00.serialmonkey.com> |
|---|
| 4 | 5 | |
|---|
| 5 | | - This program is free software; you can redistribute it and/or modify |
|---|
| 6 | | - it under the terms of the GNU General Public License as published by |
|---|
| 7 | | - the Free Software Foundation; either version 2 of the License, or |
|---|
| 8 | | - (at your option) any later version. |
|---|
| 9 | | - |
|---|
| 10 | | - This program is distributed in the hope that it will be useful, |
|---|
| 11 | | - but WITHOUT ANY WARRANTY; without even the implied warranty of |
|---|
| 12 | | - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|---|
| 13 | | - GNU General Public License for more details. |
|---|
| 14 | | - |
|---|
| 15 | | - You should have received a copy of the GNU General Public License |
|---|
| 16 | | - along with this program; if not, see <http://www.gnu.org/licenses/>. |
|---|
| 17 | 6 | */ |
|---|
| 18 | 7 | |
|---|
| 19 | 8 | /* |
|---|
| .. | .. |
|---|
| 180 | 169 | } |
|---|
| 181 | 170 | EXPORT_SYMBOL_GPL(rt2x00pci_remove); |
|---|
| 182 | 171 | |
|---|
| 183 | | -#ifdef CONFIG_PM |
|---|
| 184 | | -int rt2x00pci_suspend(struct pci_dev *pci_dev, pm_message_t state) |
|---|
| 172 | +static int __maybe_unused rt2x00pci_suspend(struct device *dev) |
|---|
| 185 | 173 | { |
|---|
| 186 | | - struct ieee80211_hw *hw = pci_get_drvdata(pci_dev); |
|---|
| 174 | + struct ieee80211_hw *hw = dev_get_drvdata(dev); |
|---|
| 187 | 175 | struct rt2x00_dev *rt2x00dev = hw->priv; |
|---|
| 188 | | - int retval; |
|---|
| 189 | 176 | |
|---|
| 190 | | - retval = rt2x00lib_suspend(rt2x00dev, state); |
|---|
| 191 | | - if (retval) |
|---|
| 192 | | - return retval; |
|---|
| 193 | | - |
|---|
| 194 | | - pci_save_state(pci_dev); |
|---|
| 195 | | - pci_disable_device(pci_dev); |
|---|
| 196 | | - return pci_set_power_state(pci_dev, pci_choose_state(pci_dev, state)); |
|---|
| 177 | + return rt2x00lib_suspend(rt2x00dev); |
|---|
| 197 | 178 | } |
|---|
| 198 | | -EXPORT_SYMBOL_GPL(rt2x00pci_suspend); |
|---|
| 199 | 179 | |
|---|
| 200 | | -int rt2x00pci_resume(struct pci_dev *pci_dev) |
|---|
| 180 | +static int __maybe_unused rt2x00pci_resume(struct device *dev) |
|---|
| 201 | 181 | { |
|---|
| 202 | | - struct ieee80211_hw *hw = pci_get_drvdata(pci_dev); |
|---|
| 182 | + struct ieee80211_hw *hw = dev_get_drvdata(dev); |
|---|
| 203 | 183 | struct rt2x00_dev *rt2x00dev = hw->priv; |
|---|
| 204 | 184 | |
|---|
| 205 | | - if (pci_set_power_state(pci_dev, PCI_D0) || |
|---|
| 206 | | - pci_enable_device(pci_dev)) { |
|---|
| 207 | | - rt2x00_err(rt2x00dev, "Failed to resume device\n"); |
|---|
| 208 | | - return -EIO; |
|---|
| 209 | | - } |
|---|
| 210 | | - |
|---|
| 211 | | - pci_restore_state(pci_dev); |
|---|
| 212 | 185 | return rt2x00lib_resume(rt2x00dev); |
|---|
| 213 | 186 | } |
|---|
| 214 | | -EXPORT_SYMBOL_GPL(rt2x00pci_resume); |
|---|
| 215 | | -#endif /* CONFIG_PM */ |
|---|
| 187 | + |
|---|
| 188 | +SIMPLE_DEV_PM_OPS(rt2x00pci_pm_ops, rt2x00pci_suspend, rt2x00pci_resume); |
|---|
| 189 | +EXPORT_SYMBOL_GPL(rt2x00pci_pm_ops); |
|---|
| 216 | 190 | |
|---|
| 217 | 191 | /* |
|---|
| 218 | 192 | * rt2x00pci module information. |
|---|