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 8 9
#include <linux/firmware.h>
#include <linux/netdevice.h>
#include <linux/usb.h>

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

14 15
#define DRV_NAME "usb8xxx"

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

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

26 27
#define MESSAGE_HEADER_LEN	4

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

31 32
static struct usb_device_id if_usb_table[] = {
	/* Enter the device signature inside */
33 34
	{ USB_DEVICE(0x1286, 0x2001) },
	{ USB_DEVICE(0x05a3, 0x8388) },
35 36 37 38 39 40 41
	{}	/* 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);
42 43 44 45
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);
46 47 48 49 50 51 52
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);
53

54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
/* 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)
{
	struct lbs_private *priv = to_net_dev(dev)->priv;
	struct if_usb_card *cardp = priv->card;
	char fwname[FIRMWARE_NAME_MAX];
	int ret;

	sscanf(buf, "%29s", fwname); /* FIRMWARE_NAME_MAX - 1 = 29 */
	ret = if_usb_prog_firmware(cardp, fwname, BOOT_CMD_UPDATE_FW);
	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)
{
	struct lbs_private *priv = to_net_dev(dev)->priv;
	struct if_usb_card *cardp = priv->card;
	char fwname[FIRMWARE_NAME_MAX];
	int ret;

	sscanf(buf, "%29s", fwname); /* FIRMWARE_NAME_MAX - 1 = 29 */
	ret = if_usb_prog_firmware(cardp, fwname, BOOT_CMD_UPDATE_BOOT2);
	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);

110 111 112 113 114 115 116
/**
 *  @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)
{
117
	struct if_usb_card *cardp = (struct if_usb_card *) urb->context;
118 119 120

	/* handle the transmission complete validations */

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

124 125 126
		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);
127

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

	return;
}

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

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

160 161
	kfree(cardp->ep_out_buf);
	cardp->ep_out_buf = NULL;
162

163
	lbs_deb_leave(LBS_DEB_USB);
164 165
}

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

172
	b2_cmd.hdr.size = cpu_to_le16(sizeof(b2_cmd));
173
	b2_cmd.action = 0;
174
	b2_cmd.version = cardp->boot2_version;
175

176
	if (lbs_cmd_with_response(priv, CMD_SET_BOOT2_VER, &b2_cmd))
177
		lbs_deb_usb("Setting boot2 version failed\n");
178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196

	priv->wol_gpio = 2; /* Wake via GPIO2... */
	priv->wol_gap = 20; /* ... after 20ms    */
	lbs_host_sleep_cfg(priv, EHS_WAKE_ON_UNICAST_DATA);

	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");
	} 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");
			priv->ps_supported = 1;
		} else {
			/* The versions which boot up this way don't seem to
			   work even if we set it to the command interrupt */
			lbs_pr_info("Firmware doesn't wake via command interrupt; disabling PS mode\n");
		}
	}
197 198
}

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

203 204 205 206 207 208 209 210
	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);
}
211

212 213 214 215 216 217 218 219
#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

220 221 222 223 224 225 226 227 228 229 230 231
/**
 *  @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;
232
	struct lbs_private *priv;
233
	struct if_usb_card *cardp;
234 235 236 237
	int i;

	udev = interface_to_usbdev(intf);

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

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

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

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

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

263 264
			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);
265

266 267 268 269 270 271
		} 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);
272 273
		}
	}
274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290
	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;
	}
291

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

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

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

304
	priv->hw_host_to_card = if_usb_host_to_card;
305 306 307 308 309
#ifdef CONFIG_OLPC
	if (machine_is_olpc())
		priv->reset_card = if_usb_reset_olpc_card;
#endif

310
	cardp->boot2_version = udev->descriptor.bcdDevice;
311

312 313
	if_usb_submit_rx_urb(cardp);

314
	if (lbs_start_card(priv))
315
		goto err_start_card;
316

317
	if_usb_setup_firmware(priv);
318

319
	usb_get_dev(udev);
320
	usb_set_intfdata(intf, cardp);
321

322 323 324 325 326 327
	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");

328 329
	return 0;

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

error:
	return -ENOMEM;
}

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

351
	lbs_deb_enter(LBS_DEB_MAIN);
352

353 354 355
	device_remove_file(&priv->dev->dev, &dev_attr_lbs_flash_boot2);
	device_remove_file(&priv->dev->dev, &dev_attr_lbs_flash_fw);

356
	cardp->surprise_removed = 1;
357

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

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

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

370
	lbs_deb_leave(LBS_DEB_MAIN);
371 372 373 374
}

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

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

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

393 394 395 396 397
	/* 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],
398 399 400 401 402 403
	       sizeof(struct fwheader));

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

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

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

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

412 413 414 415 416 417 418 419 420 421
	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");
422 423 424 425

		cardp->fwfinalblk = 1;
	}

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

	return 0;
}

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

437 438
	lbs_deb_enter(LBS_DEB_USB);

439
	*(__le32 *)cardp->ep_out_buf = cpu_to_le32(CMD_TYPE_REQUEST);
440 441 442 443 444 445

	cmd->command = cpu_to_le16(CMD_802_11_RESET);
	cmd->size = cpu_to_le16(sizeof(struct cmd_ds_802_11_reset) + S_DS_GEN);
	cmd->result = cpu_to_le16(0);
	cmd->seqnum = cpu_to_le16(0x5a5a);
	cmd->params.reset.action = cpu_to_le16(CMD_ACT_HALT);
446
	usb_tx_block(cardp, cardp->ep_out_buf, 4 + S_DS_GEN + sizeof(struct cmd_ds_802_11_reset));
447

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

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

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

459 460 461 462 463
	return ret;
}

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

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

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

	cardp->tx_urb->transfer_flags |= URB_ZERO_PACKET;

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

tx_ret:
	return ret;
}

498
static int __if_usb_submit_rx_urb(struct if_usb_card *cardp,
499
				  void (*callbackfn)(struct urb *urb))
500 501 502 503 504 505 506 507 508
{
	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;
	}

509
	cardp->rx_skb = skb;
510 511 512

	/* Fill the receive configuration URB and initialise the Rx call back */
	usb_fill_bulk_urb(cardp->rx_urb, cardp->udev,
513
			  usb_rcvbulkpipe(cardp->udev, cardp->ep_in),
D
Dan Williams 已提交
514
			  (void *) (skb->tail + (size_t) IPFIELD_ALIGN_OFFSET),
515
			  MRVDRV_ETH_RX_PACKET_BUFFER_SIZE, callbackfn,
516
			  cardp);
517 518 519

	cardp->rx_urb->transfer_flags |= URB_ZERO_PACKET;

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

rx_ret:
	return ret;
}

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

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

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

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

559 560 561 562 563 564 565 566
	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 {
567 568
			lbs_deb_usb("Waiting for confirmation; got %x %x\n",
				    le32_to_cpu(tmp[0]), le32_to_cpu(tmp[1]));
569 570 571 572 573
			if_usb_submit_rx_urb_fwload(cardp);
		}
		kfree_skb(skb);
		return;
	}
574
	if (cardp->bootcmdresp <= 0) {
575 576
		memcpy (&bootcmdresp, skb->data + IPFIELD_ALIGN_OFFSET,
			sizeof(bootcmdresp));
577

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

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

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

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

	kfree_skb(skb);

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

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

645
	if_usb_send_fw_pkt(cardp);
646

647
 exit:
648 649
	if_usb_submit_rx_urb_fwload(cardp);

650 651 652 653 654 655 656 657
	kfree(syncfwheader);

	return;
}

#define MRVDRV_MIN_PKT_LEN	30

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

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

672
	lbs_process_rxed_packet(priv, skb);
673 674
}

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

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

	if (!in_interrupt())
		BUG();

692
	spin_lock(&priv->driver_lock);
693

694 695 696 697 698
	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]);
699
	kfree_skb(skb);
700 701
	lbs_notify_command_response(priv, i);

702
	spin_unlock(&priv->driver_lock);
703

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

726
	lbs_deb_enter(LBS_DEB_USB);
727 728 729

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

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

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

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

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

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

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

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

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

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

807
	memcpy((cardp->ep_out_buf + MESSAGE_HEADER_LEN), payload, nb);
808

809
	return usb_tx_block(cardp, cardp->ep_out_buf, nb + MESSAGE_HEADER_LEN);
810 811
}

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

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

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

	return 0;
}
832 833


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


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 928 929
/**
*  @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)
930 931 932
{
	int i = 0;
	static int reset_count = 10;
933
	int ret = 0;
934

935
	lbs_deb_enter(LBS_DEB_USB);
936

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

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

	/* 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;
958 959

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

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

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

	i = 0;

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

1005 1006
	/* Send the first firmware packet... */
	if_usb_send_fw_pkt(cardp);
1007

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

1011
	del_timer_sync(&cardp->fw_timeout);
1012
	usb_kill_urb(cardp->rx_urb);
1013 1014 1015 1016

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

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

1026
 release_fw:
1027 1028
	release_firmware(cardp->fw);
	cardp->fw = NULL;
1029

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

H
Holger Schurig 已提交
1035

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

1043
	lbs_deb_enter(LBS_DEB_USB);
1044

1045
	if (priv->psstate != PS_STATE_FULL_POWER)
1046 1047
		return -1;

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

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

1056
 out:
1057
	lbs_deb_leave(LBS_DEB_USB);
1058
	return ret;
1059 1060 1061 1062
}

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

1066
	lbs_deb_enter(LBS_DEB_USB);
1067

1068
	if_usb_submit_rx_urb(cardp);
1069

1070
	lbs_resume(priv);
1071

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

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

1090
static int __init if_usb_init_module(void)
1091
{
1092
	int ret = 0;
1093

1094 1095 1096 1097 1098 1099
	lbs_deb_enter(LBS_DEB_MAIN);

	ret = usb_register(&if_usb_driver);

	lbs_deb_leave_args(LBS_DEB_MAIN, "ret %d", ret);
	return ret;
1100 1101
}

1102
static void __exit if_usb_exit_module(void)
1103
{
1104 1105
	lbs_deb_enter(LBS_DEB_MAIN);

1106
	usb_deregister(&if_usb_driver);
1107 1108

	lbs_deb_leave(LBS_DEB_MAIN);
1109
}
1110 1111 1112 1113 1114

module_init(if_usb_init_module);
module_exit(if_usb_exit_module);

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