aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/tg3.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/tg3.c')
-rw-r--r--drivers/net/tg3.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c
index e129a6a581f6..e04cd9814e85 100644
--- a/drivers/net/tg3.c
+++ b/drivers/net/tg3.c
@@ -2156,8 +2156,14 @@ static int tg3_set_power_state(struct tg3 *tp, pci_power_t state)
2156 tw32(MAC_LED_CTRL, tp->led_ctrl); 2156 tw32(MAC_LED_CTRL, tp->led_ctrl);
2157 2157
2158 if (pci_pme_capable(tp->pdev, state) && 2158 if (pci_pme_capable(tp->pdev, state) &&
2159 (tp->tg3_flags & TG3_FLAG_WOL_ENABLE)) 2159 (tp->tg3_flags & TG3_FLAG_WOL_ENABLE)) {
2160 mac_mode |= MAC_MODE_MAGIC_PKT_ENABLE; 2160 mac_mode |= MAC_MODE_MAGIC_PKT_ENABLE;
2161 if (((tp->tg3_flags2 & TG3_FLG2_5705_PLUS) &&
2162 !(tp->tg3_flags2 & TG3_FLG2_5780_CLASS)) &&
2163 ((tp->tg3_flags & TG3_FLAG_ENABLE_ASF) ||
2164 (tp->tg3_flags3 & TG3_FLG3_ENABLE_APE)))
2165 mac_mode |= MAC_MODE_KEEP_FRAME_IN_WOL;
2166 }
2161 2167
2162 if (tp->tg3_flags3 & TG3_FLG3_ENABLE_APE) { 2168 if (tp->tg3_flags3 & TG3_FLG3_ENABLE_APE) {
2163 mac_mode |= tp->mac_mode & 2169 mac_mode |= tp->mac_mode &
@@ -5562,6 +5568,13 @@ static void tg3_ape_driver_state_change(struct tg3 *tp, int kind)
5562 event = APE_EVENT_STATUS_STATE_START; 5568 event = APE_EVENT_STATUS_STATE_START;
5563 break; 5569 break;
5564 case RESET_KIND_SHUTDOWN: 5570 case RESET_KIND_SHUTDOWN:
5571 /* With the interface we are currently using,
5572 * APE does not track driver state. Wiping
5573 * out the HOST SEGMENT SIGNATURE forces
5574 * the APE to assume OS absent status.
5575 */
5576 tg3_ape_write32(tp, TG3_APE_HOST_SEG_SIG, 0x0);
5577
5565 event = APE_EVENT_STATUS_STATE_UNLOAD; 5578 event = APE_EVENT_STATUS_STATE_UNLOAD;
5566 break; 5579 break;
5567 case RESET_KIND_SUSPEND: 5580 case RESET_KIND_SUSPEND: