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_header *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(cmd));
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
		return;
	}

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

	if (!syncfwheader->cmd) {
625 626 627
		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));
628 629
		cardp->CRC_OK = 1;
	} else {
630
		lbs_deb_usbd(&cardp->udev->dev, "FW received Blk with CRC error\n");
631 632 633 634 635
		cardp->CRC_OK = 0;
	}

	kfree_skb(skb);

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

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

644
	if_usb_send_fw_pkt(cardp);
645

646
 exit:
647 648
	if_usb_submit_rx_urb_fwload(cardp);

649 650 651 652 653 654
	kfree(syncfwheader);
}

#define MRVDRV_MIN_PKT_LEN	30

static inline void process_cmdtypedata(int recvlength, struct sk_buff *skb,
655
				       struct if_usb_card *cardp,
656
				       struct lbs_private *priv)
657
{
658 659 660
	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");
661 662 663 664 665 666 667
		kfree_skb(skb);
		return;
	}

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

669
	lbs_process_rxed_packet(priv, skb);
670 671
}

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

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

686
	BUG_ON(!in_interrupt());
687

688
	spin_lock(&priv->driver_lock);
689

690 691 692 693 694
	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]);
695
	kfree_skb(skb);
696 697
	lbs_notify_command_response(priv, i);

698
	spin_unlock(&priv->driver_lock);
699

700
	lbs_deb_usbd(&cardp->udev->dev,
701 702 703 704 705 706 707 708 709 710 711 712
		    "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)
{
713 714
	struct if_usb_card *cardp = urb->context;
	struct sk_buff *skb = cardp->rx_skb;
715
	struct lbs_private *priv = cardp->priv;
716
	int recvlength = urb->actual_length;
717 718 719
	uint8_t *recvbuff = NULL;
	uint32_t recvtype = 0;
	__le32 *pkt = (__le32 *)(skb->data + IPFIELD_ALIGN_OFFSET);
720
	uint32_t event;
721

722
	lbs_deb_enter(LBS_DEB_USB);
723 724 725

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

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

	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:
752 753 754 755
		/* Event handling */
		event = le32_to_cpu(pkt[1]);
		lbs_deb_usbd(&cardp->udev->dev, "**EVENT** 0x%X\n", event);
		kfree_skb(skb);
756

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

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

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

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

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

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

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

803
	memcpy((cardp->ep_out_buf + MESSAGE_HEADER_LEN), payload, nb);
804

805
	return usb_tx_block(cardp, cardp->ep_out_buf, nb + MESSAGE_HEADER_LEN);
806 807
}

808 809 810 811 812 813
/**
 *  @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
 */
814
static int if_usb_issue_boot_command(struct if_usb_card *cardp, int ivalue)
815
{
816
	struct bootcmd *bootcmd = cardp->ep_out_buf;
817 818

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

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

	return 0;
}
828 829


830 831 832 833 834 835 836
/**
 *  @brief This function checks the validity of Boot2/FW image.
 *
 *  @param data              pointer to image
 *         len               image length
 *  @return     0 or -1
 */
837
static int check_fwfile_format(const uint8_t *data, uint32_t totlen)
838
{
839 840
	uint32_t bincmd, exit;
	uint32_t blksize, offset, len;
841 842 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
	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;
}


878 879 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
/**
*  @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)
926 927 928
{
	int i = 0;
	static int reset_count = 10;
929
	int ret = 0;
930

931
	lbs_deb_enter(LBS_DEB_USB);
932

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

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

	/* 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;
954 955

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

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

974 975 976 977 978 979 980 981 982
	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) {
983
		if (--reset_count >= 0) {
984
			if_usb_reset_device(cardp);
985 986
			goto restart;
		}
987 988
		ret = -EIO;
		goto release_fw;
989 990 991 992 993 994 995 996 997 998 999 1000
	}

	i = 0;

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

1001 1002
	/* Send the first firmware packet... */
	if_usb_send_fw_pkt(cardp);
1003

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

1007
	del_timer_sync(&cardp->fw_timeout);
1008
	usb_kill_urb(cardp->rx_urb);
1009 1010 1011 1012

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

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

1022
 release_fw:
1023 1024
	release_firmware(cardp->fw);
	cardp->fw = NULL;
1025

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

H
Holger Schurig 已提交
1031

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

1039
	lbs_deb_enter(LBS_DEB_USB);
1040

1041
	if (priv->psstate != PS_STATE_FULL_POWER)
1042 1043
		return -1;

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

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

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

1058
 out:
1059
	lbs_deb_leave(LBS_DEB_USB);
1060
	return ret;
1061 1062 1063 1064
}

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

1068
	lbs_deb_enter(LBS_DEB_USB);
1069

1070
	if_usb_submit_rx_urb(cardp);
1071

1072
	lbs_resume(priv);
1073

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

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

1092
static int __init if_usb_init_module(void)
1093
{
1094
	int ret = 0;
1095

1096 1097 1098 1099 1100 1101
	lbs_deb_enter(LBS_DEB_MAIN);

	ret = usb_register(&if_usb_driver);

	lbs_deb_leave_args(LBS_DEB_MAIN, "ret %d", ret);
	return ret;
1102 1103
}

1104
static void __exit if_usb_exit_module(void)
1105
{
1106 1107
	lbs_deb_enter(LBS_DEB_MAIN);

1108
	usb_deregister(&if_usb_driver);
1109 1110

	lbs_deb_leave(LBS_DEB_MAIN);
1111
}
1112 1113 1114 1115 1116

module_init(if_usb_init_module);
module_exit(if_usb_exit_module);

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