diff options
Diffstat (limited to 'drivers/net/wireless/ipw2100.c')
-rw-r--r-- | drivers/net/wireless/ipw2100.c | 256 |
1 files changed, 147 insertions, 109 deletions
diff --git a/drivers/net/wireless/ipw2100.c b/drivers/net/wireless/ipw2100.c index 189ad7b2cec9..a47fce4beadf 100644 --- a/drivers/net/wireless/ipw2100.c +++ b/drivers/net/wireless/ipw2100.c | |||
@@ -106,7 +106,7 @@ that protects the following: | |||
106 | 106 | ||
107 | tx_pend_list : Holds used Tx buffers waiting to go into the TBD ring | 107 | tx_pend_list : Holds used Tx buffers waiting to go into the TBD ring |
108 | TAIL modified ipw2100_tx() | 108 | TAIL modified ipw2100_tx() |
109 | HEAD modified by X__ipw2100_tx_send_data() | 109 | HEAD modified by ipw2100_tx_send_data() |
110 | 110 | ||
111 | msg_free_list : Holds pre-allocated Msg (Command) buffers | 111 | msg_free_list : Holds pre-allocated Msg (Command) buffers |
112 | TAIL modified in __ipw2100_tx_process() | 112 | TAIL modified in __ipw2100_tx_process() |
@@ -114,7 +114,7 @@ that protects the following: | |||
114 | 114 | ||
115 | msg_pend_list : Holds used Msg buffers waiting to go into the TBD ring | 115 | msg_pend_list : Holds used Msg buffers waiting to go into the TBD ring |
116 | TAIL modified in ipw2100_hw_send_command() | 116 | TAIL modified in ipw2100_hw_send_command() |
117 | HEAD modified in X__ipw2100_tx_send_commands() | 117 | HEAD modified in ipw2100_tx_send_commands() |
118 | 118 | ||
119 | The flow of data on the TX side is as follows: | 119 | The flow of data on the TX side is as follows: |
120 | 120 | ||
@@ -207,7 +207,20 @@ MODULE_PARM_DESC(channel, "channel"); | |||
207 | MODULE_PARM_DESC(associate, "auto associate when scanning (default on)"); | 207 | MODULE_PARM_DESC(associate, "auto associate when scanning (default on)"); |
208 | MODULE_PARM_DESC(disable, "manually disable the radio (default 0 [radio on])"); | 208 | MODULE_PARM_DESC(disable, "manually disable the radio (default 0 [radio on])"); |
209 | 209 | ||
210 | u32 ipw2100_debug_level = IPW_DL_NONE; | 210 | static u32 ipw2100_debug_level = IPW_DL_NONE; |
211 | |||
212 | #ifdef CONFIG_IPW_DEBUG | ||
213 | #define IPW_DEBUG(level, message...) \ | ||
214 | do { \ | ||
215 | if (ipw2100_debug_level & (level)) { \ | ||
216 | printk(KERN_DEBUG "ipw2100: %c %s ", \ | ||
217 | in_interrupt() ? 'I' : 'U', __FUNCTION__); \ | ||
218 | printk(message); \ | ||
219 | } \ | ||
220 | } while (0) | ||
221 | #else | ||
222 | #define IPW_DEBUG(level, message...) do {} while (0) | ||
223 | #endif /* CONFIG_IPW_DEBUG */ | ||
211 | 224 | ||
212 | #ifdef CONFIG_IPW_DEBUG | 225 | #ifdef CONFIG_IPW_DEBUG |
213 | static const char *command_types[] = { | 226 | static const char *command_types[] = { |
@@ -287,14 +300,30 @@ static const char *command_types[] = { | |||
287 | 300 | ||
288 | 301 | ||
289 | /* Pre-decl until we get the code solid and then we can clean it up */ | 302 | /* Pre-decl until we get the code solid and then we can clean it up */ |
290 | static void X__ipw2100_tx_send_commands(struct ipw2100_priv *priv); | 303 | static void ipw2100_tx_send_commands(struct ipw2100_priv *priv); |
291 | static void X__ipw2100_tx_send_data(struct ipw2100_priv *priv); | 304 | static void ipw2100_tx_send_data(struct ipw2100_priv *priv); |
292 | static int ipw2100_adapter_setup(struct ipw2100_priv *priv); | 305 | static int ipw2100_adapter_setup(struct ipw2100_priv *priv); |
293 | 306 | ||
294 | static void ipw2100_queues_initialize(struct ipw2100_priv *priv); | 307 | static void ipw2100_queues_initialize(struct ipw2100_priv *priv); |
295 | static void ipw2100_queues_free(struct ipw2100_priv *priv); | 308 | static void ipw2100_queues_free(struct ipw2100_priv *priv); |
296 | static int ipw2100_queues_allocate(struct ipw2100_priv *priv); | 309 | static int ipw2100_queues_allocate(struct ipw2100_priv *priv); |
297 | 310 | ||
311 | static int ipw2100_fw_download(struct ipw2100_priv *priv, | ||
312 | struct ipw2100_fw *fw); | ||
313 | static int ipw2100_get_firmware(struct ipw2100_priv *priv, | ||
314 | struct ipw2100_fw *fw); | ||
315 | static int ipw2100_get_fwversion(struct ipw2100_priv *priv, char *buf, | ||
316 | size_t max); | ||
317 | static int ipw2100_get_ucodeversion(struct ipw2100_priv *priv, char *buf, | ||
318 | size_t max); | ||
319 | static void ipw2100_release_firmware(struct ipw2100_priv *priv, | ||
320 | struct ipw2100_fw *fw); | ||
321 | static int ipw2100_ucode_download(struct ipw2100_priv *priv, | ||
322 | struct ipw2100_fw *fw); | ||
323 | static void ipw2100_wx_event_work(struct ipw2100_priv *priv); | ||
324 | static struct iw_statistics *ipw2100_wx_wireless_stats(struct net_device * dev); | ||
325 | static struct iw_handler_def ipw2100_wx_handler_def; | ||
326 | |||
298 | 327 | ||
299 | static inline void read_register(struct net_device *dev, u32 reg, u32 *val) | 328 | static inline void read_register(struct net_device *dev, u32 reg, u32 *val) |
300 | { | 329 | { |
@@ -473,8 +502,8 @@ static inline int ipw2100_hw_is_adapter_in_system(struct net_device *dev) | |||
473 | == IPW_DATA_DOA_DEBUG_VALUE)); | 502 | == IPW_DATA_DOA_DEBUG_VALUE)); |
474 | } | 503 | } |
475 | 504 | ||
476 | int ipw2100_get_ordinal(struct ipw2100_priv *priv, u32 ord, | 505 | static int ipw2100_get_ordinal(struct ipw2100_priv *priv, u32 ord, |
477 | void *val, u32 *len) | 506 | void *val, u32 *len) |
478 | { | 507 | { |
479 | struct ipw2100_ordinals *ordinals = &priv->ordinals; | 508 | struct ipw2100_ordinals *ordinals = &priv->ordinals; |
480 | u32 addr; | 509 | u32 addr; |
@@ -484,7 +513,7 @@ int ipw2100_get_ordinal(struct ipw2100_priv *priv, u32 ord, | |||
484 | u32 total_length; | 513 | u32 total_length; |
485 | 514 | ||
486 | if (ordinals->table1_addr == 0) { | 515 | if (ordinals->table1_addr == 0) { |
487 | IPW_DEBUG_WARNING(DRV_NAME ": attempt to use fw ordinals " | 516 | printk(KERN_WARNING DRV_NAME ": attempt to use fw ordinals " |
488 | "before they have been loaded.\n"); | 517 | "before they have been loaded.\n"); |
489 | return -EINVAL; | 518 | return -EINVAL; |
490 | } | 519 | } |
@@ -493,7 +522,7 @@ int ipw2100_get_ordinal(struct ipw2100_priv *priv, u32 ord, | |||
493 | if (*len < IPW_ORD_TAB_1_ENTRY_SIZE) { | 522 | if (*len < IPW_ORD_TAB_1_ENTRY_SIZE) { |
494 | *len = IPW_ORD_TAB_1_ENTRY_SIZE; | 523 | *len = IPW_ORD_TAB_1_ENTRY_SIZE; |
495 | 524 | ||
496 | IPW_DEBUG_WARNING(DRV_NAME | 525 | printk(KERN_WARNING DRV_NAME |
497 | ": ordinal buffer length too small, need %zd\n", | 526 | ": ordinal buffer length too small, need %zd\n", |
498 | IPW_ORD_TAB_1_ENTRY_SIZE); | 527 | IPW_ORD_TAB_1_ENTRY_SIZE); |
499 | 528 | ||
@@ -546,7 +575,7 @@ int ipw2100_get_ordinal(struct ipw2100_priv *priv, u32 ord, | |||
546 | return 0; | 575 | return 0; |
547 | } | 576 | } |
548 | 577 | ||
549 | IPW_DEBUG_WARNING(DRV_NAME ": ordinal %d neither in table 1 nor " | 578 | printk(KERN_WARNING DRV_NAME ": ordinal %d neither in table 1 nor " |
550 | "in table 2\n", ord); | 579 | "in table 2\n", ord); |
551 | 580 | ||
552 | return -EINVAL; | 581 | return -EINVAL; |
@@ -736,8 +765,8 @@ static int ipw2100_hw_send_command(struct ipw2100_priv *priv, | |||
736 | list_add_tail(element, &priv->msg_pend_list); | 765 | list_add_tail(element, &priv->msg_pend_list); |
737 | INC_STAT(&priv->msg_pend_stat); | 766 | INC_STAT(&priv->msg_pend_stat); |
738 | 767 | ||
739 | X__ipw2100_tx_send_commands(priv); | 768 | ipw2100_tx_send_commands(priv); |
740 | X__ipw2100_tx_send_data(priv); | 769 | ipw2100_tx_send_data(priv); |
741 | 770 | ||
742 | spin_unlock_irqrestore(&priv->low_lock, flags); | 771 | spin_unlock_irqrestore(&priv->low_lock, flags); |
743 | 772 | ||
@@ -761,7 +790,7 @@ static int ipw2100_hw_send_command(struct ipw2100_priv *priv, | |||
761 | } | 790 | } |
762 | 791 | ||
763 | if (priv->fatal_error) { | 792 | if (priv->fatal_error) { |
764 | IPW_DEBUG_WARNING("%s: firmware fatal error\n", | 793 | printk(KERN_WARNING DRV_NAME ": %s: firmware fatal error\n", |
765 | priv->net_dev->name); | 794 | priv->net_dev->name); |
766 | return -EIO; | 795 | return -EIO; |
767 | } | 796 | } |
@@ -999,7 +1028,7 @@ static int ipw2100_download_firmware(struct ipw2100_priv *priv) | |||
999 | /* load microcode */ | 1028 | /* load microcode */ |
1000 | err = ipw2100_ucode_download(priv, &ipw2100_firmware); | 1029 | err = ipw2100_ucode_download(priv, &ipw2100_firmware); |
1001 | if (err) { | 1030 | if (err) { |
1002 | IPW_DEBUG_ERROR("%s: Error loading microcode: %d\n", | 1031 | printk(KERN_ERR DRV_NAME ": %s: Error loading microcode: %d\n", |
1003 | priv->net_dev->name, err); | 1032 | priv->net_dev->name, err); |
1004 | goto fail; | 1033 | goto fail; |
1005 | } | 1034 | } |
@@ -1012,7 +1041,7 @@ static int ipw2100_download_firmware(struct ipw2100_priv *priv) | |||
1012 | /* s/w reset and clock stabilization (again!!!) */ | 1041 | /* s/w reset and clock stabilization (again!!!) */ |
1013 | err = sw_reset_and_clock(priv); | 1042 | err = sw_reset_and_clock(priv); |
1014 | if (err) { | 1043 | if (err) { |
1015 | IPW_DEBUG_ERROR("%s: sw_reset_and_clock failed: %d\n", | 1044 | printk(KERN_ERR DRV_NAME ": %s: sw_reset_and_clock failed: %d\n", |
1016 | priv->net_dev->name, err); | 1045 | priv->net_dev->name, err); |
1017 | goto fail; | 1046 | goto fail; |
1018 | } | 1047 | } |
@@ -1206,7 +1235,7 @@ static int ipw2100_start_adapter(struct ipw2100_priv *priv) | |||
1206 | * fw & dino ucode | 1235 | * fw & dino ucode |
1207 | */ | 1236 | */ |
1208 | if (ipw2100_download_firmware(priv)) { | 1237 | if (ipw2100_download_firmware(priv)) { |
1209 | IPW_DEBUG_ERROR("%s: Failed to power on the adapter.\n", | 1238 | printk(KERN_ERR DRV_NAME ": %s: Failed to power on the adapter.\n", |
1210 | priv->net_dev->name); | 1239 | priv->net_dev->name); |
1211 | return -EIO; | 1240 | return -EIO; |
1212 | } | 1241 | } |
@@ -1266,7 +1295,7 @@ static int ipw2100_start_adapter(struct ipw2100_priv *priv) | |||
1266 | i ? "SUCCESS" : "FAILED"); | 1295 | i ? "SUCCESS" : "FAILED"); |
1267 | 1296 | ||
1268 | if (!i) { | 1297 | if (!i) { |
1269 | IPW_DEBUG_WARNING("%s: Firmware did not initialize.\n", | 1298 | printk(KERN_WARNING DRV_NAME ": %s: Firmware did not initialize.\n", |
1270 | priv->net_dev->name); | 1299 | priv->net_dev->name); |
1271 | return -EIO; | 1300 | return -EIO; |
1272 | } | 1301 | } |
@@ -1462,7 +1491,7 @@ static int ipw2100_hw_stop_adapter(struct ipw2100_priv *priv) | |||
1462 | 1491 | ||
1463 | err = ipw2100_hw_phy_off(priv); | 1492 | err = ipw2100_hw_phy_off(priv); |
1464 | if (err) | 1493 | if (err) |
1465 | IPW_DEBUG_WARNING("Error disabling radio %d\n", err); | 1494 | printk(KERN_WARNING DRV_NAME ": Error disabling radio %d\n", err); |
1466 | 1495 | ||
1467 | /* | 1496 | /* |
1468 | * If in D0-standby mode going directly to D3 may cause a | 1497 | * If in D0-standby mode going directly to D3 may cause a |
@@ -1488,7 +1517,7 @@ static int ipw2100_hw_stop_adapter(struct ipw2100_priv *priv) | |||
1488 | 1517 | ||
1489 | err = ipw2100_hw_send_command(priv, &cmd); | 1518 | err = ipw2100_hw_send_command(priv, &cmd); |
1490 | if (err) | 1519 | if (err) |
1491 | IPW_DEBUG_WARNING( | 1520 | printk(KERN_WARNING DRV_NAME ": " |
1492 | "%s: Power down command failed: Error %d\n", | 1521 | "%s: Power down command failed: Error %d\n", |
1493 | priv->net_dev->name, err); | 1522 | priv->net_dev->name, err); |
1494 | else { | 1523 | else { |
@@ -1529,7 +1558,7 @@ static int ipw2100_hw_stop_adapter(struct ipw2100_priv *priv) | |||
1529 | } | 1558 | } |
1530 | 1559 | ||
1531 | if (i == 0) | 1560 | if (i == 0) |
1532 | IPW_DEBUG_WARNING(DRV_NAME | 1561 | printk(KERN_WARNING DRV_NAME |
1533 | ": %s: Could now power down adapter.\n", | 1562 | ": %s: Could now power down adapter.\n", |
1534 | priv->net_dev->name); | 1563 | priv->net_dev->name); |
1535 | 1564 | ||
@@ -1569,13 +1598,13 @@ static int ipw2100_disable_adapter(struct ipw2100_priv *priv) | |||
1569 | 1598 | ||
1570 | err = ipw2100_hw_send_command(priv, &cmd); | 1599 | err = ipw2100_hw_send_command(priv, &cmd); |
1571 | if (err) { | 1600 | if (err) { |
1572 | IPW_DEBUG_WARNING("exit - failed to send CARD_DISABLE command\n"); | 1601 | printk(KERN_WARNING DRV_NAME ": exit - failed to send CARD_DISABLE command\n"); |
1573 | goto fail_up; | 1602 | goto fail_up; |
1574 | } | 1603 | } |
1575 | 1604 | ||
1576 | err = ipw2100_wait_for_card_state(priv, IPW_HW_STATE_DISABLED); | 1605 | err = ipw2100_wait_for_card_state(priv, IPW_HW_STATE_DISABLED); |
1577 | if (err) { | 1606 | if (err) { |
1578 | IPW_DEBUG_WARNING("exit - card failed to change to DISABLED\n"); | 1607 | printk(KERN_WARNING DRV_NAME ": exit - card failed to change to DISABLED\n"); |
1579 | goto fail_up; | 1608 | goto fail_up; |
1580 | } | 1609 | } |
1581 | 1610 | ||
@@ -1586,7 +1615,7 @@ fail_up: | |||
1586 | return err; | 1615 | return err; |
1587 | } | 1616 | } |
1588 | 1617 | ||
1589 | int ipw2100_set_scan_options(struct ipw2100_priv *priv) | 1618 | static int ipw2100_set_scan_options(struct ipw2100_priv *priv) |
1590 | { | 1619 | { |
1591 | struct host_command cmd = { | 1620 | struct host_command cmd = { |
1592 | .host_command = SET_SCAN_OPTIONS, | 1621 | .host_command = SET_SCAN_OPTIONS, |
@@ -1618,7 +1647,7 @@ int ipw2100_set_scan_options(struct ipw2100_priv *priv) | |||
1618 | return err; | 1647 | return err; |
1619 | } | 1648 | } |
1620 | 1649 | ||
1621 | int ipw2100_start_scan(struct ipw2100_priv *priv) | 1650 | static int ipw2100_start_scan(struct ipw2100_priv *priv) |
1622 | { | 1651 | { |
1623 | struct host_command cmd = { | 1652 | struct host_command cmd = { |
1624 | .host_command = BROADCAST_SCAN, | 1653 | .host_command = BROADCAST_SCAN, |
@@ -1685,7 +1714,7 @@ static int ipw2100_up(struct ipw2100_priv *priv, int deferred) | |||
1685 | (priv->status & STATUS_RESET_PENDING)) { | 1714 | (priv->status & STATUS_RESET_PENDING)) { |
1686 | /* Power cycle the card ... */ | 1715 | /* Power cycle the card ... */ |
1687 | if (ipw2100_power_cycle_adapter(priv)) { | 1716 | if (ipw2100_power_cycle_adapter(priv)) { |
1688 | IPW_DEBUG_WARNING("%s: Could not cycle adapter.\n", | 1717 | printk(KERN_WARNING DRV_NAME ": %s: Could not cycle adapter.\n", |
1689 | priv->net_dev->name); | 1718 | priv->net_dev->name); |
1690 | rc = 1; | 1719 | rc = 1; |
1691 | goto exit; | 1720 | goto exit; |
@@ -1695,7 +1724,7 @@ static int ipw2100_up(struct ipw2100_priv *priv, int deferred) | |||
1695 | 1724 | ||
1696 | /* Load the firmware, start the clocks, etc. */ | 1725 | /* Load the firmware, start the clocks, etc. */ |
1697 | if (ipw2100_start_adapter(priv)) { | 1726 | if (ipw2100_start_adapter(priv)) { |
1698 | IPW_DEBUG_ERROR("%s: Failed to start the firmware.\n", | 1727 | printk(KERN_ERR DRV_NAME ": %s: Failed to start the firmware.\n", |
1699 | priv->net_dev->name); | 1728 | priv->net_dev->name); |
1700 | rc = 1; | 1729 | rc = 1; |
1701 | goto exit; | 1730 | goto exit; |
@@ -1705,7 +1734,7 @@ static int ipw2100_up(struct ipw2100_priv *priv, int deferred) | |||
1705 | 1734 | ||
1706 | /* Determine capabilities of this particular HW configuration */ | 1735 | /* Determine capabilities of this particular HW configuration */ |
1707 | if (ipw2100_get_hw_features(priv)) { | 1736 | if (ipw2100_get_hw_features(priv)) { |
1708 | IPW_DEBUG_ERROR("%s: Failed to determine HW features.\n", | 1737 | printk(KERN_ERR DRV_NAME ": %s: Failed to determine HW features.\n", |
1709 | priv->net_dev->name); | 1738 | priv->net_dev->name); |
1710 | rc = 1; | 1739 | rc = 1; |
1711 | goto exit; | 1740 | goto exit; |
@@ -1713,7 +1742,7 @@ static int ipw2100_up(struct ipw2100_priv *priv, int deferred) | |||
1713 | 1742 | ||
1714 | lock = LOCK_NONE; | 1743 | lock = LOCK_NONE; |
1715 | if (ipw2100_set_ordinal(priv, IPW_ORD_PERS_DB_LOCK, &lock, &ord_len)) { | 1744 | if (ipw2100_set_ordinal(priv, IPW_ORD_PERS_DB_LOCK, &lock, &ord_len)) { |
1716 | IPW_DEBUG_ERROR("%s: Failed to clear ordinal lock.\n", | 1745 | printk(KERN_ERR DRV_NAME ": %s: Failed to clear ordinal lock.\n", |
1717 | priv->net_dev->name); | 1746 | priv->net_dev->name); |
1718 | rc = 1; | 1747 | rc = 1; |
1719 | goto exit; | 1748 | goto exit; |
@@ -1739,7 +1768,7 @@ static int ipw2100_up(struct ipw2100_priv *priv, int deferred) | |||
1739 | /* Send all of the commands that must be sent prior to | 1768 | /* Send all of the commands that must be sent prior to |
1740 | * HOST_COMPLETE */ | 1769 | * HOST_COMPLETE */ |
1741 | if (ipw2100_adapter_setup(priv)) { | 1770 | if (ipw2100_adapter_setup(priv)) { |
1742 | IPW_DEBUG_ERROR("%s: Failed to start the card.\n", | 1771 | printk(KERN_ERR DRV_NAME ": %s: Failed to start the card.\n", |
1743 | priv->net_dev->name); | 1772 | priv->net_dev->name); |
1744 | rc = 1; | 1773 | rc = 1; |
1745 | goto exit; | 1774 | goto exit; |
@@ -1748,7 +1777,7 @@ static int ipw2100_up(struct ipw2100_priv *priv, int deferred) | |||
1748 | if (!deferred) { | 1777 | if (!deferred) { |
1749 | /* Enable the adapter - sends HOST_COMPLETE */ | 1778 | /* Enable the adapter - sends HOST_COMPLETE */ |
1750 | if (ipw2100_enable_adapter(priv)) { | 1779 | if (ipw2100_enable_adapter(priv)) { |
1751 | IPW_DEBUG_ERROR( | 1780 | printk(KERN_ERR DRV_NAME ": " |
1752 | "%s: failed in call to enable adapter.\n", | 1781 | "%s: failed in call to enable adapter.\n", |
1753 | priv->net_dev->name); | 1782 | priv->net_dev->name); |
1754 | ipw2100_hw_stop_adapter(priv); | 1783 | ipw2100_hw_stop_adapter(priv); |
@@ -1806,7 +1835,7 @@ static void ipw2100_down(struct ipw2100_priv *priv) | |||
1806 | spin_unlock_irqrestore(&priv->low_lock, flags); | 1835 | spin_unlock_irqrestore(&priv->low_lock, flags); |
1807 | 1836 | ||
1808 | if (ipw2100_hw_stop_adapter(priv)) | 1837 | if (ipw2100_hw_stop_adapter(priv)) |
1809 | IPW_DEBUG_ERROR("%s: Error stopping adapter.\n", | 1838 | printk(KERN_ERR DRV_NAME ": %s: Error stopping adapter.\n", |
1810 | priv->net_dev->name); | 1839 | priv->net_dev->name); |
1811 | 1840 | ||
1812 | /* Do not disable the interrupt until _after_ we disable | 1841 | /* Do not disable the interrupt until _after_ we disable |
@@ -1833,7 +1862,7 @@ static void ipw2100_down(struct ipw2100_priv *priv) | |||
1833 | netif_stop_queue(priv->net_dev); | 1862 | netif_stop_queue(priv->net_dev); |
1834 | } | 1863 | } |
1835 | 1864 | ||
1836 | void ipw2100_reset_adapter(struct ipw2100_priv *priv) | 1865 | static void ipw2100_reset_adapter(struct ipw2100_priv *priv) |
1837 | { | 1866 | { |
1838 | unsigned long flags; | 1867 | unsigned long flags; |
1839 | union iwreq_data wrqu = { | 1868 | union iwreq_data wrqu = { |
@@ -1963,8 +1992,8 @@ static void isr_indicate_associated(struct ipw2100_priv *priv, u32 status) | |||
1963 | } | 1992 | } |
1964 | 1993 | ||
1965 | 1994 | ||
1966 | int ipw2100_set_essid(struct ipw2100_priv *priv, char *essid, | 1995 | static int ipw2100_set_essid(struct ipw2100_priv *priv, char *essid, |
1967 | int length, int batch_mode) | 1996 | int length, int batch_mode) |
1968 | { | 1997 | { |
1969 | int ssid_len = min(length, IW_ESSID_MAX_SIZE); | 1998 | int ssid_len = min(length, IW_ESSID_MAX_SIZE); |
1970 | struct host_command cmd = { | 1999 | struct host_command cmd = { |
@@ -2095,7 +2124,7 @@ static void isr_indicate_scanning(struct ipw2100_priv *priv, u32 status) | |||
2095 | priv->status |= STATUS_SCANNING; | 2124 | priv->status |= STATUS_SCANNING; |
2096 | } | 2125 | } |
2097 | 2126 | ||
2098 | const struct ipw2100_status_indicator status_handlers[] = { | 2127 | static const struct ipw2100_status_indicator status_handlers[] = { |
2099 | IPW2100_HANDLER(IPW_STATE_INITIALIZED, 0), | 2128 | IPW2100_HANDLER(IPW_STATE_INITIALIZED, 0), |
2100 | IPW2100_HANDLER(IPW_STATE_COUNTRY_FOUND, 0), | 2129 | IPW2100_HANDLER(IPW_STATE_COUNTRY_FOUND, 0), |
2101 | IPW2100_HANDLER(IPW_STATE_ASSOCIATED, isr_indicate_associated), | 2130 | IPW2100_HANDLER(IPW_STATE_ASSOCIATED, isr_indicate_associated), |
@@ -2163,7 +2192,7 @@ static void isr_rx_complete_command( | |||
2163 | } | 2192 | } |
2164 | 2193 | ||
2165 | #ifdef CONFIG_IPW_DEBUG | 2194 | #ifdef CONFIG_IPW_DEBUG |
2166 | const char *frame_types[] = { | 2195 | static const char *frame_types[] = { |
2167 | "COMMAND_STATUS_VAL", | 2196 | "COMMAND_STATUS_VAL", |
2168 | "STATUS_CHANGE_VAL", | 2197 | "STATUS_CHANGE_VAL", |
2169 | "P80211_DATA_VAL", | 2198 | "P80211_DATA_VAL", |
@@ -2283,7 +2312,7 @@ static inline u32 ipw2100_match_buf(struct ipw2100_priv *priv, u8 *in_buf, | |||
2283 | * | 2312 | * |
2284 | */ | 2313 | */ |
2285 | #ifdef CONFIG_IPW2100_RX_DEBUG | 2314 | #ifdef CONFIG_IPW2100_RX_DEBUG |
2286 | u8 packet_data[IPW_RX_NIC_BUFFER_LENGTH]; | 2315 | static u8 packet_data[IPW_RX_NIC_BUFFER_LENGTH]; |
2287 | #endif | 2316 | #endif |
2288 | 2317 | ||
2289 | static inline void ipw2100_corruption_detected(struct ipw2100_priv *priv, | 2318 | static inline void ipw2100_corruption_detected(struct ipw2100_priv *priv, |
@@ -2413,7 +2442,7 @@ static inline void isr_rx(struct ipw2100_priv *priv, int i, | |||
2413 | 2442 | ||
2414 | /* We need to allocate a new SKB and attach it to the RDB. */ | 2443 | /* We need to allocate a new SKB and attach it to the RDB. */ |
2415 | if (unlikely(ipw2100_alloc_skb(priv, packet))) { | 2444 | if (unlikely(ipw2100_alloc_skb(priv, packet))) { |
2416 | IPW_DEBUG_WARNING( | 2445 | printk(KERN_WARNING DRV_NAME ": " |
2417 | "%s: Unable to allocate SKB onto RBD ring - disabling " | 2446 | "%s: Unable to allocate SKB onto RBD ring - disabling " |
2418 | "adapter.\n", priv->net_dev->name); | 2447 | "adapter.\n", priv->net_dev->name); |
2419 | /* TODO: schedule adapter shutdown */ | 2448 | /* TODO: schedule adapter shutdown */ |
@@ -2675,7 +2704,7 @@ static inline int __ipw2100_tx_process(struct ipw2100_priv *priv) | |||
2675 | break; | 2704 | break; |
2676 | 2705 | ||
2677 | default: | 2706 | default: |
2678 | IPW_DEBUG_WARNING("%s: Bad fw_pend_list entry!\n", | 2707 | printk(KERN_WARNING DRV_NAME ": %s: Bad fw_pend_list entry!\n", |
2679 | priv->net_dev->name); | 2708 | priv->net_dev->name); |
2680 | return 0; | 2709 | return 0; |
2681 | } | 2710 | } |
@@ -2689,7 +2718,7 @@ static inline int __ipw2100_tx_process(struct ipw2100_priv *priv) | |||
2689 | read_register(priv->net_dev, IPW_MEM_HOST_SHARED_TX_QUEUE_WRITE_INDEX, | 2718 | read_register(priv->net_dev, IPW_MEM_HOST_SHARED_TX_QUEUE_WRITE_INDEX, |
2690 | &w); | 2719 | &w); |
2691 | if (w != txq->next) | 2720 | if (w != txq->next) |
2692 | IPW_DEBUG_WARNING("%s: write index mismatch\n", | 2721 | printk(KERN_WARNING DRV_NAME ": %s: write index mismatch\n", |
2693 | priv->net_dev->name); | 2722 | priv->net_dev->name); |
2694 | 2723 | ||
2695 | /* | 2724 | /* |
@@ -2750,7 +2779,7 @@ static inline int __ipw2100_tx_process(struct ipw2100_priv *priv) | |||
2750 | switch (packet->type) { | 2779 | switch (packet->type) { |
2751 | case DATA: | 2780 | case DATA: |
2752 | if (txq->drv[txq->oldest].status.info.fields.txType != 0) | 2781 | if (txq->drv[txq->oldest].status.info.fields.txType != 0) |
2753 | IPW_DEBUG_WARNING("%s: Queue mismatch. " | 2782 | printk(KERN_WARNING DRV_NAME ": %s: Queue mismatch. " |
2754 | "Expecting DATA TBD but pulled " | 2783 | "Expecting DATA TBD but pulled " |
2755 | "something else: ids %d=%d.\n", | 2784 | "something else: ids %d=%d.\n", |
2756 | priv->net_dev->name, txq->oldest, packet->index); | 2785 | priv->net_dev->name, txq->oldest, packet->index); |
@@ -2797,7 +2826,7 @@ static inline int __ipw2100_tx_process(struct ipw2100_priv *priv) | |||
2797 | 2826 | ||
2798 | case COMMAND: | 2827 | case COMMAND: |
2799 | if (txq->drv[txq->oldest].status.info.fields.txType != 1) | 2828 | if (txq->drv[txq->oldest].status.info.fields.txType != 1) |
2800 | IPW_DEBUG_WARNING("%s: Queue mismatch. " | 2829 | printk(KERN_WARNING DRV_NAME ": %s: Queue mismatch. " |
2801 | "Expecting COMMAND TBD but pulled " | 2830 | "Expecting COMMAND TBD but pulled " |
2802 | "something else: ids %d=%d.\n", | 2831 | "something else: ids %d=%d.\n", |
2803 | priv->net_dev->name, txq->oldest, packet->index); | 2832 | priv->net_dev->name, txq->oldest, packet->index); |
@@ -2837,14 +2866,14 @@ static inline void __ipw2100_tx_complete(struct ipw2100_priv *priv) | |||
2837 | while (__ipw2100_tx_process(priv) && i < 200) i++; | 2866 | while (__ipw2100_tx_process(priv) && i < 200) i++; |
2838 | 2867 | ||
2839 | if (i == 200) { | 2868 | if (i == 200) { |
2840 | IPW_DEBUG_WARNING( | 2869 | printk(KERN_WARNING DRV_NAME ": " |
2841 | "%s: Driver is running slow (%d iters).\n", | 2870 | "%s: Driver is running slow (%d iters).\n", |
2842 | priv->net_dev->name, i); | 2871 | priv->net_dev->name, i); |
2843 | } | 2872 | } |
2844 | } | 2873 | } |
2845 | 2874 | ||
2846 | 2875 | ||
2847 | static void X__ipw2100_tx_send_commands(struct ipw2100_priv *priv) | 2876 | static void ipw2100_tx_send_commands(struct ipw2100_priv *priv) |
2848 | { | 2877 | { |
2849 | struct list_head *element; | 2878 | struct list_head *element; |
2850 | struct ipw2100_tx_packet *packet; | 2879 | struct ipw2100_tx_packet *packet; |
@@ -2912,10 +2941,10 @@ static void X__ipw2100_tx_send_commands(struct ipw2100_priv *priv) | |||
2912 | 2941 | ||
2913 | 2942 | ||
2914 | /* | 2943 | /* |
2915 | * X__ipw2100_tx_send_data | 2944 | * ipw2100_tx_send_data |
2916 | * | 2945 | * |
2917 | */ | 2946 | */ |
2918 | static void X__ipw2100_tx_send_data(struct ipw2100_priv *priv) | 2947 | static void ipw2100_tx_send_data(struct ipw2100_priv *priv) |
2919 | { | 2948 | { |
2920 | struct list_head *element; | 2949 | struct list_head *element; |
2921 | struct ipw2100_tx_packet *packet; | 2950 | struct ipw2100_tx_packet *packet; |
@@ -3081,7 +3110,7 @@ static void ipw2100_irq_tasklet(struct ipw2100_priv *priv) | |||
3081 | (unsigned long)inta & IPW_INTERRUPT_MASK); | 3110 | (unsigned long)inta & IPW_INTERRUPT_MASK); |
3082 | 3111 | ||
3083 | if (inta & IPW2100_INTA_FATAL_ERROR) { | 3112 | if (inta & IPW2100_INTA_FATAL_ERROR) { |
3084 | IPW_DEBUG_WARNING(DRV_NAME | 3113 | printk(KERN_WARNING DRV_NAME |
3085 | ": Fatal interrupt. Scheduling firmware restart.\n"); | 3114 | ": Fatal interrupt. Scheduling firmware restart.\n"); |
3086 | priv->inta_other++; | 3115 | priv->inta_other++; |
3087 | write_register( | 3116 | write_register( |
@@ -3101,7 +3130,7 @@ static void ipw2100_irq_tasklet(struct ipw2100_priv *priv) | |||
3101 | } | 3130 | } |
3102 | 3131 | ||
3103 | if (inta & IPW2100_INTA_PARITY_ERROR) { | 3132 | if (inta & IPW2100_INTA_PARITY_ERROR) { |
3104 | IPW_DEBUG_ERROR("***** PARITY ERROR INTERRUPT !!!! \n"); | 3133 | printk(KERN_ERR DRV_NAME ": ***** PARITY ERROR INTERRUPT !!!! \n"); |
3105 | priv->inta_other++; | 3134 | priv->inta_other++; |
3106 | write_register( | 3135 | write_register( |
3107 | dev, IPW_REG_INTA, | 3136 | dev, IPW_REG_INTA, |
@@ -3130,8 +3159,8 @@ static void ipw2100_irq_tasklet(struct ipw2100_priv *priv) | |||
3130 | IPW2100_INTA_TX_TRANSFER); | 3159 | IPW2100_INTA_TX_TRANSFER); |
3131 | 3160 | ||
3132 | __ipw2100_tx_complete(priv); | 3161 | __ipw2100_tx_complete(priv); |
3133 | X__ipw2100_tx_send_commands(priv); | 3162 | ipw2100_tx_send_commands(priv); |
3134 | X__ipw2100_tx_send_data(priv); | 3163 | ipw2100_tx_send_data(priv); |
3135 | } | 3164 | } |
3136 | 3165 | ||
3137 | if (inta & IPW2100_INTA_TX_COMPLETE) { | 3166 | if (inta & IPW2100_INTA_TX_COMPLETE) { |
@@ -3219,7 +3248,7 @@ static irqreturn_t ipw2100_interrupt(int irq, void *data, | |||
3219 | 3248 | ||
3220 | if (inta == 0xFFFFFFFF) { | 3249 | if (inta == 0xFFFFFFFF) { |
3221 | /* Hardware disappeared */ | 3250 | /* Hardware disappeared */ |
3222 | IPW_DEBUG_WARNING("IRQ INTA == 0xFFFFFFFF\n"); | 3251 | printk(KERN_WARNING DRV_NAME ": IRQ INTA == 0xFFFFFFFF\n"); |
3223 | goto none; | 3252 | goto none; |
3224 | } | 3253 | } |
3225 | 3254 | ||
@@ -3282,7 +3311,7 @@ static int ipw2100_tx(struct ieee80211_txb *txb, struct net_device *dev) | |||
3282 | list_add_tail(element, &priv->tx_pend_list); | 3311 | list_add_tail(element, &priv->tx_pend_list); |
3283 | INC_STAT(&priv->tx_pend_stat); | 3312 | INC_STAT(&priv->tx_pend_stat); |
3284 | 3313 | ||
3285 | X__ipw2100_tx_send_data(priv); | 3314 | ipw2100_tx_send_data(priv); |
3286 | 3315 | ||
3287 | spin_unlock_irqrestore(&priv->low_lock, flags); | 3316 | spin_unlock_irqrestore(&priv->low_lock, flags); |
3288 | return 0; | 3317 | return 0; |
@@ -3304,7 +3333,7 @@ static int ipw2100_msg_allocate(struct ipw2100_priv *priv) | |||
3304 | IPW_COMMAND_POOL_SIZE * sizeof(struct ipw2100_tx_packet), | 3333 | IPW_COMMAND_POOL_SIZE * sizeof(struct ipw2100_tx_packet), |
3305 | GFP_KERNEL); | 3334 | GFP_KERNEL); |
3306 | if (!priv->msg_buffers) { | 3335 | if (!priv->msg_buffers) { |
3307 | IPW_DEBUG_ERROR("%s: PCI alloc failed for msg " | 3336 | printk(KERN_ERR DRV_NAME ": %s: PCI alloc failed for msg " |
3308 | "buffers.\n", priv->net_dev->name); | 3337 | "buffers.\n", priv->net_dev->name); |
3309 | return -ENOMEM; | 3338 | return -ENOMEM; |
3310 | } | 3339 | } |
@@ -3315,7 +3344,7 @@ static int ipw2100_msg_allocate(struct ipw2100_priv *priv) | |||
3315 | sizeof(struct ipw2100_cmd_header), | 3344 | sizeof(struct ipw2100_cmd_header), |
3316 | &p); | 3345 | &p); |
3317 | if (!v) { | 3346 | if (!v) { |
3318 | IPW_DEBUG_ERROR( | 3347 | printk(KERN_ERR DRV_NAME ": " |
3319 | "%s: PCI alloc failed for msg " | 3348 | "%s: PCI alloc failed for msg " |
3320 | "buffers.\n", | 3349 | "buffers.\n", |
3321 | priv->net_dev->name); | 3350 | priv->net_dev->name); |
@@ -3427,7 +3456,7 @@ static DEVICE_ATTR(capability, S_IRUGO, show_capability, NULL); | |||
3427 | 3456 | ||
3428 | 3457 | ||
3429 | #define IPW2100_REG(x) { IPW_ ##x, #x } | 3458 | #define IPW2100_REG(x) { IPW_ ##x, #x } |
3430 | const struct { | 3459 | static const struct { |
3431 | u32 addr; | 3460 | u32 addr; |
3432 | const char *name; | 3461 | const char *name; |
3433 | } hw_data[] = { | 3462 | } hw_data[] = { |
@@ -3438,7 +3467,7 @@ const struct { | |||
3438 | IPW2100_REG(REG_RESET_REG), | 3467 | IPW2100_REG(REG_RESET_REG), |
3439 | }; | 3468 | }; |
3440 | #define IPW2100_NIC(x, s) { x, #x, s } | 3469 | #define IPW2100_NIC(x, s) { x, #x, s } |
3441 | const struct { | 3470 | static const struct { |
3442 | u32 addr; | 3471 | u32 addr; |
3443 | const char *name; | 3472 | const char *name; |
3444 | size_t size; | 3473 | size_t size; |
@@ -3448,7 +3477,7 @@ const struct { | |||
3448 | IPW2100_NIC(0x210000, 1), | 3477 | IPW2100_NIC(0x210000, 1), |
3449 | }; | 3478 | }; |
3450 | #define IPW2100_ORD(x, d) { IPW_ORD_ ##x, #x, d } | 3479 | #define IPW2100_ORD(x, d) { IPW_ORD_ ##x, #x, d } |
3451 | const struct { | 3480 | static const struct { |
3452 | u8 index; | 3481 | u8 index; |
3453 | const char *name; | 3482 | const char *name; |
3454 | const char *desc; | 3483 | const char *desc; |
@@ -3813,7 +3842,7 @@ static ssize_t show_stats(struct device *d, struct device_attribute *attr, | |||
3813 | static DEVICE_ATTR(stats, S_IRUGO, show_stats, NULL); | 3842 | static DEVICE_ATTR(stats, S_IRUGO, show_stats, NULL); |
3814 | 3843 | ||
3815 | 3844 | ||
3816 | int ipw2100_switch_mode(struct ipw2100_priv *priv, u32 mode) | 3845 | static int ipw2100_switch_mode(struct ipw2100_priv *priv, u32 mode) |
3817 | { | 3846 | { |
3818 | int err; | 3847 | int err; |
3819 | 3848 | ||
@@ -3822,7 +3851,7 @@ int ipw2100_switch_mode(struct ipw2100_priv *priv, u32 mode) | |||
3822 | 3851 | ||
3823 | err = ipw2100_disable_adapter(priv); | 3852 | err = ipw2100_disable_adapter(priv); |
3824 | if (err) { | 3853 | if (err) { |
3825 | IPW_DEBUG_ERROR("%s: Could not disable adapter %d\n", | 3854 | printk(KERN_ERR DRV_NAME ": %s: Could not disable adapter %d\n", |
3826 | priv->net_dev->name, err); | 3855 | priv->net_dev->name, err); |
3827 | return err; | 3856 | return err; |
3828 | } | 3857 | } |
@@ -4268,7 +4297,7 @@ static int ipw2100_tx_allocate(struct ipw2100_priv *priv) | |||
4268 | TX_PENDED_QUEUE_LENGTH * sizeof(struct ipw2100_tx_packet), | 4297 | TX_PENDED_QUEUE_LENGTH * sizeof(struct ipw2100_tx_packet), |
4269 | GFP_ATOMIC); | 4298 | GFP_ATOMIC); |
4270 | if (!priv->tx_buffers) { | 4299 | if (!priv->tx_buffers) { |
4271 | IPW_DEBUG_ERROR("%s: alloc failed form tx buffers.\n", | 4300 | printk(KERN_ERR DRV_NAME ": %s: alloc failed form tx buffers.\n", |
4272 | priv->net_dev->name); | 4301 | priv->net_dev->name); |
4273 | bd_queue_free(priv, &priv->tx_queue); | 4302 | bd_queue_free(priv, &priv->tx_queue); |
4274 | return -ENOMEM; | 4303 | return -ENOMEM; |
@@ -4278,7 +4307,7 @@ static int ipw2100_tx_allocate(struct ipw2100_priv *priv) | |||
4278 | v = pci_alloc_consistent( | 4307 | v = pci_alloc_consistent( |
4279 | priv->pci_dev, sizeof(struct ipw2100_data_header), &p); | 4308 | priv->pci_dev, sizeof(struct ipw2100_data_header), &p); |
4280 | if (!v) { | 4309 | if (!v) { |
4281 | IPW_DEBUG_ERROR("%s: PCI alloc failed for tx " | 4310 | printk(KERN_ERR DRV_NAME ": %s: PCI alloc failed for tx " |
4282 | "buffers.\n", priv->net_dev->name); | 4311 | "buffers.\n", priv->net_dev->name); |
4283 | err = -ENOMEM; | 4312 | err = -ENOMEM; |
4284 | break; | 4313 | break; |
@@ -4537,7 +4566,7 @@ static int ipw2100_read_mac_address(struct ipw2100_priv *priv) | |||
4537 | * | 4566 | * |
4538 | ********************************************************************/ | 4567 | ********************************************************************/ |
4539 | 4568 | ||
4540 | int ipw2100_set_mac_address(struct ipw2100_priv *priv, int batch_mode) | 4569 | static int ipw2100_set_mac_address(struct ipw2100_priv *priv, int batch_mode) |
4541 | { | 4570 | { |
4542 | struct host_command cmd = { | 4571 | struct host_command cmd = { |
4543 | .host_command = ADAPTER_ADDRESS, | 4572 | .host_command = ADAPTER_ADDRESS, |
@@ -4564,7 +4593,7 @@ int ipw2100_set_mac_address(struct ipw2100_priv *priv, int batch_mode) | |||
4564 | return err; | 4593 | return err; |
4565 | } | 4594 | } |
4566 | 4595 | ||
4567 | int ipw2100_set_port_type(struct ipw2100_priv *priv, u32 port_type, | 4596 | static int ipw2100_set_port_type(struct ipw2100_priv *priv, u32 port_type, |
4568 | int batch_mode) | 4597 | int batch_mode) |
4569 | { | 4598 | { |
4570 | struct host_command cmd = { | 4599 | struct host_command cmd = { |
@@ -4589,7 +4618,7 @@ int ipw2100_set_port_type(struct ipw2100_priv *priv, u32 port_type, | |||
4589 | if (!batch_mode) { | 4618 | if (!batch_mode) { |
4590 | err = ipw2100_disable_adapter(priv); | 4619 | err = ipw2100_disable_adapter(priv); |
4591 | if (err) { | 4620 | if (err) { |
4592 | IPW_DEBUG_ERROR("%s: Could not disable adapter %d\n", | 4621 | printk(KERN_ERR DRV_NAME ": %s: Could not disable adapter %d\n", |
4593 | priv->net_dev->name, err); | 4622 | priv->net_dev->name, err); |
4594 | return err; | 4623 | return err; |
4595 | } | 4624 | } |
@@ -4605,7 +4634,8 @@ int ipw2100_set_port_type(struct ipw2100_priv *priv, u32 port_type, | |||
4605 | } | 4634 | } |
4606 | 4635 | ||
4607 | 4636 | ||
4608 | int ipw2100_set_channel(struct ipw2100_priv *priv, u32 channel, int batch_mode) | 4637 | static int ipw2100_set_channel(struct ipw2100_priv *priv, u32 channel, |
4638 | int batch_mode) | ||
4609 | { | 4639 | { |
4610 | struct host_command cmd = { | 4640 | struct host_command cmd = { |
4611 | .host_command = CHANNEL, | 4641 | .host_command = CHANNEL, |
@@ -4655,7 +4685,7 @@ int ipw2100_set_channel(struct ipw2100_priv *priv, u32 channel, int batch_mode) | |||
4655 | return 0; | 4685 | return 0; |
4656 | } | 4686 | } |
4657 | 4687 | ||
4658 | int ipw2100_system_config(struct ipw2100_priv *priv, int batch_mode) | 4688 | static int ipw2100_system_config(struct ipw2100_priv *priv, int batch_mode) |
4659 | { | 4689 | { |
4660 | struct host_command cmd = { | 4690 | struct host_command cmd = { |
4661 | .host_command = SYSTEM_CONFIG, | 4691 | .host_command = SYSTEM_CONFIG, |
@@ -4717,7 +4747,8 @@ int ipw2100_system_config(struct ipw2100_priv *priv, int batch_mode) | |||
4717 | return 0; | 4747 | return 0; |
4718 | } | 4748 | } |
4719 | 4749 | ||
4720 | int ipw2100_set_tx_rates(struct ipw2100_priv *priv, u32 rate, int batch_mode) | 4750 | static int ipw2100_set_tx_rates(struct ipw2100_priv *priv, u32 rate, |
4751 | int batch_mode) | ||
4721 | { | 4752 | { |
4722 | struct host_command cmd = { | 4753 | struct host_command cmd = { |
4723 | .host_command = BASIC_TX_RATES, | 4754 | .host_command = BASIC_TX_RATES, |
@@ -4756,8 +4787,8 @@ int ipw2100_set_tx_rates(struct ipw2100_priv *priv, u32 rate, int batch_mode) | |||
4756 | return 0; | 4787 | return 0; |
4757 | } | 4788 | } |
4758 | 4789 | ||
4759 | int ipw2100_set_power_mode(struct ipw2100_priv *priv, | 4790 | static int ipw2100_set_power_mode(struct ipw2100_priv *priv, |
4760 | int power_level) | 4791 | int power_level) |
4761 | { | 4792 | { |
4762 | struct host_command cmd = { | 4793 | struct host_command cmd = { |
4763 | .host_command = POWER_MODE, | 4794 | .host_command = POWER_MODE, |
@@ -4794,7 +4825,7 @@ int ipw2100_set_power_mode(struct ipw2100_priv *priv, | |||
4794 | } | 4825 | } |
4795 | 4826 | ||
4796 | 4827 | ||
4797 | int ipw2100_set_rts_threshold(struct ipw2100_priv *priv, u32 threshold) | 4828 | static int ipw2100_set_rts_threshold(struct ipw2100_priv *priv, u32 threshold) |
4798 | { | 4829 | { |
4799 | struct host_command cmd = { | 4830 | struct host_command cmd = { |
4800 | .host_command = RTS_THRESHOLD, | 4831 | .host_command = RTS_THRESHOLD, |
@@ -4858,7 +4889,7 @@ int ipw2100_set_fragmentation_threshold(struct ipw2100_priv *priv, | |||
4858 | } | 4889 | } |
4859 | #endif | 4890 | #endif |
4860 | 4891 | ||
4861 | int ipw2100_set_short_retry(struct ipw2100_priv *priv, u32 retry) | 4892 | static int ipw2100_set_short_retry(struct ipw2100_priv *priv, u32 retry) |
4862 | { | 4893 | { |
4863 | struct host_command cmd = { | 4894 | struct host_command cmd = { |
4864 | .host_command = SHORT_RETRY_LIMIT, | 4895 | .host_command = SHORT_RETRY_LIMIT, |
@@ -4878,7 +4909,7 @@ int ipw2100_set_short_retry(struct ipw2100_priv *priv, u32 retry) | |||
4878 | return 0; | 4909 | return 0; |
4879 | } | 4910 | } |
4880 | 4911 | ||
4881 | int ipw2100_set_long_retry(struct ipw2100_priv *priv, u32 retry) | 4912 | static int ipw2100_set_long_retry(struct ipw2100_priv *priv, u32 retry) |
4882 | { | 4913 | { |
4883 | struct host_command cmd = { | 4914 | struct host_command cmd = { |
4884 | .host_command = LONG_RETRY_LIMIT, | 4915 | .host_command = LONG_RETRY_LIMIT, |
@@ -4899,8 +4930,8 @@ int ipw2100_set_long_retry(struct ipw2100_priv *priv, u32 retry) | |||
4899 | } | 4930 | } |
4900 | 4931 | ||
4901 | 4932 | ||
4902 | int ipw2100_set_mandatory_bssid(struct ipw2100_priv *priv, u8 *bssid, | 4933 | static int ipw2100_set_mandatory_bssid(struct ipw2100_priv *priv, u8 *bssid, |
4903 | int batch_mode) | 4934 | int batch_mode) |
4904 | { | 4935 | { |
4905 | struct host_command cmd = { | 4936 | struct host_command cmd = { |
4906 | .host_command = MANDATORY_BSSID, | 4937 | .host_command = MANDATORY_BSSID, |
@@ -5037,11 +5068,11 @@ struct security_info_params { | |||
5037 | u8 unicast_using_group; | 5068 | u8 unicast_using_group; |
5038 | } __attribute__ ((packed)); | 5069 | } __attribute__ ((packed)); |
5039 | 5070 | ||
5040 | int ipw2100_set_security_information(struct ipw2100_priv *priv, | 5071 | static int ipw2100_set_security_information(struct ipw2100_priv *priv, |
5041 | int auth_mode, | 5072 | int auth_mode, |
5042 | int security_level, | 5073 | int security_level, |
5043 | int unicast_using_group, | 5074 | int unicast_using_group, |
5044 | int batch_mode) | 5075 | int batch_mode) |
5045 | { | 5076 | { |
5046 | struct host_command cmd = { | 5077 | struct host_command cmd = { |
5047 | .host_command = SET_SECURITY_INFORMATION, | 5078 | .host_command = SET_SECURITY_INFORMATION, |
@@ -5103,8 +5134,8 @@ int ipw2100_set_security_information(struct ipw2100_priv *priv, | |||
5103 | return err; | 5134 | return err; |
5104 | } | 5135 | } |
5105 | 5136 | ||
5106 | int ipw2100_set_tx_power(struct ipw2100_priv *priv, | 5137 | static int ipw2100_set_tx_power(struct ipw2100_priv *priv, |
5107 | u32 tx_power) | 5138 | u32 tx_power) |
5108 | { | 5139 | { |
5109 | struct host_command cmd = { | 5140 | struct host_command cmd = { |
5110 | .host_command = TX_POWER_INDEX, | 5141 | .host_command = TX_POWER_INDEX, |
@@ -5123,8 +5154,8 @@ int ipw2100_set_tx_power(struct ipw2100_priv *priv, | |||
5123 | return 0; | 5154 | return 0; |
5124 | } | 5155 | } |
5125 | 5156 | ||
5126 | int ipw2100_set_ibss_beacon_interval(struct ipw2100_priv *priv, | 5157 | static int ipw2100_set_ibss_beacon_interval(struct ipw2100_priv *priv, |
5127 | u32 interval, int batch_mode) | 5158 | u32 interval, int batch_mode) |
5128 | { | 5159 | { |
5129 | struct host_command cmd = { | 5160 | struct host_command cmd = { |
5130 | .host_command = BEACON_INTERVAL, | 5161 | .host_command = BEACON_INTERVAL, |
@@ -5208,7 +5239,7 @@ static int ipw2100_set_wep_flags(struct ipw2100_priv *priv, u32 flags, | |||
5208 | if (!batch_mode) { | 5239 | if (!batch_mode) { |
5209 | err = ipw2100_disable_adapter(priv); | 5240 | err = ipw2100_disable_adapter(priv); |
5210 | if (err) { | 5241 | if (err) { |
5211 | IPW_DEBUG_ERROR("%s: Could not disable adapter %d\n", | 5242 | printk(KERN_ERR DRV_NAME ": %s: Could not disable adapter %d\n", |
5212 | priv->net_dev->name, err); | 5243 | priv->net_dev->name, err); |
5213 | return err; | 5244 | return err; |
5214 | } | 5245 | } |
@@ -5296,7 +5327,7 @@ static int ipw2100_set_key(struct ipw2100_priv *priv, | |||
5296 | err = ipw2100_disable_adapter(priv); | 5327 | err = ipw2100_disable_adapter(priv); |
5297 | /* FIXME: IPG: shouldn't this prink be in _disable_adapter()? */ | 5328 | /* FIXME: IPG: shouldn't this prink be in _disable_adapter()? */ |
5298 | if (err) { | 5329 | if (err) { |
5299 | IPW_DEBUG_ERROR("%s: Could not disable adapter %d\n", | 5330 | printk(KERN_ERR DRV_NAME ": %s: Could not disable adapter %d\n", |
5300 | priv->net_dev->name, err); | 5331 | priv->net_dev->name, err); |
5301 | return err; | 5332 | return err; |
5302 | } | 5333 | } |
@@ -5332,7 +5363,7 @@ static int ipw2100_set_key_index(struct ipw2100_priv *priv, | |||
5332 | if (!batch_mode) { | 5363 | if (!batch_mode) { |
5333 | err = ipw2100_disable_adapter(priv); | 5364 | err = ipw2100_disable_adapter(priv); |
5334 | if (err) { | 5365 | if (err) { |
5335 | IPW_DEBUG_ERROR("%s: Could not disable adapter %d\n", | 5366 | printk(KERN_ERR DRV_NAME ": %s: Could not disable adapter %d\n", |
5336 | priv->net_dev->name, err); | 5367 | priv->net_dev->name, err); |
5337 | return err; | 5368 | return err; |
5338 | } | 5369 | } |
@@ -5654,8 +5685,10 @@ static int ipw2100_open(struct net_device *dev) | |||
5654 | IPW_DEBUG_INFO("dev->open\n"); | 5685 | IPW_DEBUG_INFO("dev->open\n"); |
5655 | 5686 | ||
5656 | spin_lock_irqsave(&priv->low_lock, flags); | 5687 | spin_lock_irqsave(&priv->low_lock, flags); |
5657 | if (priv->status & STATUS_ASSOCIATED) | 5688 | if (priv->status & STATUS_ASSOCIATED) { |
5689 | netif_carrier_on(dev); | ||
5658 | netif_start_queue(dev); | 5690 | netif_start_queue(dev); |
5691 | } | ||
5659 | spin_unlock_irqrestore(&priv->low_lock, flags); | 5692 | spin_unlock_irqrestore(&priv->low_lock, flags); |
5660 | 5693 | ||
5661 | return 0; | 5694 | return 0; |
@@ -5880,7 +5913,7 @@ static int ipw2100_wpa_set_param(struct net_device *dev, u8 name, u32 value){ | |||
5880 | break; | 5913 | break; |
5881 | 5914 | ||
5882 | default: | 5915 | default: |
5883 | IPW_DEBUG_ERROR("%s: Unknown WPA param: %d\n", | 5916 | printk(KERN_ERR DRV_NAME ": %s: Unknown WPA param: %d\n", |
5884 | dev->name, name); | 5917 | dev->name, name); |
5885 | ret = -EOPNOTSUPP; | 5918 | ret = -EOPNOTSUPP; |
5886 | } | 5919 | } |
@@ -5903,7 +5936,7 @@ static int ipw2100_wpa_mlme(struct net_device *dev, int command, int reason){ | |||
5903 | break; | 5936 | break; |
5904 | 5937 | ||
5905 | default: | 5938 | default: |
5906 | IPW_DEBUG_ERROR("%s: Unknown MLME request: %d\n", | 5939 | printk(KERN_ERR DRV_NAME ": %s: Unknown MLME request: %d\n", |
5907 | dev->name, command); | 5940 | dev->name, command); |
5908 | ret = -EOPNOTSUPP; | 5941 | ret = -EOPNOTSUPP; |
5909 | } | 5942 | } |
@@ -6153,7 +6186,7 @@ static int ipw2100_wpa_supplicant(struct net_device *dev, struct iw_point *p){ | |||
6153 | break; | 6186 | break; |
6154 | 6187 | ||
6155 | default: | 6188 | default: |
6156 | IPW_DEBUG_ERROR("%s: Unknown WPA supplicant request: %d\n", | 6189 | printk(KERN_ERR DRV_NAME ": %s: Unknown WPA supplicant request: %d\n", |
6157 | dev->name, param->cmd); | 6190 | dev->name, param->cmd); |
6158 | ret = -EOPNOTSUPP; | 6191 | ret = -EOPNOTSUPP; |
6159 | 6192 | ||
@@ -6883,7 +6916,7 @@ module_exit(ipw2100_exit); | |||
6883 | 6916 | ||
6884 | #define WEXT_USECHANNELS 1 | 6917 | #define WEXT_USECHANNELS 1 |
6885 | 6918 | ||
6886 | const long ipw2100_frequencies[] = { | 6919 | static const long ipw2100_frequencies[] = { |
6887 | 2412, 2417, 2422, 2427, | 6920 | 2412, 2417, 2422, 2427, |
6888 | 2432, 2437, 2442, 2447, | 6921 | 2432, 2437, 2442, 2447, |
6889 | 2452, 2457, 2462, 2467, | 6922 | 2452, 2457, 2462, 2467, |
@@ -6893,7 +6926,7 @@ const long ipw2100_frequencies[] = { | |||
6893 | #define FREQ_COUNT (sizeof(ipw2100_frequencies) / \ | 6926 | #define FREQ_COUNT (sizeof(ipw2100_frequencies) / \ |
6894 | sizeof(ipw2100_frequencies[0])) | 6927 | sizeof(ipw2100_frequencies[0])) |
6895 | 6928 | ||
6896 | const long ipw2100_rates_11b[] = { | 6929 | static const long ipw2100_rates_11b[] = { |
6897 | 1000000, | 6930 | 1000000, |
6898 | 2000000, | 6931 | 2000000, |
6899 | 5500000, | 6932 | 5500000, |
@@ -7052,7 +7085,7 @@ static int ipw2100_wx_get_mode(struct net_device *dev, | |||
7052 | #define POWER_MODES 5 | 7085 | #define POWER_MODES 5 |
7053 | 7086 | ||
7054 | /* Values are in microsecond */ | 7087 | /* Values are in microsecond */ |
7055 | const s32 timeout_duration[POWER_MODES] = { | 7088 | static const s32 timeout_duration[POWER_MODES] = { |
7056 | 350000, | 7089 | 350000, |
7057 | 250000, | 7090 | 250000, |
7058 | 75000, | 7091 | 75000, |
@@ -7060,7 +7093,7 @@ const s32 timeout_duration[POWER_MODES] = { | |||
7060 | 25000, | 7093 | 25000, |
7061 | }; | 7094 | }; |
7062 | 7095 | ||
7063 | const s32 period_duration[POWER_MODES] = { | 7096 | static const s32 period_duration[POWER_MODES] = { |
7064 | 400000, | 7097 | 400000, |
7065 | 700000, | 7098 | 700000, |
7066 | 1000000, | 7099 | 1000000, |
@@ -8125,7 +8158,7 @@ static iw_handler ipw2100_private_handler[] = { | |||
8125 | ipw2100_wx_get_preamble, | 8158 | ipw2100_wx_get_preamble, |
8126 | }; | 8159 | }; |
8127 | 8160 | ||
8128 | struct iw_handler_def ipw2100_wx_handler_def = | 8161 | static struct iw_handler_def ipw2100_wx_handler_def = |
8129 | { | 8162 | { |
8130 | .standard = ipw2100_wx_handlers, | 8163 | .standard = ipw2100_wx_handlers, |
8131 | .num_standard = sizeof(ipw2100_wx_handlers) / sizeof(iw_handler), | 8164 | .num_standard = sizeof(ipw2100_wx_handlers) / sizeof(iw_handler), |
@@ -8141,7 +8174,7 @@ struct iw_handler_def ipw2100_wx_handler_def = | |||
8141 | * Called by /proc/net/wireless | 8174 | * Called by /proc/net/wireless |
8142 | * Also called by SIOCGIWSTATS | 8175 | * Also called by SIOCGIWSTATS |
8143 | */ | 8176 | */ |
8144 | struct iw_statistics *ipw2100_wx_wireless_stats(struct net_device * dev) | 8177 | static struct iw_statistics *ipw2100_wx_wireless_stats(struct net_device * dev) |
8145 | { | 8178 | { |
8146 | enum { | 8179 | enum { |
8147 | POOR = 30, | 8180 | POOR = 30, |
@@ -8277,7 +8310,7 @@ struct iw_statistics *ipw2100_wx_wireless_stats(struct net_device * dev) | |||
8277 | return (struct iw_statistics *) NULL; | 8310 | return (struct iw_statistics *) NULL; |
8278 | } | 8311 | } |
8279 | 8312 | ||
8280 | void ipw2100_wx_event_work(struct ipw2100_priv *priv) | 8313 | static void ipw2100_wx_event_work(struct ipw2100_priv *priv) |
8281 | { | 8314 | { |
8282 | union iwreq_data wrqu; | 8315 | union iwreq_data wrqu; |
8283 | int len = ETH_ALEN; | 8316 | int len = ETH_ALEN; |
@@ -8375,7 +8408,7 @@ static int ipw2100_mod_firmware_load(struct ipw2100_fw *fw) | |||
8375 | (struct ipw2100_fw_header *)fw->fw_entry->data; | 8408 | (struct ipw2100_fw_header *)fw->fw_entry->data; |
8376 | 8409 | ||
8377 | if (IPW2100_FW_MAJOR(h->version) != IPW2100_FW_MAJOR_VERSION) { | 8410 | if (IPW2100_FW_MAJOR(h->version) != IPW2100_FW_MAJOR_VERSION) { |
8378 | IPW_DEBUG_WARNING("Firmware image not compatible " | 8411 | printk(KERN_WARNING DRV_NAME ": Firmware image not compatible " |
8379 | "(detected version id of %u). " | 8412 | "(detected version id of %u). " |
8380 | "See Documentation/networking/README.ipw2100\n", | 8413 | "See Documentation/networking/README.ipw2100\n", |
8381 | h->version); | 8414 | h->version); |
@@ -8392,7 +8425,8 @@ static int ipw2100_mod_firmware_load(struct ipw2100_fw *fw) | |||
8392 | } | 8425 | } |
8393 | 8426 | ||
8394 | 8427 | ||
8395 | int ipw2100_get_firmware(struct ipw2100_priv *priv, struct ipw2100_fw *fw) | 8428 | static int ipw2100_get_firmware(struct ipw2100_priv *priv, |
8429 | struct ipw2100_fw *fw) | ||
8396 | { | 8430 | { |
8397 | char *fw_name; | 8431 | char *fw_name; |
8398 | int rc; | 8432 | int rc; |
@@ -8418,7 +8452,7 @@ int ipw2100_get_firmware(struct ipw2100_priv *priv, struct ipw2100_fw *fw) | |||
8418 | rc = request_firmware(&fw->fw_entry, fw_name, &priv->pci_dev->dev); | 8452 | rc = request_firmware(&fw->fw_entry, fw_name, &priv->pci_dev->dev); |
8419 | 8453 | ||
8420 | if (rc < 0) { | 8454 | if (rc < 0) { |
8421 | IPW_DEBUG_ERROR( | 8455 | printk(KERN_ERR DRV_NAME ": " |
8422 | "%s: Firmware '%s' not available or load failed.\n", | 8456 | "%s: Firmware '%s' not available or load failed.\n", |
8423 | priv->net_dev->name, fw_name); | 8457 | priv->net_dev->name, fw_name); |
8424 | return rc; | 8458 | return rc; |
@@ -8431,8 +8465,8 @@ int ipw2100_get_firmware(struct ipw2100_priv *priv, struct ipw2100_fw *fw) | |||
8431 | return 0; | 8465 | return 0; |
8432 | } | 8466 | } |
8433 | 8467 | ||
8434 | void ipw2100_release_firmware(struct ipw2100_priv *priv, | 8468 | static void ipw2100_release_firmware(struct ipw2100_priv *priv, |
8435 | struct ipw2100_fw *fw) | 8469 | struct ipw2100_fw *fw) |
8436 | { | 8470 | { |
8437 | fw->version = 0; | 8471 | fw->version = 0; |
8438 | if (fw->fw_entry) | 8472 | if (fw->fw_entry) |
@@ -8441,7 +8475,8 @@ void ipw2100_release_firmware(struct ipw2100_priv *priv, | |||
8441 | } | 8475 | } |
8442 | 8476 | ||
8443 | 8477 | ||
8444 | int ipw2100_get_fwversion(struct ipw2100_priv *priv, char *buf, size_t max) | 8478 | static int ipw2100_get_fwversion(struct ipw2100_priv *priv, char *buf, |
8479 | size_t max) | ||
8445 | { | 8480 | { |
8446 | char ver[MAX_FW_VERSION_LEN]; | 8481 | char ver[MAX_FW_VERSION_LEN]; |
8447 | u32 len = MAX_FW_VERSION_LEN; | 8482 | u32 len = MAX_FW_VERSION_LEN; |
@@ -8460,7 +8495,8 @@ int ipw2100_get_fwversion(struct ipw2100_priv *priv, char *buf, size_t max) | |||
8460 | return tmp; | 8495 | return tmp; |
8461 | } | 8496 | } |
8462 | 8497 | ||
8463 | int ipw2100_get_ucodeversion(struct ipw2100_priv *priv, char *buf, size_t max) | 8498 | static int ipw2100_get_ucodeversion(struct ipw2100_priv *priv, char *buf, |
8499 | size_t max) | ||
8464 | { | 8500 | { |
8465 | u32 ver; | 8501 | u32 ver; |
8466 | u32 len = sizeof(ver); | 8502 | u32 len = sizeof(ver); |
@@ -8474,7 +8510,8 @@ int ipw2100_get_ucodeversion(struct ipw2100_priv *priv, char *buf, size_t max) | |||
8474 | /* | 8510 | /* |
8475 | * On exit, the firmware will have been freed from the fw list | 8511 | * On exit, the firmware will have been freed from the fw list |
8476 | */ | 8512 | */ |
8477 | int ipw2100_fw_download(struct ipw2100_priv *priv, struct ipw2100_fw *fw) | 8513 | static int ipw2100_fw_download(struct ipw2100_priv *priv, |
8514 | struct ipw2100_fw *fw) | ||
8478 | { | 8515 | { |
8479 | /* firmware is constructed of N contiguous entries, each entry is | 8516 | /* firmware is constructed of N contiguous entries, each entry is |
8480 | * structured as: | 8517 | * structured as: |
@@ -8500,7 +8537,7 @@ int ipw2100_fw_download(struct ipw2100_priv *priv, struct ipw2100_fw *fw) | |||
8500 | firmware_data_left -= 2; | 8537 | firmware_data_left -= 2; |
8501 | 8538 | ||
8502 | if (len > 32) { | 8539 | if (len > 32) { |
8503 | IPW_DEBUG_ERROR( | 8540 | printk(KERN_ERR DRV_NAME ": " |
8504 | "Invalid firmware run-length of %d bytes\n", | 8541 | "Invalid firmware run-length of %d bytes\n", |
8505 | len); | 8542 | len); |
8506 | return -EINVAL; | 8543 | return -EINVAL; |
@@ -8531,7 +8568,8 @@ struct symbol_alive_response { | |||
8531 | u8 ucode_valid; | 8568 | u8 ucode_valid; |
8532 | }; | 8569 | }; |
8533 | 8570 | ||
8534 | int ipw2100_ucode_download(struct ipw2100_priv *priv, struct ipw2100_fw *fw) | 8571 | static int ipw2100_ucode_download(struct ipw2100_priv *priv, |
8572 | struct ipw2100_fw *fw) | ||
8535 | { | 8573 | { |
8536 | struct net_device *dev = priv->net_dev; | 8574 | struct net_device *dev = priv->net_dev; |
8537 | const unsigned char *microcode_data = fw->uc.data; | 8575 | const unsigned char *microcode_data = fw->uc.data; |
@@ -8610,7 +8648,7 @@ int ipw2100_ucode_download(struct ipw2100_priv *priv, struct ipw2100_fw *fw) | |||
8610 | } | 8648 | } |
8611 | 8649 | ||
8612 | if (i == 10) { | 8650 | if (i == 10) { |
8613 | IPW_DEBUG_ERROR("%s: Error initializing Symbol\n", | 8651 | printk(KERN_ERR DRV_NAME ": %s: Error initializing Symbol\n", |
8614 | dev->name); | 8652 | dev->name); |
8615 | return -EIO; | 8653 | return -EIO; |
8616 | } | 8654 | } |
@@ -8631,7 +8669,7 @@ int ipw2100_ucode_download(struct ipw2100_priv *priv, struct ipw2100_fw *fw) | |||
8631 | } | 8669 | } |
8632 | 8670 | ||
8633 | if (i == 30) { | 8671 | if (i == 30) { |
8634 | IPW_DEBUG_ERROR("%s: No response from Symbol - hw not alive\n", | 8672 | printk(KERN_ERR DRV_NAME ": %s: No response from Symbol - hw not alive\n", |
8635 | dev->name); | 8673 | dev->name); |
8636 | printk_buf(IPW_DL_ERROR, (u8*)&response, sizeof(response)); | 8674 | printk_buf(IPW_DL_ERROR, (u8*)&response, sizeof(response)); |
8637 | return -EIO; | 8675 | return -EIO; |