aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/sfc
diff options
context:
space:
mode:
authorBen Hutchings <bhutchings@solarflare.com>2009-11-25 11:09:41 -0500
committerDavid S. Miller <davem@davemloft.net>2009-11-26 18:59:16 -0500
commit44838a447de3b1541cbf845853c4f8999310b0dd (patch)
tree53d5f1b0a6ad773764c7f97eb1d48619e781a67f /drivers/net/sfc
parent734a350a6ccee59647f064fd49cd6cebc5dda48b (diff)
sfc: Clean up struct falcon_board and struct falcon_board_data
Put all static information in struct falcon_board_type and replace it with a pointer in struct falcon_board. Simplify probing aocordingly. Signed-off-by: Ben Hutchings <bhutchings@solarflare.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/sfc')
-rw-r--r--drivers/net/sfc/efx.c2
-rw-r--r--drivers/net/sfc/ethtool.c6
-rw-r--r--drivers/net/sfc/falcon.c4
-rw-r--r--drivers/net/sfc/falcon.h34
-rw-r--r--drivers/net/sfc/falcon_boards.c115
-rw-r--r--drivers/net/sfc/qt202x_phy.c2
-rw-r--r--drivers/net/sfc/tenxpress.c2
7 files changed, 85 insertions, 80 deletions
diff --git a/drivers/net/sfc/efx.c b/drivers/net/sfc/efx.c
index 9f3ef387a047..dc85efaf15a0 100644
--- a/drivers/net/sfc/efx.c
+++ b/drivers/net/sfc/efx.c
@@ -1309,7 +1309,7 @@ static void efx_monitor(struct work_struct *data)
1309 goto out_requeue; 1309 goto out_requeue;
1310 if (!efx->port_enabled) 1310 if (!efx->port_enabled)
1311 goto out_unlock; 1311 goto out_unlock;
1312 rc = falcon_board(efx)->monitor(efx); 1312 rc = falcon_board(efx)->type->monitor(efx);
1313 if (rc) { 1313 if (rc) {
1314 EFX_ERR(efx, "Board sensor %s; shutting down PHY\n", 1314 EFX_ERR(efx, "Board sensor %s; shutting down PHY\n",
1315 (rc == -ERANGE) ? "reported fault" : "failed"); 1315 (rc == -ERANGE) ? "reported fault" : "failed");
diff --git a/drivers/net/sfc/ethtool.c b/drivers/net/sfc/ethtool.c
index d8915b95e65a..bb9abf24f545 100644
--- a/drivers/net/sfc/ethtool.c
+++ b/drivers/net/sfc/ethtool.c
@@ -174,14 +174,14 @@ static int efx_ethtool_phys_id(struct net_device *net_dev, u32 count)
174 struct efx_nic *efx = netdev_priv(net_dev); 174 struct efx_nic *efx = netdev_priv(net_dev);
175 175
176 do { 176 do {
177 falcon_board(efx)->set_id_led(efx, EFX_LED_ON); 177 falcon_board(efx)->type->set_id_led(efx, EFX_LED_ON);
178 schedule_timeout_interruptible(HZ / 2); 178 schedule_timeout_interruptible(HZ / 2);
179 179
180 falcon_board(efx)->set_id_led(efx, EFX_LED_OFF); 180 falcon_board(efx)->type->set_id_led(efx, EFX_LED_OFF);
181 schedule_timeout_interruptible(HZ / 2); 181 schedule_timeout_interruptible(HZ / 2);
182 } while (!signal_pending(current) && --count != 0); 182 } while (!signal_pending(current) && --count != 0);
183 183
184 falcon_board(efx)->set_id_led(efx, EFX_LED_DEFAULT); 184 falcon_board(efx)->type->set_id_led(efx, EFX_LED_DEFAULT);
185 return 0; 185 return 0;
186} 186}
187 187
diff --git a/drivers/net/sfc/falcon.c b/drivers/net/sfc/falcon.c
index 2c0be6ccc624..2f1f1fca0802 100644
--- a/drivers/net/sfc/falcon.c
+++ b/drivers/net/sfc/falcon.c
@@ -2864,7 +2864,7 @@ int falcon_probe_nic(struct efx_nic *efx)
2864 if (rc) 2864 if (rc)
2865 goto fail5; 2865 goto fail5;
2866 2866
2867 rc = falcon_board(efx)->init(efx); 2867 rc = falcon_board(efx)->type->init(efx);
2868 if (rc) { 2868 if (rc) {
2869 EFX_ERR(efx, "failed to initialise board\n"); 2869 EFX_ERR(efx, "failed to initialise board\n");
2870 goto fail6; 2870 goto fail6;
@@ -3067,7 +3067,7 @@ void falcon_remove_nic(struct efx_nic *efx)
3067 struct falcon_board *board = falcon_board(efx); 3067 struct falcon_board *board = falcon_board(efx);
3068 int rc; 3068 int rc;
3069 3069
3070 falcon_board(efx)->fini(efx); 3070 board->type->fini(efx);
3071 3071
3072 /* Remove I2C adapter and clear it in preparation for a retry */ 3072 /* Remove I2C adapter and clear it in preparation for a retry */
3073 rc = i2c_del_adapter(&board->i2c_adap); 3073 rc = i2c_del_adapter(&board->i2c_adap);
diff --git a/drivers/net/sfc/falcon.h b/drivers/net/sfc/falcon.h
index ea6ac06fa26a..b331889ca46c 100644
--- a/drivers/net/sfc/falcon.h
+++ b/drivers/net/sfc/falcon.h
@@ -31,29 +31,41 @@ static inline int falcon_rev(struct efx_nic *efx)
31} 31}
32 32
33/** 33/**
34 * struct falcon_board - board information 34 * struct falcon_board_type - board operations and type information
35 * @type: Board model type 35 * @id: Board type id, as found in NVRAM
36 * @major: Major rev. ('A', 'B' ...) 36 * @ref_model: Model number of Solarflare reference design
37 * @minor: Minor rev. (0, 1, ...) 37 * @gen_type: Generic board type description
38 * @init: Allocate resources and initialise peripheral hardware 38 * @init: Allocate resources and initialise peripheral hardware
39 * @init_phy: Do board-specific PHY initialisation 39 * @init_phy: Do board-specific PHY initialisation
40 * @fini: Shut down hardware and free resources
40 * @set_id_led: Set state of identifying LED or revert to automatic function 41 * @set_id_led: Set state of identifying LED or revert to automatic function
41 * @monitor: Board-specific health check function 42 * @monitor: Board-specific health check function
42 * @fini: Shut down hardware and free resources 43 */
44struct falcon_board_type {
45 u8 id;
46 const char *ref_model;
47 const char *gen_type;
48 int (*init) (struct efx_nic *nic);
49 void (*init_phy) (struct efx_nic *efx);
50 void (*fini) (struct efx_nic *nic);
51 void (*set_id_led) (struct efx_nic *efx, enum efx_led_mode mode);
52 int (*monitor) (struct efx_nic *nic);
53};
54
55/**
56 * struct falcon_board - board information
57 * @type: Type of board
58 * @major: Major rev. ('A', 'B' ...)
59 * @minor: Minor rev. (0, 1, ...)
43 * @i2c_adap: I2C adapter for on-board peripherals 60 * @i2c_adap: I2C adapter for on-board peripherals
44 * @i2c_data: Data for bit-banging algorithm 61 * @i2c_data: Data for bit-banging algorithm
45 * @hwmon_client: I2C client for hardware monitor 62 * @hwmon_client: I2C client for hardware monitor
46 * @ioexp_client: I2C client for power/port control 63 * @ioexp_client: I2C client for power/port control
47 */ 64 */
48struct falcon_board { 65struct falcon_board {
49 int type; 66 const struct falcon_board_type *type;
50 int major; 67 int major;
51 int minor; 68 int minor;
52 int (*init) (struct efx_nic *nic);
53 void (*init_phy) (struct efx_nic *efx);
54 void (*set_id_led) (struct efx_nic *efx, enum efx_led_mode mode);
55 int (*monitor) (struct efx_nic *nic);
56 void (*fini) (struct efx_nic *nic);
57 struct i2c_adapter i2c_adap; 69 struct i2c_adapter i2c_adap;
58 struct i2c_algo_bit_data i2c_data; 70 struct i2c_algo_bit_data i2c_data;
59 struct i2c_client *hwmon_client, *ioexp_client; 71 struct i2c_client *hwmon_client, *ioexp_client;
diff --git a/drivers/net/sfc/falcon_boards.c b/drivers/net/sfc/falcon_boards.c
index f05c9d330a46..ac1258ea677c 100644
--- a/drivers/net/sfc/falcon_boards.c
+++ b/drivers/net/sfc/falcon_boards.c
@@ -348,7 +348,7 @@ static ssize_t set_phy_flash_cfg(struct device *dev,
348 efx->phy_mode = new_mode; 348 efx->phy_mode = new_mode;
349 if (new_mode & PHY_MODE_SPECIAL) 349 if (new_mode & PHY_MODE_SPECIAL)
350 efx_stats_disable(efx); 350 efx_stats_disable(efx);
351 if (falcon_board(efx)->type == FALCON_BOARD_SFE4001) 351 if (falcon_board(efx)->type->id == FALCON_BOARD_SFE4001)
352 err = sfe4001_poweron(efx); 352 err = sfe4001_poweron(efx);
353 else 353 else
354 err = sfn4111t_reset(efx); 354 err = sfn4111t_reset(efx);
@@ -438,13 +438,6 @@ static int sfe4001_init(struct efx_nic *efx)
438 goto fail_hwmon; 438 goto fail_hwmon;
439 } 439 }
440 440
441 /* 10Xpress has fixed-function LED pins, so there is no board-specific
442 * blink code. */
443 board->set_id_led = tenxpress_set_id_led;
444
445 board->monitor = sfe4001_check_hw;
446 board->fini = sfe4001_fini;
447
448 if (efx->phy_mode & PHY_MODE_SPECIAL) { 441 if (efx->phy_mode & PHY_MODE_SPECIAL) {
449 /* PHY won't generate a 156.25 MHz clock and MAC stats fetch 442 /* PHY won't generate a 156.25 MHz clock and MAC stats fetch
450 * will fail. */ 443 * will fail. */
@@ -531,11 +524,6 @@ static int sfn4111t_init(struct efx_nic *efx)
531 if (!board->hwmon_client) 524 if (!board->hwmon_client)
532 return -EIO; 525 return -EIO;
533 526
534 board->init_phy = sfn4111t_init_phy;
535 board->set_id_led = tenxpress_set_id_led;
536 board->monitor = sfn4111t_check_hw;
537 board->fini = sfn4111t_fini;
538
539 rc = device_create_file(&efx->pci_dev->dev, &dev_attr_phy_flash_cfg); 527 rc = device_create_file(&efx->pci_dev->dev, &dev_attr_phy_flash_cfg);
540 if (rc) 528 if (rc)
541 goto fail_hwmon; 529 goto fail_hwmon;
@@ -620,15 +608,7 @@ static int sfe4002_check_hw(struct efx_nic *efx)
620 608
621static int sfe4002_init(struct efx_nic *efx) 609static int sfe4002_init(struct efx_nic *efx)
622{ 610{
623 struct falcon_board *board = falcon_board(efx); 611 return efx_init_lm87(efx, &sfe4002_hwmon_info, sfe4002_lm87_regs);
624 int rc = efx_init_lm87(efx, &sfe4002_hwmon_info, sfe4002_lm87_regs);
625 if (rc)
626 return rc;
627 board->monitor = sfe4002_check_hw;
628 board->init_phy = sfe4002_init_phy;
629 board->set_id_led = sfe4002_set_id_led;
630 board->fini = efx_fini_lm87;
631 return 0;
632} 612}
633 613
634/***************************************************************************** 614/*****************************************************************************
@@ -692,67 +672,80 @@ static int sfn4112f_check_hw(struct efx_nic *efx)
692 672
693static int sfn4112f_init(struct efx_nic *efx) 673static int sfn4112f_init(struct efx_nic *efx)
694{ 674{
695 struct falcon_board *board = falcon_board(efx); 675 return efx_init_lm87(efx, &sfn4112f_hwmon_info, sfn4112f_lm87_regs);
696
697 int rc = efx_init_lm87(efx, &sfn4112f_hwmon_info, sfn4112f_lm87_regs);
698 if (rc)
699 return rc;
700 board->monitor = sfn4112f_check_hw;
701 board->init_phy = sfn4112f_init_phy;
702 board->set_id_led = sfn4112f_set_id_led;
703 board->fini = efx_fini_lm87;
704 return 0;
705} 676}
706 677
707/* This will get expanded as board-specific details get moved out of the 678static const struct falcon_board_type board_types[] = {
708 * PHY drivers. */ 679 {
709struct falcon_board_data { 680 .id = FALCON_BOARD_SFE4001,
710 u8 type; 681 .ref_model = "SFE4001",
711 const char *ref_model; 682 .gen_type = "10GBASE-T adapter",
712 const char *gen_type; 683 .init = sfe4001_init,
713 int (*init) (struct efx_nic *nic); 684 .init_phy = efx_port_dummy_op_void,
714}; 685 .fini = sfe4001_fini,
715 686 .set_id_led = tenxpress_set_id_led,
716 687 .monitor = sfe4001_check_hw,
717static struct falcon_board_data board_data[] = { 688 },
718 { FALCON_BOARD_SFE4001, "SFE4001", "10GBASE-T adapter", sfe4001_init }, 689 {
719 { FALCON_BOARD_SFE4002, "SFE4002", "XFP adapter", sfe4002_init }, 690 .id = FALCON_BOARD_SFE4002,
720 { FALCON_BOARD_SFN4111T, "SFN4111T", "100/1000/10GBASE-T adapter", 691 .ref_model = "SFE4002",
721 sfn4111t_init }, 692 .gen_type = "XFP adapter",
722 { FALCON_BOARD_SFN4112F, "SFN4112F", "SFP+ adapter", 693 .init = sfe4002_init,
723 sfn4112f_init }, 694 .init_phy = sfe4002_init_phy,
695 .fini = efx_fini_lm87,
696 .set_id_led = sfe4002_set_id_led,
697 .monitor = sfe4002_check_hw,
698 },
699 {
700 .id = FALCON_BOARD_SFN4111T,
701 .ref_model = "SFN4111T",
702 .gen_type = "100/1000/10GBASE-T adapter",
703 .init = sfn4111t_init,
704 .init_phy = sfn4111t_init_phy,
705 .fini = sfn4111t_fini,
706 .set_id_led = tenxpress_set_id_led,
707 .monitor = sfn4111t_check_hw,
708 },
709 {
710 .id = FALCON_BOARD_SFN4112F,
711 .ref_model = "SFN4112F",
712 .gen_type = "SFP+ adapter",
713 .init = sfn4112f_init,
714 .init_phy = sfn4112f_init_phy,
715 .fini = efx_fini_lm87,
716 .set_id_led = sfn4112f_set_id_led,
717 .monitor = sfn4112f_check_hw,
718 },
724}; 719};
725 720
726static struct falcon_board falcon_dummy_board = { 721static const struct falcon_board_type falcon_dummy_board = {
727 .init = efx_port_dummy_op_int, 722 .init = efx_port_dummy_op_int,
728 .init_phy = efx_port_dummy_op_void, 723 .init_phy = efx_port_dummy_op_void,
724 .fini = efx_port_dummy_op_void,
729 .set_id_led = efx_port_dummy_op_set_id_led, 725 .set_id_led = efx_port_dummy_op_set_id_led,
730 .monitor = efx_port_dummy_op_int, 726 .monitor = efx_port_dummy_op_int,
731 .fini = efx_port_dummy_op_void,
732}; 727};
733 728
734void falcon_probe_board(struct efx_nic *efx, u16 revision_info) 729void falcon_probe_board(struct efx_nic *efx, u16 revision_info)
735{ 730{
736 struct falcon_board *board = falcon_board(efx); 731 struct falcon_board *board = falcon_board(efx);
737 struct falcon_board_data *data = NULL; 732 u8 type_id = FALCON_BOARD_TYPE(revision_info);
738 int i; 733 int i;
739 734
740 *board = falcon_dummy_board;
741 board->type = FALCON_BOARD_TYPE(revision_info);
742 board->major = FALCON_BOARD_MAJOR(revision_info); 735 board->major = FALCON_BOARD_MAJOR(revision_info);
743 board->minor = FALCON_BOARD_MINOR(revision_info); 736 board->minor = FALCON_BOARD_MINOR(revision_info);
744 737
745 for (i = 0; i < ARRAY_SIZE(board_data); i++) 738 for (i = 0; i < ARRAY_SIZE(board_types); i++)
746 if (board_data[i].type == board->type) 739 if (board_types[i].id == type_id)
747 data = &board_data[i]; 740 board->type = &board_types[i];
748 741
749 if (data) { 742 if (board->type) {
750 EFX_INFO(efx, "board is %s rev %c%d\n", 743 EFX_INFO(efx, "board is %s rev %c%d\n",
751 (efx->pci_dev->subsystem_vendor == EFX_VENDID_SFC) 744 (efx->pci_dev->subsystem_vendor == EFX_VENDID_SFC)
752 ? data->ref_model : data->gen_type, 745 ? board->type->ref_model : board->type->gen_type,
753 'A' + board->major, board->minor); 746 'A' + board->major, board->minor);
754 board->init = data->init;
755 } else { 747 } else {
756 EFX_ERR(efx, "unknown board type %d\n", board->type); 748 EFX_ERR(efx, "unknown board type %d\n", type_id);
749 board->type = &falcon_dummy_board;
757 } 750 }
758} 751}
diff --git a/drivers/net/sfc/qt202x_phy.c b/drivers/net/sfc/qt202x_phy.c
index 8208ac0ffad7..f9c354e9fc3c 100644
--- a/drivers/net/sfc/qt202x_phy.c
+++ b/drivers/net/sfc/qt202x_phy.c
@@ -126,7 +126,7 @@ static int qt202x_reset_phy(struct efx_nic *efx)
126 if (rc < 0) 126 if (rc < 0)
127 goto fail; 127 goto fail;
128 128
129 falcon_board(efx)->init_phy(efx); 129 falcon_board(efx)->type->init_phy(efx);
130 130
131 return rc; 131 return rc;
132 132
diff --git a/drivers/net/sfc/tenxpress.c b/drivers/net/sfc/tenxpress.c
index b001f38524f7..a95402d601c7 100644
--- a/drivers/net/sfc/tenxpress.c
+++ b/drivers/net/sfc/tenxpress.c
@@ -303,7 +303,7 @@ static int tenxpress_phy_init(struct efx_nic *efx)
303 u16 old_adv, adv; 303 u16 old_adv, adv;
304 int rc = 0; 304 int rc = 0;
305 305
306 falcon_board(efx)->init_phy(efx); 306 falcon_board(efx)->type->init_phy(efx);
307 307
308 phy_data = kzalloc(sizeof(*phy_data), GFP_KERNEL); 308 phy_data = kzalloc(sizeof(*phy_data), GFP_KERNEL);
309 if (!phy_data) 309 if (!phy_data)