if_usb.c 28.7 KB
Newer Older
1 2 3 4
/**
  * This file contains functions used in USB interface module.
  */
#include <linux/delay.h>
5
#include <linux/moduleparam.h>
6 7
#include <linux/firmware.h>
#include <linux/netdevice.h>
8
#include <linux/slab.h>
9 10
#include <linux/usb.h>

11 12 13 14
#ifdef CONFIG_OLPC
#include <asm/olpc.h>
#endif

15 16
#define DRV_NAME "usb8xxx"

17 18 19 20
#include "host.h"
#include "decl.h"
#include "defs.h"
#include "dev.h"
21
#include "cmd.h"
22 23
#include "if_usb.h"

24 25 26
#define INSANEDEBUG	0
#define lbs_deb_usb2(...) do { if (INSANEDEBUG) lbs_deb_usbd(__VA_ARGS__); } while (0)

27 28
#define MESSAGE_HEADER_LEN	4

29
static char *lbs_fw_name = "usb8388.bin";
30
module_param_named(fw_name, lbs_fw_name, charp, 0644);
31

B
Ben Hutchings 已提交
32 33
MODULE_FIRMWARE("usb8388.bin");

34 35
static struct usb_device_id if_usb_table[] = {
	/* Enter the device signature inside */
36 37
	{ USB_DEVICE(0x1286, 0x2001) },
	{ USB_DEVICE(0x05a3, 0x8388) },
38 39 40 41 42 43 44
	{}	/* Terminating entry */
};

MODULE_DEVICE_TABLE(usb, if_usb_table);

static void if_usb_receive(struct urb *urb);
static void if_usb_receive_fwload(struct urb *urb);
45 46 47 48
static int __if_usb_prog_firmware(struct if_usb_card *cardp,
					const char *fwname, int cmd);
static int if_usb_prog_firmware(struct if_usb_card *cardp,
					const char *fwname, int cmd);
49 50 51 52 53 54 55
static int if_usb_host_to_card(struct lbs_private *priv, uint8_t type,
			       uint8_t *payload, uint16_t nb);
static int usb_tx_block(struct if_usb_card *cardp, uint8_t *payload,
			uint16_t nb);
static void if_usb_free(struct if_usb_card *cardp);
static int if_usb_submit_rx_urb(struct if_usb_card *cardp);
static int if_usb_reset_device(struct if_usb_card *cardp);
56

57 58 59 60 61 62 63 64
/* sysfs hooks */

/**
 *  Set function to write firmware to device's persistent memory
 */
static ssize_t if_usb_firmware_set(struct device *dev,
		struct device_attribute *attr, const char *buf, size_t count)
{
65
	struct lbs_private *priv = to_net_dev(dev)->ml_priv;
66 67 68
	struct if_usb_card *cardp = priv->card;
	int ret;

69
	ret = if_usb_prog_firmware(cardp, buf, BOOT_CMD_UPDATE_FW);
70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
	if (ret == 0)
		return count;

	return ret;
}

/**
 * lbs_flash_fw attribute to be exported per ethX interface through sysfs
 * (/sys/class/net/ethX/lbs_flash_fw).  Use this like so to write firmware to
 * the device's persistent memory:
 * echo usb8388-5.126.0.p5.bin > /sys/class/net/ethX/lbs_flash_fw
 */
static DEVICE_ATTR(lbs_flash_fw, 0200, NULL, if_usb_firmware_set);

/**
 *  Set function to write firmware to device's persistent memory
 */
static ssize_t if_usb_boot2_set(struct device *dev,
		struct device_attribute *attr, const char *buf, size_t count)
{
90
	struct lbs_private *priv = to_net_dev(dev)->ml_priv;
91 92 93
	struct if_usb_card *cardp = priv->card;
	int ret;

94
	ret = if_usb_prog_firmware(cardp, buf, BOOT_CMD_UPDATE_BOOT2);
95 96 97 98 99 100 101 102 103 104 105 106 107 108
	if (ret == 0)
		return count;

	return ret;
}

/**
 * lbs_flash_boot2 attribute to be exported per ethX interface through sysfs
 * (/sys/class/net/ethX/lbs_flash_boot2).  Use this like so to write firmware
 * to the device's persistent memory:
 * echo usb8388-5.126.0.p5.bin > /sys/class/net/ethX/lbs_flash_boot2
 */
static DEVICE_ATTR(lbs_flash_boot2, 0200, NULL, if_usb_boot2_set);

109 110 111 112 113 114 115
/**
 *  @brief  call back function to handle the status of the URB
 *  @param urb 		pointer to urb structure
 *  @return 	   	N/A
 */
static void if_usb_write_bulk_callback(struct urb *urb)
{
116
	struct if_usb_card *cardp = (struct if_usb_card *) urb->context;
117 118 119

	/* handle the transmission complete validations */

120
	if (urb->status == 0) {
121
		struct lbs_private *priv = cardp->priv;
122

123 124 125
		lbs_deb_usb2(&urb->dev->dev, "URB status is successful\n");
		lbs_deb_usb2(&urb->dev->dev, "Actual length transmitted %d\n",
			     urb->actual_length);
126

127 128
		/* Boot commands such as UPDATE_FW and UPDATE_BOOT2 are not
		 * passed up to the lbs level.
129
		 */
130
		if (priv && priv->dnld_sent != DNLD_BOOTCMD_SENT)
131
			lbs_host_to_card_done(priv);
132 133 134
	} else {
		/* print the failure status number for debug */
		lbs_pr_info("URB in failure status: %d\n", urb->status);
135 136 137 138 139
	}
}

/**
 *  @brief  free tx/rx urb, skb and rx buffer
140
 *  @param cardp	pointer if_usb_card
141 142
 *  @return 	   	N/A
 */
143
static void if_usb_free(struct if_usb_card *cardp)
144
{
145
	lbs_deb_enter(LBS_DEB_USB);
146 147 148 149 150 151 152 153 154 155 156

	/* Unlink tx & rx urb */
	usb_kill_urb(cardp->tx_urb);
	usb_kill_urb(cardp->rx_urb);

	usb_free_urb(cardp->tx_urb);
	cardp->tx_urb = NULL;

	usb_free_urb(cardp->rx_urb);
	cardp->rx_urb = NULL;

157 158
	kfree(cardp->ep_out_buf);
	cardp->ep_out_buf = NULL;
159

160
	lbs_deb_leave(LBS_DEB_USB);
161 162
}

163
static void if_usb_setup_firmware(struct lbs_private *priv)
164
{
165
	struct if_usb_card *cardp = priv->card;
166
	struct cmd_ds_set_boot2_ver b2_cmd;
167
	struct cmd_ds_802_11_fw_wake_method wake_method;
168

169
	b2_cmd.hdr.size = cpu_to_le16(sizeof(b2_cmd));
170
	b2_cmd.action = 0;
171
	b2_cmd.version = cardp->boot2_version;
172

173
	if (lbs_cmd_with_response(priv, CMD_SET_BOOT2_VER, &b2_cmd))
174
		lbs_deb_usb("Setting boot2 version failed\n");
175 176 177

	priv->wol_gpio = 2; /* Wake via GPIO2... */
	priv->wol_gap = 20; /* ... after 20ms    */
178 179
	lbs_host_sleep_cfg(priv, EHS_WAKE_ON_UNICAST_DATA,
			(struct wol_config *) NULL);
180 181 182 183 184

	wake_method.hdr.size = cpu_to_le16(sizeof(wake_method));
	wake_method.action = cpu_to_le16(CMD_ACT_GET);
	if (lbs_cmd_with_response(priv, CMD_802_11_FW_WAKE_METHOD, &wake_method)) {
		lbs_pr_info("Firmware does not seem to support PS mode\n");
185
		priv->fwcapinfo &= ~FW_CAPINFO_PS;
186 187 188 189 190 191
	} else {
		if (le16_to_cpu(wake_method.method) == CMD_WAKE_METHOD_COMMAND_INT) {
			lbs_deb_usb("Firmware seems to support PS with wake-via-command\n");
		} else {
			/* The versions which boot up this way don't seem to
			   work even if we set it to the command interrupt */
192
			priv->fwcapinfo &= ~FW_CAPINFO_PS;
193 194 195
			lbs_pr_info("Firmware doesn't wake via command interrupt; disabling PS mode\n");
		}
	}
196 197
}

198
static void if_usb_fw_timeo(unsigned long priv)
199
{
200
	struct if_usb_card *cardp = (void *)priv;
201

202 203 204 205 206 207 208 209
	if (cardp->fwdnldover) {
		lbs_deb_usb("Download complete, no event. Assuming success\n");
	} else {
		lbs_pr_err("Download timed out\n");
		cardp->surprise_removed = 1;
	}
	wake_up(&cardp->fw_wq);
}
210

211 212 213 214 215 216 217 218
#ifdef CONFIG_OLPC
static void if_usb_reset_olpc_card(struct lbs_private *priv)
{
	printk(KERN_CRIT "Resetting OLPC wireless via EC...\n");
	olpc_ec_cmd(0x25, NULL, 0, NULL, 0);
}
#endif

219 220 221 222 223 224 225 226 227 228 229 230
/**
 *  @brief sets the configuration values
 *  @param ifnum	interface number
 *  @param id		pointer to usb_device_id
 *  @return 	   	0 on success, error code on failure
 */
static int if_usb_probe(struct usb_interface *intf,
			const struct usb_device_id *id)
{
	struct usb_device *udev;
	struct usb_host_interface *iface_desc;
	struct usb_endpoint_descriptor *endpoint;
231
	struct lbs_private *priv;
232
	struct if_usb_card *cardp;
233 234 235 236
	int i;

	udev = interface_to_usbdev(intf);

237
	cardp = kzalloc(sizeof(struct if_usb_card), GFP_KERNEL);
238
	if (!cardp) {
239 240 241 242
		lbs_pr_err("Out of memory allocating private data.\n");
		goto error;
	}

243 244
	setup_timer(&cardp->fw_timeout, if_usb_fw_timeo, (unsigned long)cardp);
	init_waitqueue_head(&cardp->fw_wq);
245

246
	cardp->udev = udev;
247 248
	iface_desc = intf->cur_altsetting;

249
	lbs_deb_usbd(&udev->dev, "bcdUSB = 0x%X bDeviceClass = 0x%X"
250
		     " bDeviceSubClass = 0x%X, bDeviceProtocol = 0x%X\n",
251 252 253 254
		     le16_to_cpu(udev->descriptor.bcdUSB),
		     udev->descriptor.bDeviceClass,
		     udev->descriptor.bDeviceSubClass,
		     udev->descriptor.bDeviceProtocol);
255 256 257

	for (i = 0; i < iface_desc->desc.bNumEndpoints; ++i) {
		endpoint = &iface_desc->endpoint[i].desc;
258 259 260
		if (usb_endpoint_is_bulk_in(endpoint)) {
			cardp->ep_in_size = le16_to_cpu(endpoint->wMaxPacketSize);
			cardp->ep_in = usb_endpoint_num(endpoint);
261

262 263
			lbs_deb_usbd(&udev->dev, "in_endpoint = %d\n", cardp->ep_in);
			lbs_deb_usbd(&udev->dev, "Bulk in size is %d\n", cardp->ep_in_size);
264

265 266 267 268 269 270
		} else if (usb_endpoint_is_bulk_out(endpoint)) {
			cardp->ep_out_size = le16_to_cpu(endpoint->wMaxPacketSize);
			cardp->ep_out = usb_endpoint_num(endpoint);

			lbs_deb_usbd(&udev->dev, "out_endpoint = %d\n", cardp->ep_out);
			lbs_deb_usbd(&udev->dev, "Bulk out size is %d\n", cardp->ep_out_size);
271 272
		}
	}
273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289
	if (!cardp->ep_out_size || !cardp->ep_in_size) {
		lbs_deb_usbd(&udev->dev, "Endpoints not found\n");
		goto dealloc;
	}
	if (!(cardp->rx_urb = usb_alloc_urb(0, GFP_KERNEL))) {
		lbs_deb_usbd(&udev->dev, "Rx URB allocation failed\n");
		goto dealloc;
	}
	if (!(cardp->tx_urb = usb_alloc_urb(0, GFP_KERNEL))) {
		lbs_deb_usbd(&udev->dev, "Tx URB allocation failed\n");
		goto dealloc;
	}
	cardp->ep_out_buf = kmalloc(MRVDRV_ETH_TX_PACKET_BUFFER_SIZE, GFP_KERNEL);
	if (!cardp->ep_out_buf) {
		lbs_deb_usbd(&udev->dev, "Could not allocate buffer\n");
		goto dealloc;
	}
290

291
	/* Upload firmware */
292
	if (__if_usb_prog_firmware(cardp, lbs_fw_name, BOOT_CMD_FW_BY_USB)) {
293
		lbs_deb_usbd(&udev->dev, "FW upload failed\n");
294 295 296
		goto err_prog_firmware;
	}

297
	if (!(priv = lbs_add_card(cardp, &udev->dev)))
298
		goto err_prog_firmware;
299

300
	cardp->priv = priv;
301
	cardp->priv->fw_ready = 1;
302

303
	priv->hw_host_to_card = if_usb_host_to_card;
304 305 306
	priv->enter_deep_sleep = NULL;
	priv->exit_deep_sleep = NULL;
	priv->reset_deep_sleep_wakeup = NULL;
307 308 309 310 311
#ifdef CONFIG_OLPC
	if (machine_is_olpc())
		priv->reset_card = if_usb_reset_olpc_card;
#endif

312
	cardp->boot2_version = udev->descriptor.bcdDevice;
313

314 315
	if_usb_submit_rx_urb(cardp);

316
	if (lbs_start_card(priv))
317
		goto err_start_card;
318

319
	if_usb_setup_firmware(priv);
320

321
	usb_get_dev(udev);
322
	usb_set_intfdata(intf, cardp);
323

324 325 326 327 328 329
	if (device_create_file(&priv->dev->dev, &dev_attr_lbs_flash_fw))
		lbs_pr_err("cannot register lbs_flash_fw attribute\n");

	if (device_create_file(&priv->dev->dev, &dev_attr_lbs_flash_boot2))
		lbs_pr_err("cannot register lbs_flash_boot2 attribute\n");

330 331
	return 0;

332
err_start_card:
333
	lbs_remove_card(priv);
334 335
err_prog_firmware:
	if_usb_reset_device(cardp);
336
dealloc:
337
	if_usb_free(cardp);
338 339 340 341 342 343 344

error:
	return -ENOMEM;
}

/**
 *  @brief free resource and cleanup
345
 *  @param intf		USB interface structure
346 347 348 349
 *  @return 	   	N/A
 */
static void if_usb_disconnect(struct usb_interface *intf)
{
350
	struct if_usb_card *cardp = usb_get_intfdata(intf);
351
	struct lbs_private *priv = (struct lbs_private *) cardp->priv;
352

353
	lbs_deb_enter(LBS_DEB_MAIN);
354

355 356 357
	device_remove_file(&priv->dev->dev, &dev_attr_lbs_flash_boot2);
	device_remove_file(&priv->dev->dev, &dev_attr_lbs_flash_fw);

358
	cardp->surprise_removed = 1;
359

360
	if (priv) {
361
		priv->surpriseremoved = 1;
362 363
		lbs_stop_card(priv);
		lbs_remove_card(priv);
364
	}
365 366 367 368 369 370 371

	/* Unlink and free urb */
	if_usb_free(cardp);

	usb_set_intfdata(intf, NULL);
	usb_put_dev(interface_to_usbdev(intf));

372
	lbs_deb_leave(LBS_DEB_MAIN);
373 374 375 376
}

/**
 *  @brief  This function download FW
377
 *  @param priv		pointer to struct lbs_private
378 379
 *  @return 	   	0
 */
380
static int if_usb_send_fw_pkt(struct if_usb_card *cardp)
381
{
382
	struct fwdata *fwdata = cardp->ep_out_buf;
383
	const uint8_t *firmware = cardp->fw->data;
384

385 386
	/* If we got a CRC failure on the last block, back
	   up and retry it */
387 388
	if (!cardp->CRC_OK) {
		cardp->totalbytes = cardp->fwlastblksent;
389
		cardp->fwseqnum--;
390 391
	}

392 393
	lbs_deb_usb2(&cardp->udev->dev, "totalbytes = %d\n",
		     cardp->totalbytes);
394

395 396 397 398 399
	/* struct fwdata (which we sent to the card) has an
	   extra __le32 field in between the header and the data,
	   which is not in the struct fwheader in the actual
	   firmware binary. Insert the seqnum in the middle... */
	memcpy(&fwdata->hdr, &firmware[cardp->totalbytes],
400 401 402 403 404 405
	       sizeof(struct fwheader));

	cardp->fwlastblksent = cardp->totalbytes;
	cardp->totalbytes += sizeof(struct fwheader);

	memcpy(fwdata->data, &firmware[cardp->totalbytes],
406
	       le32_to_cpu(fwdata->hdr.datalength));
407

408 409
	lbs_deb_usb2(&cardp->udev->dev, "Data length = %d\n",
		     le32_to_cpu(fwdata->hdr.datalength));
410

411 412
	fwdata->seqnum = cpu_to_le32(++cardp->fwseqnum);
	cardp->totalbytes += le32_to_cpu(fwdata->hdr.datalength);
413

414 415 416 417 418 419 420 421 422 423
	usb_tx_block(cardp, cardp->ep_out_buf, sizeof(struct fwdata) +
		     le32_to_cpu(fwdata->hdr.datalength));

	if (fwdata->hdr.dnldcmd == cpu_to_le32(FW_HAS_DATA_TO_RECV)) {
		lbs_deb_usb2(&cardp->udev->dev, "There are data to follow\n");
		lbs_deb_usb2(&cardp->udev->dev, "seqnum = %d totalbytes = %d\n",
			     cardp->fwseqnum, cardp->totalbytes);
	} else if (fwdata->hdr.dnldcmd == cpu_to_le32(FW_HAS_LAST_BLOCK)) {
		lbs_deb_usb2(&cardp->udev->dev, "Host has finished FW downloading\n");
		lbs_deb_usb2(&cardp->udev->dev, "Donwloading FW JUMP BLOCK\n");
424 425 426 427

		cardp->fwfinalblk = 1;
	}

428 429
	lbs_deb_usb2(&cardp->udev->dev, "Firmware download done; size %d\n",
		     cardp->totalbytes);
430 431 432 433

	return 0;
}

434
static int if_usb_reset_device(struct if_usb_card *cardp)
435
{
436
	struct cmd_ds_command *cmd = cardp->ep_out_buf + 4;
437 438
	int ret;

439 440
	lbs_deb_enter(LBS_DEB_USB);

441
	*(__le32 *)cardp->ep_out_buf = cpu_to_le32(CMD_TYPE_REQUEST);
442 443

	cmd->command = cpu_to_le16(CMD_802_11_RESET);
444
	cmd->size = cpu_to_le16(sizeof(struct cmd_header));
445 446
	cmd->result = cpu_to_le16(0);
	cmd->seqnum = cpu_to_le16(0x5a5a);
447
	usb_tx_block(cardp, cardp->ep_out_buf, 4 + sizeof(struct cmd_header));
448

449
	msleep(100);
450
	ret = usb_reset_device(cardp->udev);
451
	msleep(100);
452

453 454 455 456 457
#ifdef CONFIG_OLPC
	if (ret && machine_is_olpc())
		if_usb_reset_olpc_card(NULL);
#endif

458 459
	lbs_deb_leave_args(LBS_DEB_USB, "ret %d", ret);

460 461 462 463 464
	return ret;
}

/**
 *  @brief This function transfer the data to the device.
465
 *  @param priv 	pointer to struct lbs_private
466 467 468 469
 *  @param payload	pointer to payload data
 *  @param nb		data length
 *  @return 	   	0 or -1
 */
470
static int usb_tx_block(struct if_usb_card *cardp, uint8_t *payload, uint16_t nb)
471 472 473 474
{
	int ret = -1;

	/* check if device is removed */
475
	if (cardp->surprise_removed) {
476
		lbs_deb_usbd(&cardp->udev->dev, "Device removed\n");
477 478 479 480 481
		goto tx_ret;
	}

	usb_fill_bulk_urb(cardp->tx_urb, cardp->udev,
			  usb_sndbulkpipe(cardp->udev,
482
					  cardp->ep_out),
483
			  payload, nb, if_usb_write_bulk_callback, cardp);
484 485 486 487

	cardp->tx_urb->transfer_flags |= URB_ZERO_PACKET;

	if ((ret = usb_submit_urb(cardp->tx_urb, GFP_ATOMIC))) {
488
		lbs_deb_usbd(&cardp->udev->dev, "usb_submit_urb failed: %d\n", ret);
489 490
		ret = -1;
	} else {
491
		lbs_deb_usb2(&cardp->udev->dev, "usb_submit_urb success\n");
492 493 494 495 496 497 498
		ret = 0;
	}

tx_ret:
	return ret;
}

499
static int __if_usb_submit_rx_urb(struct if_usb_card *cardp,
500
				  void (*callbackfn)(struct urb *urb))
501 502 503 504 505 506 507 508 509
{
	struct sk_buff *skb;
	int ret = -1;

	if (!(skb = dev_alloc_skb(MRVDRV_ETH_RX_PACKET_BUFFER_SIZE))) {
		lbs_pr_err("No free skb\n");
		goto rx_ret;
	}

510
	cardp->rx_skb = skb;
511 512 513

	/* Fill the receive configuration URB and initialise the Rx call back */
	usb_fill_bulk_urb(cardp->rx_urb, cardp->udev,
514
			  usb_rcvbulkpipe(cardp->udev, cardp->ep_in),
515
			  skb->data + IPFIELD_ALIGN_OFFSET,
516
			  MRVDRV_ETH_RX_PACKET_BUFFER_SIZE, callbackfn,
517
			  cardp);
518 519 520

	cardp->rx_urb->transfer_flags |= URB_ZERO_PACKET;

521
	lbs_deb_usb2(&cardp->udev->dev, "Pointer for rx_urb %p\n", cardp->rx_urb);
522
	if ((ret = usb_submit_urb(cardp->rx_urb, GFP_ATOMIC))) {
523
		lbs_deb_usbd(&cardp->udev->dev, "Submit Rx URB failed: %d\n", ret);
524
		kfree_skb(skb);
525
		cardp->rx_skb = NULL;
526 527
		ret = -1;
	} else {
528
		lbs_deb_usb2(&cardp->udev->dev, "Submit Rx URB success\n");
529 530 531 532 533 534 535
		ret = 0;
	}

rx_ret:
	return ret;
}

536
static int if_usb_submit_rx_urb_fwload(struct if_usb_card *cardp)
537
{
538
	return __if_usb_submit_rx_urb(cardp, &if_usb_receive_fwload);
539 540
}

541
static int if_usb_submit_rx_urb(struct if_usb_card *cardp)
542
{
543
	return __if_usb_submit_rx_urb(cardp, &if_usb_receive);
544 545 546 547
}

static void if_usb_receive_fwload(struct urb *urb)
{
548 549
	struct if_usb_card *cardp = urb->context;
	struct sk_buff *skb = cardp->rx_skb;
550
	struct fwsyncheader *syncfwheader;
551
	struct bootcmdresp bootcmdresp;
552 553

	if (urb->status) {
554
		lbs_deb_usbd(&cardp->udev->dev,
555
			     "URB status is failed during fw load\n");
556 557 558 559
		kfree_skb(skb);
		return;
	}

560 561 562 563 564 565 566 567
	if (cardp->fwdnldover) {
		__le32 *tmp = (__le32 *)(skb->data + IPFIELD_ALIGN_OFFSET);

		if (tmp[0] == cpu_to_le32(CMD_TYPE_INDICATION) &&
		    tmp[1] == cpu_to_le32(MACREG_INT_CODE_FIRMWARE_READY)) {
			lbs_pr_info("Firmware ready event received\n");
			wake_up(&cardp->fw_wq);
		} else {
568 569
			lbs_deb_usb("Waiting for confirmation; got %x %x\n",
				    le32_to_cpu(tmp[0]), le32_to_cpu(tmp[1]));
570 571 572 573 574
			if_usb_submit_rx_urb_fwload(cardp);
		}
		kfree_skb(skb);
		return;
	}
575
	if (cardp->bootcmdresp <= 0) {
576 577
		memcpy (&bootcmdresp, skb->data + IPFIELD_ALIGN_OFFSET,
			sizeof(bootcmdresp));
578

579
		if (le16_to_cpu(cardp->udev->descriptor.bcdDevice) < 0x3106) {
580
			kfree_skb(skb);
581
			if_usb_submit_rx_urb_fwload(cardp);
582
			cardp->bootcmdresp = BOOT_CMD_RESP_OK;
583
			lbs_deb_usbd(&cardp->udev->dev,
584
				     "Received valid boot command response\n");
585 586
			return;
		}
587 588 589 590
		if (bootcmdresp.magic != cpu_to_le32(BOOT_CMD_MAGIC_NUMBER)) {
			if (bootcmdresp.magic == cpu_to_le32(CMD_TYPE_REQUEST) ||
			    bootcmdresp.magic == cpu_to_le32(CMD_TYPE_DATA) ||
			    bootcmdresp.magic == cpu_to_le32(CMD_TYPE_INDICATION)) {
591 592
				if (!cardp->bootcmdresp)
					lbs_pr_info("Firmware already seems alive; resetting\n");
593 594 595
				cardp->bootcmdresp = -1;
			} else {
				lbs_pr_info("boot cmd response wrong magic number (0x%x)\n",
596
					    le32_to_cpu(bootcmdresp.magic));
597
			}
598 599 600
		} else if ((bootcmdresp.cmd != BOOT_CMD_FW_BY_USB) &&
			   (bootcmdresp.cmd != BOOT_CMD_UPDATE_FW) &&
			   (bootcmdresp.cmd != BOOT_CMD_UPDATE_BOOT2)) {
601 602 603 604 605
			lbs_pr_info("boot cmd response cmd_tag error (%d)\n",
				    bootcmdresp.cmd);
		} else if (bootcmdresp.result != BOOT_CMD_RESP_OK) {
			lbs_pr_info("boot cmd response result error (%d)\n",
				    bootcmdresp.result);
606 607
		} else {
			cardp->bootcmdresp = 1;
608
			lbs_deb_usbd(&cardp->udev->dev,
609
				     "Received valid boot command response\n");
610 611
		}
		kfree_skb(skb);
612
		if_usb_submit_rx_urb_fwload(cardp);
613 614 615 616 617
		return;
	}

	syncfwheader = kmalloc(sizeof(struct fwsyncheader), GFP_ATOMIC);
	if (!syncfwheader) {
618
		lbs_deb_usbd(&cardp->udev->dev, "Failure to allocate syncfwheader\n");
619 620 621 622 623
		kfree_skb(skb);
		return;
	}

	memcpy(syncfwheader, skb->data + IPFIELD_ALIGN_OFFSET,
624
	       sizeof(struct fwsyncheader));
625 626

	if (!syncfwheader->cmd) {
627 628 629
		lbs_deb_usb2(&cardp->udev->dev, "FW received Blk with correct CRC\n");
		lbs_deb_usb2(&cardp->udev->dev, "FW received Blk seqnum = %d\n",
			     le32_to_cpu(syncfwheader->seqnum));
630 631
		cardp->CRC_OK = 1;
	} else {
632
		lbs_deb_usbd(&cardp->udev->dev, "FW received Blk with CRC error\n");
633 634 635 636 637
		cardp->CRC_OK = 0;
	}

	kfree_skb(skb);

638 639
	/* Give device 5s to either write firmware to its RAM or eeprom */
	mod_timer(&cardp->fw_timeout, jiffies + (HZ*5));
640

641 642 643 644 645
	if (cardp->fwfinalblk) {
		cardp->fwdnldover = 1;
		goto exit;
	}

646
	if_usb_send_fw_pkt(cardp);
647

648
 exit:
649 650
	if_usb_submit_rx_urb_fwload(cardp);

651 652 653 654 655 656
	kfree(syncfwheader);
}

#define MRVDRV_MIN_PKT_LEN	30

static inline void process_cmdtypedata(int recvlength, struct sk_buff *skb,
657
				       struct if_usb_card *cardp,
658
				       struct lbs_private *priv)
659
{
660 661 662
	if (recvlength > MRVDRV_ETH_RX_PACKET_BUFFER_SIZE + MESSAGE_HEADER_LEN
	    || recvlength < MRVDRV_MIN_PKT_LEN) {
		lbs_deb_usbd(&cardp->udev->dev, "Packet length is Invalid\n");
663 664 665 666 667 668 669
		kfree_skb(skb);
		return;
	}

	skb_reserve(skb, IPFIELD_ALIGN_OFFSET);
	skb_put(skb, recvlength);
	skb_pull(skb, MESSAGE_HEADER_LEN);
670

671
	lbs_process_rxed_packet(priv, skb);
672 673
}

674
static inline void process_cmdrequest(int recvlength, uint8_t *recvbuff,
675
				      struct sk_buff *skb,
676
				      struct if_usb_card *cardp,
677
				      struct lbs_private *priv)
678
{
679 680
	u8 i;

681
	if (recvlength > LBS_CMD_BUFFER_SIZE) {
682
		lbs_deb_usbd(&cardp->udev->dev,
683
			     "The receive buffer is too large\n");
684 685 686 687
		kfree_skb(skb);
		return;
	}

688
	BUG_ON(!in_interrupt());
689

690
	spin_lock(&priv->driver_lock);
691

692 693 694 695 696
	i = (priv->resp_idx == 0) ? 1 : 0;
	BUG_ON(priv->resp_len[i]);
	priv->resp_len[i] = (recvlength - MESSAGE_HEADER_LEN);
	memcpy(priv->resp_buf[i], recvbuff + MESSAGE_HEADER_LEN,
		priv->resp_len[i]);
697
	kfree_skb(skb);
698 699
	lbs_notify_command_response(priv, i);

700
	spin_unlock(&priv->driver_lock);
701

702
	lbs_deb_usbd(&cardp->udev->dev,
703 704 705 706 707 708 709 710 711 712 713 714
		    "Wake up main thread to handle cmd response\n");
}

/**
 *  @brief This function reads of the packet into the upload buff,
 *  wake up the main thread and initialise the Rx callack.
 *
 *  @param urb		pointer to struct urb
 *  @return 	   	N/A
 */
static void if_usb_receive(struct urb *urb)
{
715 716
	struct if_usb_card *cardp = urb->context;
	struct sk_buff *skb = cardp->rx_skb;
717
	struct lbs_private *priv = cardp->priv;
718
	int recvlength = urb->actual_length;
719 720 721
	uint8_t *recvbuff = NULL;
	uint32_t recvtype = 0;
	__le32 *pkt = (__le32 *)(skb->data + IPFIELD_ALIGN_OFFSET);
722
	uint32_t event;
723

724
	lbs_deb_enter(LBS_DEB_USB);
725 726 727

	if (recvlength) {
		if (urb->status) {
728 729
			lbs_deb_usbd(&cardp->udev->dev, "RX URB failed: %d\n",
				     urb->status);
730 731 732 733 734
			kfree_skb(skb);
			goto setup_for_next;
		}

		recvbuff = skb->data + IPFIELD_ALIGN_OFFSET;
735
		recvtype = le32_to_cpu(pkt[0]);
736
		lbs_deb_usbd(&cardp->udev->dev,
737 738
			    "Recv length = 0x%x, Recv type = 0x%X\n",
			    recvlength, recvtype);
739 740
	} else if (urb->status) {
		kfree_skb(skb);
741
		goto rx_exit;
742
	}
743 744 745 746 747 748 749 750 751 752 753

	switch (recvtype) {
	case CMD_TYPE_DATA:
		process_cmdtypedata(recvlength, skb, cardp, priv);
		break;

	case CMD_TYPE_REQUEST:
		process_cmdrequest(recvlength, recvbuff, skb, cardp, priv);
		break;

	case CMD_TYPE_INDICATION:
754 755 756 757
		/* Event handling */
		event = le32_to_cpu(pkt[1]);
		lbs_deb_usbd(&cardp->udev->dev, "**EVENT** 0x%X\n", event);
		kfree_skb(skb);
758

759 760 761
		/* Icky undocumented magic special case */
		if (event & 0xffff0000) {
			u32 trycount = (event & 0xffff0000) >> 16;
762

763 764 765 766
			lbs_send_tx_feedback(priv, trycount);
		} else
			lbs_queue_event(priv, event & 0xFF);
		break;
767

768
	default:
769
		lbs_deb_usbd(&cardp->udev->dev, "Unknown command type 0x%X\n",
770
			     recvtype);
771 772 773 774 775
		kfree_skb(skb);
		break;
	}

setup_for_next:
776
	if_usb_submit_rx_urb(cardp);
777
rx_exit:
778
	lbs_deb_leave(LBS_DEB_USB);
779 780 781 782
}

/**
 *  @brief This function downloads data to FW
783
 *  @param priv		pointer to struct lbs_private structure
784 785 786 787 788
 *  @param type		type of data
 *  @param buf		pointer to data buffer
 *  @param len		number of bytes
 *  @return 	   	0 or -1
 */
789 790
static int if_usb_host_to_card(struct lbs_private *priv, uint8_t type,
			       uint8_t *payload, uint16_t nb)
791
{
792
	struct if_usb_card *cardp = priv->card;
793

794 795
	lbs_deb_usbd(&cardp->udev->dev,"*** type = %u\n", type);
	lbs_deb_usbd(&cardp->udev->dev,"size after = %d\n", nb);
796 797

	if (type == MVMS_CMD) {
798
		*(__le32 *)cardp->ep_out_buf = cpu_to_le32(CMD_TYPE_REQUEST);
799
		priv->dnld_sent = DNLD_CMD_SENT;
800
	} else {
801
		*(__le32 *)cardp->ep_out_buf = cpu_to_le32(CMD_TYPE_DATA);
802
		priv->dnld_sent = DNLD_DATA_SENT;
803 804
	}

805
	memcpy((cardp->ep_out_buf + MESSAGE_HEADER_LEN), payload, nb);
806

807
	return usb_tx_block(cardp, cardp->ep_out_buf, nb + MESSAGE_HEADER_LEN);
808 809
}

810 811 812 813 814 815
/**
 *  @brief This function issues Boot command to the Boot2 code
 *  @param ivalue   1:Boot from FW by USB-Download
 *                  2:Boot from FW in EEPROM
 *  @return 	   	0
 */
816
static int if_usb_issue_boot_command(struct if_usb_card *cardp, int ivalue)
817
{
818
	struct bootcmd *bootcmd = cardp->ep_out_buf;
819 820

	/* Prepare command */
821 822 823
	bootcmd->magic = cpu_to_le32(BOOT_CMD_MAGIC_NUMBER);
	bootcmd->cmd = ivalue;
	memset(bootcmd->pad, 0, sizeof(bootcmd->pad));
824 825

	/* Issue command */
826
	usb_tx_block(cardp, cardp->ep_out_buf, sizeof(*bootcmd));
827 828 829

	return 0;
}
830 831


832 833 834 835 836 837 838
/**
 *  @brief This function checks the validity of Boot2/FW image.
 *
 *  @param data              pointer to image
 *         len               image length
 *  @return     0 or -1
 */
839
static int check_fwfile_format(const uint8_t *data, uint32_t totlen)
840
{
841 842
	uint32_t bincmd, exit;
	uint32_t blksize, offset, len;
843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879
	int ret;

	ret = 1;
	exit = len = 0;

	do {
		struct fwheader *fwh = (void *)data;

		bincmd = le32_to_cpu(fwh->dnldcmd);
		blksize = le32_to_cpu(fwh->datalength);
		switch (bincmd) {
		case FW_HAS_DATA_TO_RECV:
			offset = sizeof(struct fwheader) + blksize;
			data += offset;
			len += offset;
			if (len >= totlen)
				exit = 1;
			break;
		case FW_HAS_LAST_BLOCK:
			exit = 1;
			ret = 0;
			break;
		default:
			exit = 1;
			break;
		}
	} while (!exit);

	if (ret)
		lbs_pr_err("firmware file format check FAIL\n");
	else
		lbs_deb_fw("firmware file format check PASS\n");

	return ret;
}


880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927
/**
*  @brief This function programs the firmware subject to cmd
*
*  @param cardp             the if_usb_card descriptor
*         fwname            firmware or boot2 image file name
*         cmd               either BOOT_CMD_FW_BY_USB, BOOT_CMD_UPDATE_FW,
*                           or BOOT_CMD_UPDATE_BOOT2.
*  @return     0 or error code
*/
static int if_usb_prog_firmware(struct if_usb_card *cardp,
				const char *fwname, int cmd)
{
	struct lbs_private *priv = cardp->priv;
	unsigned long flags, caps;
	int ret;

	caps = priv->fwcapinfo;
	if (((cmd == BOOT_CMD_UPDATE_FW) && !(caps & FW_CAPINFO_FIRMWARE_UPGRADE)) ||
	    ((cmd == BOOT_CMD_UPDATE_BOOT2) && !(caps & FW_CAPINFO_BOOT2_UPGRADE)))
		return -EOPNOTSUPP;

	/* Ensure main thread is idle. */
	spin_lock_irqsave(&priv->driver_lock, flags);
	while (priv->cur_cmd != NULL || priv->dnld_sent != DNLD_RES_RECEIVED) {
		spin_unlock_irqrestore(&priv->driver_lock, flags);
		if (wait_event_interruptible(priv->waitq,
				(priv->cur_cmd == NULL &&
				priv->dnld_sent == DNLD_RES_RECEIVED))) {
			return -ERESTARTSYS;
		}
		spin_lock_irqsave(&priv->driver_lock, flags);
	}
	priv->dnld_sent = DNLD_BOOTCMD_SENT;
	spin_unlock_irqrestore(&priv->driver_lock, flags);

	ret = __if_usb_prog_firmware(cardp, fwname, cmd);

	spin_lock_irqsave(&priv->driver_lock, flags);
	priv->dnld_sent = DNLD_RES_RECEIVED;
	spin_unlock_irqrestore(&priv->driver_lock, flags);

	wake_up_interruptible(&priv->waitq);

	return ret;
}

static int __if_usb_prog_firmware(struct if_usb_card *cardp,
					const char *fwname, int cmd)
928 929 930
{
	int i = 0;
	static int reset_count = 10;
931
	int ret = 0;
932

933
	lbs_deb_enter(LBS_DEB_USB);
934

935 936
	ret = request_firmware(&cardp->fw, fwname, &cardp->udev->dev);
	if (ret < 0) {
937
		lbs_pr_err("request_firmware() failed with %#x\n", ret);
938
		lbs_pr_err("firmware %s not found\n", fwname);
939 940 941
		goto done;
	}

942 943
	if (check_fwfile_format(cardp->fw->data, cardp->fw->size)) {
		ret = -EINVAL;
944
		goto release_fw;
945 946 947 948 949 950 951 952 953 954 955
	}

	/* Cancel any pending usb business */
	usb_kill_urb(cardp->rx_urb);
	usb_kill_urb(cardp->tx_urb);

	cardp->fwlastblksent = 0;
	cardp->fwdnldover = 0;
	cardp->totalbytes = 0;
	cardp->fwfinalblk = 0;
	cardp->bootcmdresp = 0;
956 957

restart:
958
	if (if_usb_submit_rx_urb_fwload(cardp) < 0) {
959
		lbs_deb_usbd(&cardp->udev->dev, "URB submission is failed\n");
960
		ret = -EIO;
961
		goto release_fw;
962 963 964 965 966 967
	}

	cardp->bootcmdresp = 0;
	do {
		int j = 0;
		i++;
968
		if_usb_issue_boot_command(cardp, cmd);
969 970 971 972 973 974 975
		/* wait for command response */
		do {
			j++;
			msleep_interruptible(100);
		} while (cardp->bootcmdresp == 0 && j < 10);
	} while (cardp->bootcmdresp == 0 && i < 5);

976 977 978 979 980 981 982 983 984
	if (cardp->bootcmdresp == BOOT_CMD_RESP_NOT_SUPPORTED) {
		/* Return to normal operation */
		ret = -EOPNOTSUPP;
		usb_kill_urb(cardp->rx_urb);
		usb_kill_urb(cardp->tx_urb);
		if (if_usb_submit_rx_urb(cardp) < 0)
			ret = -EIO;
		goto release_fw;
	} else if (cardp->bootcmdresp <= 0) {
985
		if (--reset_count >= 0) {
986
			if_usb_reset_device(cardp);
987 988
			goto restart;
		}
989 990
		ret = -EIO;
		goto release_fw;
991 992 993 994 995 996 997 998 999 1000 1001 1002
	}

	i = 0;

	cardp->totalbytes = 0;
	cardp->fwlastblksent = 0;
	cardp->CRC_OK = 1;
	cardp->fwdnldover = 0;
	cardp->fwseqnum = -1;
	cardp->totalbytes = 0;
	cardp->fwfinalblk = 0;

1003 1004
	/* Send the first firmware packet... */
	if_usb_send_fw_pkt(cardp);
1005

1006 1007
	/* ... and wait for the process to complete */
	wait_event_interruptible(cardp->fw_wq, cardp->surprise_removed || cardp->fwdnldover);
1008

1009
	del_timer_sync(&cardp->fw_timeout);
1010
	usb_kill_urb(cardp->rx_urb);
1011 1012 1013 1014

	if (!cardp->fwdnldover) {
		lbs_pr_info("failed to load fw, resetting device!\n");
		if (--reset_count >= 0) {
1015
			if_usb_reset_device(cardp);
1016 1017 1018 1019
			goto restart;
		}

		lbs_pr_info("FW download failure, time = %d ms\n", i * 100);
1020
		ret = -EIO;
1021
		goto release_fw;
1022 1023
	}

1024
 release_fw:
1025 1026
	release_firmware(cardp->fw);
	cardp->fw = NULL;
1027

1028
 done:
1029 1030
	lbs_deb_leave_args(LBS_DEB_USB, "ret %d", ret);
	return ret;
1031 1032
}

H
Holger Schurig 已提交
1033

1034 1035 1036
#ifdef CONFIG_PM
static int if_usb_suspend(struct usb_interface *intf, pm_message_t message)
{
1037
	struct if_usb_card *cardp = usb_get_intfdata(intf);
1038
	struct lbs_private *priv = cardp->priv;
1039
	int ret;
1040

1041
	lbs_deb_enter(LBS_DEB_USB);
1042

1043
	if (priv->psstate != PS_STATE_FULL_POWER)
1044 1045
		return -1;

1046 1047 1048 1049 1050 1051
	if (priv->wol_criteria == EHS_REMOVE_WAKEUP) {
		lbs_pr_info("Suspend attempt without "
						"configuring wake params!\n");
		return -ENOSYS;
	}

1052 1053 1054
	ret = lbs_suspend(priv);
	if (ret)
		goto out;
1055 1056 1057 1058 1059

	/* Unlink tx & rx urb */
	usb_kill_urb(cardp->tx_urb);
	usb_kill_urb(cardp->rx_urb);

1060
 out:
1061
	lbs_deb_leave(LBS_DEB_USB);
1062
	return ret;
1063 1064 1065 1066
}

static int if_usb_resume(struct usb_interface *intf)
{
1067
	struct if_usb_card *cardp = usb_get_intfdata(intf);
1068
	struct lbs_private *priv = cardp->priv;
1069

1070
	lbs_deb_enter(LBS_DEB_USB);
1071

1072
	if_usb_submit_rx_urb(cardp);
1073

1074
	lbs_resume(priv);
1075

1076
	lbs_deb_leave(LBS_DEB_USB);
1077 1078 1079 1080 1081 1082 1083 1084
	return 0;
}
#else
#define if_usb_suspend NULL
#define if_usb_resume NULL
#endif

static struct usb_driver if_usb_driver = {
1085
	.name = DRV_NAME,
1086 1087 1088 1089 1090
	.probe = if_usb_probe,
	.disconnect = if_usb_disconnect,
	.id_table = if_usb_table,
	.suspend = if_usb_suspend,
	.resume = if_usb_resume,
1091
	.reset_resume = if_usb_resume,
1092 1093
};

1094
static int __init if_usb_init_module(void)
1095
{
1096
	int ret = 0;
1097

1098 1099 1100 1101 1102 1103
	lbs_deb_enter(LBS_DEB_MAIN);

	ret = usb_register(&if_usb_driver);

	lbs_deb_leave_args(LBS_DEB_MAIN, "ret %d", ret);
	return ret;
1104 1105
}

1106
static void __exit if_usb_exit_module(void)
1107
{
1108 1109
	lbs_deb_enter(LBS_DEB_MAIN);

1110
	usb_deregister(&if_usb_driver);
1111 1112

	lbs_deb_leave(LBS_DEB_MAIN);
1113
}
1114 1115 1116 1117 1118

module_init(if_usb_init_module);
module_exit(if_usb_exit_module);

MODULE_DESCRIPTION("8388 USB WLAN Driver");
1119
MODULE_AUTHOR("Marvell International Ltd. and Red Hat, Inc.");
1120
MODULE_LICENSE("GPL");