.. | .. |
---|
| 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. |
---|