qeth_core_main.c 191.8 KB
Newer Older
1
// SPDX-License-Identifier: GPL-2.0
F
Frank Blaschka 已提交
2
/*
3
 *    Copyright IBM Corp. 2007, 2009
F
Frank Blaschka 已提交
4 5 6 7 8 9
 *    Author(s): Utz Bacher <utz.bacher@de.ibm.com>,
 *		 Frank Pavlic <fpavlic@de.ibm.com>,
 *		 Thomas Spatzier <tspat@de.ibm.com>,
 *		 Frank Blaschka <frank.blaschka@de.ibm.com>
 */

10 11 12
#define KMSG_COMPONENT "qeth"
#define pr_fmt(fmt) KMSG_COMPONENT ": " fmt

13
#include <linux/compat.h>
F
Frank Blaschka 已提交
14 15 16 17 18
#include <linux/module.h>
#include <linux/moduleparam.h>
#include <linux/string.h>
#include <linux/errno.h>
#include <linux/kernel.h>
19
#include <linux/log2.h>
20
#include <linux/io.h>
F
Frank Blaschka 已提交
21 22 23
#include <linux/ip.h>
#include <linux/tcp.h>
#include <linux/mii.h>
J
Julian Wiedmann 已提交
24
#include <linux/mm.h>
F
Frank Blaschka 已提交
25
#include <linux/kthread.h>
26
#include <linux/slab.h>
27 28 29
#include <linux/if_vlan.h>
#include <linux/netdevice.h>
#include <linux/netdev_features.h>
30
#include <linux/rcutree.h>
31
#include <linux/skbuff.h>
32
#include <linux/vmalloc.h>
33

34
#include <net/iucv/af_iucv.h>
35
#include <net/dsfield.h>
36
#include <net/sock.h>
F
Frank Blaschka 已提交
37

38
#include <asm/ebcdic.h>
39
#include <asm/chpid.h>
40
#include <asm/sysinfo.h>
41 42 43
#include <asm/diag.h>
#include <asm/cio.h>
#include <asm/ccwdev.h>
44
#include <asm/cpcmd.h>
F
Frank Blaschka 已提交
45 46 47

#include "qeth_core.h"

48 49 50 51 52
struct qeth_dbf_info qeth_dbf[QETH_DBF_INFOS] = {
	/* define dbf - Name, Pages, Areas, Maxlen, Level, View, Handle */
	/*                   N  P  A    M  L  V                      H  */
	[QETH_DBF_SETUP] = {"qeth_setup",
				8, 1,   8, 5, &debug_hex_ascii_view, NULL},
53 54
	[QETH_DBF_MSG]	 = {"qeth_msg", 8, 1, 11 * sizeof(long), 3,
			    &debug_sprintf_view, NULL},
55 56 57 58
	[QETH_DBF_CTRL]  = {"qeth_control",
		8, 1, QETH_DBF_CTRL_LEN, 5, &debug_hex_ascii_view, NULL},
};
EXPORT_SYMBOL_GPL(qeth_dbf);
F
Frank Blaschka 已提交
59

60 61
struct kmem_cache *qeth_core_header_cache;
EXPORT_SYMBOL_GPL(qeth_core_header_cache);
62
static struct kmem_cache *qeth_qdio_outbuf_cache;
F
Frank Blaschka 已提交
63 64

static struct device *qeth_core_root_dev;
65
static struct dentry *qeth_debugfs_root;
F
Frank Blaschka 已提交
66 67
static struct lock_class_key qdio_out_skb_queue_key;

68
static void qeth_issue_next_read_cb(struct qeth_card *card,
69 70
				    struct qeth_cmd_buffer *iob,
				    unsigned int data_length);
F
Frank Blaschka 已提交
71
static int qeth_qdio_establish(struct qeth_card *);
72
static void qeth_free_qdio_queues(struct qeth_card *card);
73 74 75
static void qeth_notify_skbs(struct qeth_qdio_out_q *queue,
		struct qeth_qdio_out_buffer *buf,
		enum iucv_tx_notify notification);
F
Frank Blaschka 已提交
76

S
Stefan Raspl 已提交
77 78 79 80 81 82 83 84 85
static void qeth_close_dev_handler(struct work_struct *work)
{
	struct qeth_card *card;

	card = container_of(work, struct qeth_card, close_dev_work);
	QETH_CARD_TEXT(card, 2, "cldevhdl");
	ccwgroup_set_offline(card->gdev);
}

J
Julian Wiedmann 已提交
86
static const char *qeth_get_cardname(struct qeth_card *card)
F
Frank Blaschka 已提交
87
{
88
	if (IS_VM_NIC(card)) {
F
Frank Blaschka 已提交
89
		switch (card->info.type) {
90
		case QETH_CARD_TYPE_OSD:
91
			return " Virtual NIC QDIO";
F
Frank Blaschka 已提交
92
		case QETH_CARD_TYPE_IQD:
93
			return " Virtual NIC Hiper";
94
		case QETH_CARD_TYPE_OSM:
95
			return " Virtual NIC QDIO - OSM";
96
		case QETH_CARD_TYPE_OSX:
97
			return " Virtual NIC QDIO - OSX";
F
Frank Blaschka 已提交
98 99 100 101 102
		default:
			return " unknown";
		}
	} else {
		switch (card->info.type) {
103
		case QETH_CARD_TYPE_OSD:
F
Frank Blaschka 已提交
104 105 106 107 108
			return " OSD Express";
		case QETH_CARD_TYPE_IQD:
			return " HiperSockets";
		case QETH_CARD_TYPE_OSN:
			return " OSN QDIO";
109 110 111 112
		case QETH_CARD_TYPE_OSM:
			return " OSM QDIO";
		case QETH_CARD_TYPE_OSX:
			return " OSX QDIO";
F
Frank Blaschka 已提交
113 114 115 116 117 118 119 120 121 122
		default:
			return " unknown";
		}
	}
	return " n/a";
}

/* max length to be returned: 14 */
const char *qeth_get_cardname_short(struct qeth_card *card)
{
123
	if (IS_VM_NIC(card)) {
F
Frank Blaschka 已提交
124
		switch (card->info.type) {
125
		case QETH_CARD_TYPE_OSD:
126
			return "Virt.NIC QDIO";
F
Frank Blaschka 已提交
127
		case QETH_CARD_TYPE_IQD:
128
			return "Virt.NIC Hiper";
129
		case QETH_CARD_TYPE_OSM:
130
			return "Virt.NIC OSM";
131
		case QETH_CARD_TYPE_OSX:
132
			return "Virt.NIC OSX";
F
Frank Blaschka 已提交
133 134 135 136 137
		default:
			return "unknown";
		}
	} else {
		switch (card->info.type) {
138
		case QETH_CARD_TYPE_OSD:
F
Frank Blaschka 已提交
139 140 141 142 143 144 145 146 147
			switch (card->info.link_type) {
			case QETH_LINK_TYPE_FAST_ETH:
				return "OSD_100";
			case QETH_LINK_TYPE_HSTR:
				return "HSTR";
			case QETH_LINK_TYPE_GBIT_ETH:
				return "OSD_1000";
			case QETH_LINK_TYPE_10GBIT_ETH:
				return "OSD_10GIG";
148 149
			case QETH_LINK_TYPE_25GBIT_ETH:
				return "OSD_25GIG";
F
Frank Blaschka 已提交
150 151 152 153 154 155 156 157 158 159 160 161 162 163 164
			case QETH_LINK_TYPE_LANE_ETH100:
				return "OSD_FE_LANE";
			case QETH_LINK_TYPE_LANE_TR:
				return "OSD_TR_LANE";
			case QETH_LINK_TYPE_LANE_ETH1000:
				return "OSD_GbE_LANE";
			case QETH_LINK_TYPE_LANE:
				return "OSD_ATM_LANE";
			default:
				return "OSD_Express";
			}
		case QETH_CARD_TYPE_IQD:
			return "HiperSockets";
		case QETH_CARD_TYPE_OSN:
			return "OSN";
165 166 167 168
		case QETH_CARD_TYPE_OSM:
			return "OSM_1000";
		case QETH_CARD_TYPE_OSX:
			return "OSX_10GIG";
F
Frank Blaschka 已提交
169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201
		default:
			return "unknown";
		}
	}
	return "n/a";
}

void qeth_set_allowed_threads(struct qeth_card *card, unsigned long threads,
			 int clear_start_mask)
{
	unsigned long flags;

	spin_lock_irqsave(&card->thread_mask_lock, flags);
	card->thread_allowed_mask = threads;
	if (clear_start_mask)
		card->thread_start_mask &= threads;
	spin_unlock_irqrestore(&card->thread_mask_lock, flags);
	wake_up(&card->wait_q);
}
EXPORT_SYMBOL_GPL(qeth_set_allowed_threads);

int qeth_threads_running(struct qeth_card *card, unsigned long threads)
{
	unsigned long flags;
	int rc = 0;

	spin_lock_irqsave(&card->thread_mask_lock, flags);
	rc = (card->thread_running_mask & threads);
	spin_unlock_irqrestore(&card->thread_mask_lock, flags);
	return rc;
}
EXPORT_SYMBOL_GPL(qeth_threads_running);

202
static void qeth_clear_working_pool_list(struct qeth_card *card)
F
Frank Blaschka 已提交
203 204
{
	struct qeth_buffer_pool_entry *pool_entry, *tmp;
205 206
	struct qeth_qdio_q *queue = card->qdio.in_q;
	unsigned int i;
F
Frank Blaschka 已提交
207

C
Carsten Otte 已提交
208
	QETH_CARD_TEXT(card, 5, "clwrklst");
F
Frank Blaschka 已提交
209
	list_for_each_entry_safe(pool_entry, tmp,
210 211
				 &card->qdio.in_buf_pool.entry_list, list)
		list_del(&pool_entry->list);
212 213 214

	for (i = 0; i < ARRAY_SIZE(queue->bufs); i++)
		queue->bufs[i].pool_entry = NULL;
F
Frank Blaschka 已提交
215 216
}

217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249
static void qeth_free_pool_entry(struct qeth_buffer_pool_entry *entry)
{
	unsigned int i;

	for (i = 0; i < ARRAY_SIZE(entry->elements); i++) {
		if (entry->elements[i])
			__free_page(entry->elements[i]);
	}

	kfree(entry);
}

static void qeth_free_buffer_pool(struct qeth_card *card)
{
	struct qeth_buffer_pool_entry *entry, *tmp;

	list_for_each_entry_safe(entry, tmp, &card->qdio.init_pool.entry_list,
				 init_list) {
		list_del(&entry->init_list);
		qeth_free_pool_entry(entry);
	}
}

static struct qeth_buffer_pool_entry *qeth_alloc_pool_entry(unsigned int pages)
{
	struct qeth_buffer_pool_entry *entry;
	unsigned int i;

	entry = kzalloc(sizeof(*entry), GFP_KERNEL);
	if (!entry)
		return NULL;

	for (i = 0; i < pages; i++) {
250
		entry->elements[i] = __dev_alloc_page(GFP_KERNEL);
251 252 253 254 255 256 257 258 259 260

		if (!entry->elements[i]) {
			qeth_free_pool_entry(entry);
			return NULL;
		}
	}

	return entry;
}

F
Frank Blaschka 已提交
261 262
static int qeth_alloc_buffer_pool(struct qeth_card *card)
{
263 264
	unsigned int buf_elements = QETH_MAX_BUFFER_ELEMENTS(card);
	unsigned int i;
F
Frank Blaschka 已提交
265

C
Carsten Otte 已提交
266
	QETH_CARD_TEXT(card, 5, "alocpool");
F
Frank Blaschka 已提交
267
	for (i = 0; i < card->qdio.init_pool.buf_count; ++i) {
268 269 270 271
		struct qeth_buffer_pool_entry *entry;

		entry = qeth_alloc_pool_entry(buf_elements);
		if (!entry) {
F
Frank Blaschka 已提交
272 273 274
			qeth_free_buffer_pool(card);
			return -ENOMEM;
		}
275

276
		list_add(&entry->init_list, &card->qdio.init_pool.entry_list);
F
Frank Blaschka 已提交
277 278 279 280
	}
	return 0;
}

281
int qeth_resize_buffer_pool(struct qeth_card *card, unsigned int count)
F
Frank Blaschka 已提交
282
{
283 284 285 286 287 288
	unsigned int buf_elements = QETH_MAX_BUFFER_ELEMENTS(card);
	struct qeth_qdio_buffer_pool *pool = &card->qdio.init_pool;
	struct qeth_buffer_pool_entry *entry, *tmp;
	int delta = count - pool->buf_count;
	LIST_HEAD(entries);

C
Carsten Otte 已提交
289
	QETH_CARD_TEXT(card, 2, "realcbp");
F
Frank Blaschka 已提交
290

291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329
	/* Defer until queue is allocated: */
	if (!card->qdio.in_q)
		goto out;

	/* Remove entries from the pool: */
	while (delta < 0) {
		entry = list_first_entry(&pool->entry_list,
					 struct qeth_buffer_pool_entry,
					 init_list);
		list_del(&entry->init_list);
		qeth_free_pool_entry(entry);

		delta++;
	}

	/* Allocate additional entries: */
	while (delta > 0) {
		entry = qeth_alloc_pool_entry(buf_elements);
		if (!entry) {
			list_for_each_entry_safe(entry, tmp, &entries,
						 init_list) {
				list_del(&entry->init_list);
				qeth_free_pool_entry(entry);
			}

			return -ENOMEM;
		}

		list_add(&entry->init_list, &entries);

		delta--;
	}

	list_splice(&entries, &pool->entry_list);

out:
	card->qdio.in_buf_pool.buf_count = count;
	pool->buf_count = count;
	return 0;
F
Frank Blaschka 已提交
330
}
331
EXPORT_SYMBOL_GPL(qeth_resize_buffer_pool);
F
Frank Blaschka 已提交
332

S
Sebastian Ott 已提交
333 334
static void qeth_free_qdio_queue(struct qeth_qdio_q *q)
{
335 336 337 338
	if (!q)
		return;

	qdio_free_buffers(q->qdio_bufs, QDIO_MAX_BUFFERS_PER_Q);
S
Sebastian Ott 已提交
339 340 341 342 343 344 345 346 347 348 349
	kfree(q);
}

static struct qeth_qdio_q *qeth_alloc_qdio_queue(void)
{
	struct qeth_qdio_q *q = kzalloc(sizeof(*q), GFP_KERNEL);
	int i;

	if (!q)
		return NULL;

350 351 352 353 354
	if (qdio_alloc_buffers(q->qdio_bufs, QDIO_MAX_BUFFERS_PER_Q)) {
		kfree(q);
		return NULL;
	}

S
Sebastian Ott 已提交
355
	for (i = 0; i < QDIO_MAX_BUFFERS_PER_Q; ++i)
356
		q->bufs[i].buffer = q->qdio_bufs[i];
S
Sebastian Ott 已提交
357 358 359 360 361

	QETH_DBF_HEX(SETUP, 2, &q, sizeof(void *));
	return q;
}

J
Julian Wiedmann 已提交
362
static int qeth_cq_init(struct qeth_card *card)
363 364 365 366
{
	int rc;

	if (card->options.cq == QETH_CQ_ENABLED) {
367
		QETH_CARD_TEXT(card, 2, "cqinit");
368 369
		qdio_reset_buffers(card->qdio.c_q->qdio_bufs,
				   QDIO_MAX_BUFFERS_PER_Q);
370 371 372 373 374
		card->qdio.c_q->next_buf_to_init = 127;
		rc = do_QDIO(CARD_DDEV(card), QDIO_FLAG_SYNC_INPUT,
			     card->qdio.no_in_queues - 1, 0,
			     127);
		if (rc) {
375
			QETH_CARD_TEXT_(card, 2, "1err%d", rc);
376 377 378 379 380 381 382 383
			goto out;
		}
	}
	rc = 0;
out:
	return rc;
}

J
Julian Wiedmann 已提交
384
static int qeth_alloc_cq(struct qeth_card *card)
385 386 387 388 389 390 391
{
	int rc;

	if (card->options.cq == QETH_CQ_ENABLED) {
		int i;
		struct qdio_outbuf_state *outbuf_states;

392
		QETH_CARD_TEXT(card, 2, "cqon");
S
Sebastian Ott 已提交
393
		card->qdio.c_q = qeth_alloc_qdio_queue();
394 395 396 397 398
		if (!card->qdio.c_q) {
			rc = -1;
			goto kmsg_out;
		}
		card->qdio.no_in_queues = 2;
399
		card->qdio.out_bufstates =
K
Kees Cook 已提交
400 401 402 403
			kcalloc(card->qdio.no_out_queues *
					QDIO_MAX_BUFFERS_PER_Q,
				sizeof(struct qdio_outbuf_state),
				GFP_KERNEL);
404 405 406 407 408 409 410 411 412 413
		outbuf_states = card->qdio.out_bufstates;
		if (outbuf_states == NULL) {
			rc = -1;
			goto free_cq_out;
		}
		for (i = 0; i < card->qdio.no_out_queues; ++i) {
			card->qdio.out_qs[i]->bufstates = outbuf_states;
			outbuf_states += QDIO_MAX_BUFFERS_PER_Q;
		}
	} else {
414
		QETH_CARD_TEXT(card, 2, "nocq");
415 416 417
		card->qdio.c_q = NULL;
		card->qdio.no_in_queues = 1;
	}
418
	QETH_CARD_TEXT_(card, 2, "iqc%d", card->qdio.no_in_queues);
419 420 421 422
	rc = 0;
out:
	return rc;
free_cq_out:
S
Sebastian Ott 已提交
423
	qeth_free_qdio_queue(card->qdio.c_q);
424 425 426 427 428 429
	card->qdio.c_q = NULL;
kmsg_out:
	dev_err(&card->gdev->dev, "Failed to create completion queue\n");
	goto out;
}

J
Julian Wiedmann 已提交
430
static void qeth_free_cq(struct qeth_card *card)
431 432 433
{
	if (card->qdio.c_q) {
		--card->qdio.no_in_queues;
S
Sebastian Ott 已提交
434
		qeth_free_qdio_queue(card->qdio.c_q);
435 436 437 438 439 440
		card->qdio.c_q = NULL;
	}
	kfree(card->qdio.out_bufstates);
	card->qdio.out_bufstates = NULL;
}

J
Julian Wiedmann 已提交
441 442 443
static enum iucv_tx_notify qeth_compute_cq_notification(int sbalf15,
							int delayed)
{
444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465
	enum iucv_tx_notify n;

	switch (sbalf15) {
	case 0:
		n = delayed ? TX_NOTIFY_DELAYED_OK : TX_NOTIFY_OK;
		break;
	case 4:
	case 16:
	case 17:
	case 18:
		n = delayed ? TX_NOTIFY_DELAYED_UNREACHABLE :
			TX_NOTIFY_UNREACHABLE;
		break;
	default:
		n = delayed ? TX_NOTIFY_DELAYED_GENERALERROR :
			TX_NOTIFY_GENERALERROR;
		break;
	}

	return n;
}

J
Julian Wiedmann 已提交
466 467 468
static void qeth_qdio_handle_aob(struct qeth_card *card,
				 unsigned long phys_aob_addr)
{
469
	enum qeth_qdio_out_buffer_state new_state = QETH_QDIO_BUF_QAOB_OK;
470 471
	struct qaob *aob;
	struct qeth_qdio_out_buffer *buffer;
472
	enum iucv_tx_notify notification;
473
	struct qeth_qdio_out_q *queue;
474
	unsigned int i;
475 476 477 478 479 480 481

	aob = (struct qaob *) phys_to_virt(phys_aob_addr);
	QETH_CARD_TEXT(card, 5, "haob");
	QETH_CARD_TEXT_(card, 5, "%lx", phys_aob_addr);
	buffer = (struct qeth_qdio_out_buffer *) aob->user1;
	QETH_CARD_TEXT_(card, 5, "%lx", aob->user1);

482 483 484 485 486 487 488
	if (aob->aorc) {
		QETH_CARD_TEXT_(card, 2, "aorc%02X", aob->aorc);
		new_state = QETH_QDIO_BUF_QAOB_ERROR;
	}

	switch (atomic_xchg(&buffer->state, new_state)) {
	case QETH_QDIO_BUF_PRIMED:
489 490 491
		/* Faster than TX completion code, let it handle the async
		 * completion for us.
		 */
492 493 494 495 496 497 498 499 500 501
		break;
	case QETH_QDIO_BUF_PENDING:
		/* TX completion code is active and will handle the async
		 * completion for us.
		 */
		break;
	case QETH_QDIO_BUF_NEED_QAOB:
		/* TX completion code is already finished. */
		notification = qeth_compute_cq_notification(aob->aorc, 1);
		qeth_notify_skbs(buffer->q, buffer, notification);
502 503

		/* Free dangling allocations. The attached skbs are handled by
504
		 * qeth_tx_complete_pending_bufs().
505 506 507 508 509 510 511 512
		 */
		for (i = 0;
		     i < aob->sb_count && i < QETH_MAX_BUFFER_ELEMENTS(card);
		     i++) {
			void *data = phys_to_virt(aob->sba[i]);

			if (data && buffer->is_header[i])
				kmem_cache_free(qeth_core_header_cache, data);
513
			buffer->is_header[i] = 0;
514 515
		}

516
		queue = buffer->q;
517
		atomic_set(&buffer->state, QETH_QDIO_BUF_EMPTY);
518
		napi_schedule(&queue->napi);
519 520 521 522
		break;
	default:
		WARN_ON_ONCE(1);
	}
523

524 525 526
	qdio_release_aob(aob);
}

527 528
static void qeth_setup_ccw(struct ccw1 *ccw, u8 cmd_code, u8 flags, u32 len,
			   void *data)
529 530
{
	ccw->cmd_code = cmd_code;
531
	ccw->flags = flags | CCW_FLAG_SLI;
532 533 534 535
	ccw->count = len;
	ccw->cda = (__u32) __pa(data);
}

536
static int __qeth_issue_next_read(struct qeth_card *card)
F
Frank Blaschka 已提交
537
{
538 539 540
	struct qeth_cmd_buffer *iob = card->read_cmd;
	struct qeth_channel *channel = iob->channel;
	struct ccw1 *ccw = __ccw_from_cmd(iob);
541
	int rc;
F
Frank Blaschka 已提交
542

C
Carsten Otte 已提交
543
	QETH_CARD_TEXT(card, 5, "issnxrd");
544
	if (channel->state != CH_STATE_UP)
F
Frank Blaschka 已提交
545
		return -EIO;
546

547 548
	memset(iob->data, 0, iob->length);
	qeth_setup_ccw(ccw, CCW_CMD_READ, 0, iob->length, iob->data);
549
	iob->callback = qeth_issue_next_read_cb;
550 551 552
	/* keep the cmd alive after completion: */
	qeth_get_cmd(iob);

C
Carsten Otte 已提交
553
	QETH_CARD_TEXT(card, 6, "noirqpnd");
554
	rc = ccw_device_start(channel->ccwdev, ccw, (addr_t) iob, 0, 0);
555 556 557
	if (!rc) {
		channel->active_cmd = iob;
	} else {
558 559
		QETH_DBF_MESSAGE(2, "error %i on device %x when starting next read ccw!\n",
				 rc, CARD_DEVID(card));
560
		qeth_unlock_channel(card, channel);
561
		qeth_put_cmd(iob);
562
		card->read_or_write_problem = 1;
F
Frank Blaschka 已提交
563 564 565 566 567
		qeth_schedule_recovery(card);
	}
	return rc;
}

568 569 570 571 572 573 574 575 576 577 578
static int qeth_issue_next_read(struct qeth_card *card)
{
	int ret;

	spin_lock_irq(get_ccwdev_lock(CARD_RDEV(card)));
	ret = __qeth_issue_next_read(card);
	spin_unlock_irq(get_ccwdev_lock(CARD_RDEV(card)));

	return ret;
}

579 580
static void qeth_enqueue_cmd(struct qeth_card *card,
			     struct qeth_cmd_buffer *iob)
581 582
{
	spin_lock_irq(&card->lock);
583
	list_add_tail(&iob->list_entry, &card->cmd_waiter_list);
584 585 586
	spin_unlock_irq(&card->lock);
}

587 588
static void qeth_dequeue_cmd(struct qeth_card *card,
			     struct qeth_cmd_buffer *iob)
589 590
{
	spin_lock_irq(&card->lock);
591
	list_del(&iob->list_entry);
592 593 594
	spin_unlock_irq(&card->lock);
}

595
void qeth_notify_cmd(struct qeth_cmd_buffer *iob, int reason)
596
{
597 598
	iob->rc = reason;
	complete(&iob->done);
599
}
600
EXPORT_SYMBOL_GPL(qeth_notify_cmd);
601

602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629
static void qeth_flush_local_addrs4(struct qeth_card *card)
{
	struct qeth_local_addr *addr;
	struct hlist_node *tmp;
	unsigned int i;

	spin_lock_irq(&card->local_addrs4_lock);
	hash_for_each_safe(card->local_addrs4, i, tmp, addr, hnode) {
		hash_del_rcu(&addr->hnode);
		kfree_rcu(addr, rcu);
	}
	spin_unlock_irq(&card->local_addrs4_lock);
}

static void qeth_flush_local_addrs6(struct qeth_card *card)
{
	struct qeth_local_addr *addr;
	struct hlist_node *tmp;
	unsigned int i;

	spin_lock_irq(&card->local_addrs6_lock);
	hash_for_each_safe(card->local_addrs6, i, tmp, addr, hnode) {
		hash_del_rcu(&addr->hnode);
		kfree_rcu(addr, rcu);
	}
	spin_unlock_irq(&card->local_addrs6_lock);
}

630
static void qeth_flush_local_addrs(struct qeth_card *card)
631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781
{
	qeth_flush_local_addrs4(card);
	qeth_flush_local_addrs6(card);
}

static void qeth_add_local_addrs4(struct qeth_card *card,
				  struct qeth_ipacmd_local_addrs4 *cmd)
{
	unsigned int i;

	if (cmd->addr_length !=
	    sizeof_field(struct qeth_ipacmd_local_addr4, addr)) {
		dev_err_ratelimited(&card->gdev->dev,
				    "Dropped IPv4 ADD LOCAL ADDR event with bad length %u\n",
				    cmd->addr_length);
		return;
	}

	spin_lock(&card->local_addrs4_lock);
	for (i = 0; i < cmd->count; i++) {
		unsigned int key = ipv4_addr_hash(cmd->addrs[i].addr);
		struct qeth_local_addr *addr;
		bool duplicate = false;

		hash_for_each_possible(card->local_addrs4, addr, hnode, key) {
			if (addr->addr.s6_addr32[3] == cmd->addrs[i].addr) {
				duplicate = true;
				break;
			}
		}

		if (duplicate)
			continue;

		addr = kmalloc(sizeof(*addr), GFP_ATOMIC);
		if (!addr) {
			dev_err(&card->gdev->dev,
				"Failed to allocate local addr object. Traffic to %pI4 might suffer.\n",
				&cmd->addrs[i].addr);
			continue;
		}

		ipv6_addr_set(&addr->addr, 0, 0, 0, cmd->addrs[i].addr);
		hash_add_rcu(card->local_addrs4, &addr->hnode, key);
	}
	spin_unlock(&card->local_addrs4_lock);
}

static void qeth_add_local_addrs6(struct qeth_card *card,
				  struct qeth_ipacmd_local_addrs6 *cmd)
{
	unsigned int i;

	if (cmd->addr_length !=
	    sizeof_field(struct qeth_ipacmd_local_addr6, addr)) {
		dev_err_ratelimited(&card->gdev->dev,
				    "Dropped IPv6 ADD LOCAL ADDR event with bad length %u\n",
				    cmd->addr_length);
		return;
	}

	spin_lock(&card->local_addrs6_lock);
	for (i = 0; i < cmd->count; i++) {
		u32 key = ipv6_addr_hash(&cmd->addrs[i].addr);
		struct qeth_local_addr *addr;
		bool duplicate = false;

		hash_for_each_possible(card->local_addrs6, addr, hnode, key) {
			if (ipv6_addr_equal(&addr->addr, &cmd->addrs[i].addr)) {
				duplicate = true;
				break;
			}
		}

		if (duplicate)
			continue;

		addr = kmalloc(sizeof(*addr), GFP_ATOMIC);
		if (!addr) {
			dev_err(&card->gdev->dev,
				"Failed to allocate local addr object. Traffic to %pI6c might suffer.\n",
				&cmd->addrs[i].addr);
			continue;
		}

		addr->addr = cmd->addrs[i].addr;
		hash_add_rcu(card->local_addrs6, &addr->hnode, key);
	}
	spin_unlock(&card->local_addrs6_lock);
}

static void qeth_del_local_addrs4(struct qeth_card *card,
				  struct qeth_ipacmd_local_addrs4 *cmd)
{
	unsigned int i;

	if (cmd->addr_length !=
	    sizeof_field(struct qeth_ipacmd_local_addr4, addr)) {
		dev_err_ratelimited(&card->gdev->dev,
				    "Dropped IPv4 DEL LOCAL ADDR event with bad length %u\n",
				    cmd->addr_length);
		return;
	}

	spin_lock(&card->local_addrs4_lock);
	for (i = 0; i < cmd->count; i++) {
		struct qeth_ipacmd_local_addr4 *addr = &cmd->addrs[i];
		unsigned int key = ipv4_addr_hash(addr->addr);
		struct qeth_local_addr *tmp;

		hash_for_each_possible(card->local_addrs4, tmp, hnode, key) {
			if (tmp->addr.s6_addr32[3] == addr->addr) {
				hash_del_rcu(&tmp->hnode);
				kfree_rcu(tmp, rcu);
				break;
			}
		}
	}
	spin_unlock(&card->local_addrs4_lock);
}

static void qeth_del_local_addrs6(struct qeth_card *card,
				  struct qeth_ipacmd_local_addrs6 *cmd)
{
	unsigned int i;

	if (cmd->addr_length !=
	    sizeof_field(struct qeth_ipacmd_local_addr6, addr)) {
		dev_err_ratelimited(&card->gdev->dev,
				    "Dropped IPv6 DEL LOCAL ADDR event with bad length %u\n",
				    cmd->addr_length);
		return;
	}

	spin_lock(&card->local_addrs6_lock);
	for (i = 0; i < cmd->count; i++) {
		struct qeth_ipacmd_local_addr6 *addr = &cmd->addrs[i];
		u32 key = ipv6_addr_hash(&addr->addr);
		struct qeth_local_addr *tmp;

		hash_for_each_possible(card->local_addrs6, tmp, hnode, key) {
			if (ipv6_addr_equal(&tmp->addr, &addr->addr)) {
				hash_del_rcu(&tmp->hnode);
				kfree_rcu(tmp, rcu);
				break;
			}
		}
	}
	spin_unlock(&card->local_addrs6_lock);
}

782 783 784 785 786 787 788 789 790 791 792 793
static bool qeth_next_hop_is_local_v4(struct qeth_card *card,
				      struct sk_buff *skb)
{
	struct qeth_local_addr *tmp;
	bool is_local = false;
	unsigned int key;
	__be32 next_hop;

	if (hash_empty(card->local_addrs4))
		return false;

	rcu_read_lock();
794 795
	next_hop = qeth_next_hop_v4_rcu(skb,
					qeth_dst_check_rcu(skb, htons(ETH_P_IP)));
796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820
	key = ipv4_addr_hash(next_hop);

	hash_for_each_possible_rcu(card->local_addrs4, tmp, hnode, key) {
		if (tmp->addr.s6_addr32[3] == next_hop) {
			is_local = true;
			break;
		}
	}
	rcu_read_unlock();

	return is_local;
}

static bool qeth_next_hop_is_local_v6(struct qeth_card *card,
				      struct sk_buff *skb)
{
	struct qeth_local_addr *tmp;
	struct in6_addr *next_hop;
	bool is_local = false;
	u32 key;

	if (hash_empty(card->local_addrs6))
		return false;

	rcu_read_lock();
821 822
	next_hop = qeth_next_hop_v6_rcu(skb,
					qeth_dst_check_rcu(skb, htons(ETH_P_IPV6)));
823 824 825 826 827 828 829 830 831 832 833 834 835
	key = ipv6_addr_hash(next_hop);

	hash_for_each_possible_rcu(card->local_addrs6, tmp, hnode, key) {
		if (ipv6_addr_equal(&tmp->addr, next_hop)) {
			is_local = true;
			break;
		}
	}
	rcu_read_unlock();

	return is_local;
}

836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853
static int qeth_debugfs_local_addr_show(struct seq_file *m, void *v)
{
	struct qeth_card *card = m->private;
	struct qeth_local_addr *tmp;
	unsigned int i;

	rcu_read_lock();
	hash_for_each_rcu(card->local_addrs4, i, tmp, hnode)
		seq_printf(m, "%pI4\n", &tmp->addr.s6_addr32[3]);
	hash_for_each_rcu(card->local_addrs6, i, tmp, hnode)
		seq_printf(m, "%pI6c\n", &tmp->addr);
	rcu_read_unlock();

	return 0;
}

DEFINE_SHOW_ATTRIBUTE(qeth_debugfs_local_addr);

854
static void qeth_issue_ipa_msg(struct qeth_ipa_cmd *cmd, int rc,
F
Frank Blaschka 已提交
855 856
		struct qeth_card *card)
{
857
	const char *ipa_name;
858
	int com = cmd->hdr.command;
859

F
Frank Blaschka 已提交
860
	ipa_name = qeth_get_ipa_cmd_name(com);
861

862
	if (rc)
863 864 865
		QETH_DBF_MESSAGE(2, "IPA: %s(%#x) for device %x returned %#x \"%s\"\n",
				 ipa_name, com, CARD_DEVID(card), rc,
				 qeth_get_ipa_msg(rc));
866
	else
867 868
		QETH_DBF_MESSAGE(5, "IPA: %s(%#x) for device %x succeeded\n",
				 ipa_name, com, CARD_DEVID(card));
F
Frank Blaschka 已提交
869 870 871
}

static struct qeth_ipa_cmd *qeth_check_ipa_data(struct qeth_card *card,
872
						struct qeth_ipa_cmd *cmd)
F
Frank Blaschka 已提交
873
{
C
Carsten Otte 已提交
874
	QETH_CARD_TEXT(card, 5, "chkipad");
875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890

	if (IS_IPA_REPLY(cmd)) {
		if (cmd->hdr.command != IPA_CMD_SETCCID &&
		    cmd->hdr.command != IPA_CMD_DELCCID &&
		    cmd->hdr.command != IPA_CMD_MODCCID &&
		    cmd->hdr.command != IPA_CMD_SET_DIAG_ASS)
			qeth_issue_ipa_msg(cmd, cmd->hdr.return_code, card);
		return cmd;
	}

	/* handle unsolicited event: */
	switch (cmd->hdr.command) {
	case IPA_CMD_STOPLAN:
		if (cmd->hdr.return_code == IPA_RC_VEPA_TO_VEB_TRANSITION) {
			dev_err(&card->gdev->dev,
				"Interface %s is down because the adjacent port is no longer in reflective relay mode\n",
J
Julian Wiedmann 已提交
891
				netdev_name(card->dev));
892
			schedule_work(&card->close_dev_work);
F
Frank Blaschka 已提交
893
		} else {
894 895
			dev_warn(&card->gdev->dev,
				 "The link for interface %s on CHPID 0x%X failed\n",
J
Julian Wiedmann 已提交
896
				 netdev_name(card->dev), card->info.chpid);
897
			qeth_issue_ipa_msg(cmd, cmd->hdr.return_code, card);
898
			netif_carrier_off(card->dev);
F
Frank Blaschka 已提交
899
		}
900 901 902 903
		return NULL;
	case IPA_CMD_STARTLAN:
		dev_info(&card->gdev->dev,
			 "The link for %s on CHPID 0x%X has been restored\n",
J
Julian Wiedmann 已提交
904
			 netdev_name(card->dev), card->info.chpid);
905 906 907 908 909 910 911 912 913 914 915 916 917
		if (card->info.hwtrap)
			card->info.hwtrap = 2;
		qeth_schedule_recovery(card);
		return NULL;
	case IPA_CMD_SETBRIDGEPORT_IQD:
	case IPA_CMD_SETBRIDGEPORT_OSA:
	case IPA_CMD_ADDRESS_CHANGE_NOTIF:
		if (card->discipline->control_event_handler(card, cmd))
			return cmd;
		return NULL;
	case IPA_CMD_MODCCID:
		return cmd;
	case IPA_CMD_REGISTER_LOCAL_ADDR:
918 919 920 921 922
		if (cmd->hdr.prot_version == QETH_PROT_IPV4)
			qeth_add_local_addrs4(card, &cmd->data.local_addrs4);
		else if (cmd->hdr.prot_version == QETH_PROT_IPV6)
			qeth_add_local_addrs6(card, &cmd->data.local_addrs6);

923 924 925
		QETH_CARD_TEXT(card, 3, "irla");
		return NULL;
	case IPA_CMD_UNREGISTER_LOCAL_ADDR:
926 927 928 929 930
		if (cmd->hdr.prot_version == QETH_PROT_IPV4)
			qeth_del_local_addrs4(card, &cmd->data.local_addrs4);
		else if (cmd->hdr.prot_version == QETH_PROT_IPV6)
			qeth_del_local_addrs6(card, &cmd->data.local_addrs6);

931 932 933 934 935
		QETH_CARD_TEXT(card, 3, "urla");
		return NULL;
	default:
		QETH_DBF_MESSAGE(2, "Received data is IPA but not a reply!\n");
		return cmd;
F
Frank Blaschka 已提交
936 937 938
	}
}

939
static void qeth_clear_ipacmd_list(struct qeth_card *card)
F
Frank Blaschka 已提交
940
{
941
	struct qeth_cmd_buffer *iob;
F
Frank Blaschka 已提交
942 943
	unsigned long flags;

C
Carsten Otte 已提交
944
	QETH_CARD_TEXT(card, 4, "clipalst");
F
Frank Blaschka 已提交
945 946

	spin_lock_irqsave(&card->lock, flags);
947
	list_for_each_entry(iob, &card->cmd_waiter_list, list_entry)
948
		qeth_notify_cmd(iob, -ECANCELED);
F
Frank Blaschka 已提交
949 950 951
	spin_unlock_irqrestore(&card->lock, flags);
}

952 953
static int qeth_check_idx_response(struct qeth_card *card,
	unsigned char *buffer)
F
Frank Blaschka 已提交
954
{
955
	QETH_DBF_HEX(CTRL, 2, buffer, QETH_DBF_CTRL_LEN);
956
	if ((buffer[2] & QETH_IDX_TERMINATE_MASK) == QETH_IDX_TERMINATE) {
957
		QETH_DBF_MESSAGE(2, "received an IDX TERMINATE with cause code %#04x\n",
958
				 buffer[4]);
C
Carsten Otte 已提交
959 960
		QETH_CARD_TEXT(card, 2, "ckidxres");
		QETH_CARD_TEXT(card, 2, " idxterm");
961 962 963
		QETH_CARD_TEXT_(card, 2, "rc%x", buffer[4]);
		if (buffer[4] == QETH_IDX_TERM_BAD_TRANSPORT ||
		    buffer[4] == QETH_IDX_TERM_BAD_TRANSPORT_VM) {
964
			dev_err(&card->gdev->dev,
965 966
				"The device does not support the configured transport mode\n");
			return -EPROTONOSUPPORT;
967
		}
F
Frank Blaschka 已提交
968 969 970 971 972
		return -EIO;
	}
	return 0;
}

973
void qeth_put_cmd(struct qeth_cmd_buffer *iob)
974 975 976 977 978 979
{
	if (refcount_dec_and_test(&iob->ref_count)) {
		kfree(iob->data);
		kfree(iob);
	}
}
980
EXPORT_SYMBOL_GPL(qeth_put_cmd);
F
Frank Blaschka 已提交
981

982
static void qeth_release_buffer_cb(struct qeth_card *card,
983 984
				   struct qeth_cmd_buffer *iob,
				   unsigned int data_length)
985
{
986
	qeth_put_cmd(iob);
987 988
}

989 990
static void qeth_cancel_cmd(struct qeth_cmd_buffer *iob, int rc)
{
991
	qeth_notify_cmd(iob, rc);
992
	qeth_put_cmd(iob);
F
Frank Blaschka 已提交
993 994
}

995 996 997
struct qeth_cmd_buffer *qeth_alloc_cmd(struct qeth_channel *channel,
				       unsigned int length, unsigned int ccws,
				       long timeout)
998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014
{
	struct qeth_cmd_buffer *iob;

	if (length > QETH_BUFSIZE)
		return NULL;

	iob = kzalloc(sizeof(*iob), GFP_KERNEL);
	if (!iob)
		return NULL;

	iob->data = kzalloc(ALIGN(length, 8) + ccws * sizeof(struct ccw1),
			    GFP_KERNEL | GFP_DMA);
	if (!iob->data) {
		kfree(iob);
		return NULL;
	}

1015 1016
	init_completion(&iob->done);
	spin_lock_init(&iob->lock);
1017
	refcount_set(&iob->ref_count, 1);
1018 1019 1020 1021 1022
	iob->channel = channel;
	iob->timeout = timeout;
	iob->length = length;
	return iob;
}
1023
EXPORT_SYMBOL_GPL(qeth_alloc_cmd);
1024

1025
static void qeth_issue_next_read_cb(struct qeth_card *card,
1026 1027
				    struct qeth_cmd_buffer *iob,
				    unsigned int data_length)
F
Frank Blaschka 已提交
1028
{
1029
	struct qeth_cmd_buffer *request = NULL;
1030
	struct qeth_ipa_cmd *cmd = NULL;
1031
	struct qeth_reply *reply = NULL;
1032
	struct qeth_cmd_buffer *tmp;
F
Frank Blaschka 已提交
1033
	unsigned long flags;
1034
	int rc = 0;
F
Frank Blaschka 已提交
1035

C
Carsten Otte 已提交
1036
	QETH_CARD_TEXT(card, 4, "sndctlcb");
1037 1038 1039 1040 1041 1042
	rc = qeth_check_idx_response(card, iob->data);
	switch (rc) {
	case 0:
		break;
	case -EIO:
		qeth_schedule_recovery(card);
1043
		fallthrough;
1044
	default:
1045
		qeth_clear_ipacmd_list(card);
1046
		goto err_idx;
F
Frank Blaschka 已提交
1047 1048
	}

1049 1050
	cmd = __ipa_reply(iob);
	if (cmd) {
1051
		cmd = qeth_check_ipa_data(card, cmd);
1052 1053 1054 1055 1056 1057 1058
		if (!cmd)
			goto out;
		if (IS_OSN(card) && card->osn_info.assist_cb &&
		    cmd->hdr.command != IPA_CMD_STARTLAN) {
			card->osn_info.assist_cb(card->dev, cmd);
			goto out;
		}
F
Frank Blaschka 已提交
1059 1060
	}

1061
	/* match against pending cmd requests */
F
Frank Blaschka 已提交
1062
	spin_lock_irqsave(&card->lock, flags);
1063
	list_for_each_entry(tmp, &card->cmd_waiter_list, list_entry) {
1064
		if (tmp->match && tmp->match(tmp, iob)) {
1065
			request = tmp;
1066
			/* take the object outside the lock */
1067
			qeth_get_cmd(request);
1068
			break;
F
Frank Blaschka 已提交
1069 1070 1071
		}
	}
	spin_unlock_irqrestore(&card->lock, flags);
1072

1073
	if (!request)
1074 1075
		goto out;

1076
	reply = &request->reply;
1077 1078
	if (!reply->callback) {
		rc = 0;
1079 1080 1081
		goto no_callback;
	}

1082 1083
	spin_lock_irqsave(&request->lock, flags);
	if (request->rc)
1084
		/* Bail out when the requestor has already left: */
1085
		rc = request->rc;
1086 1087 1088
	else
		rc = reply->callback(card, reply, cmd ? (unsigned long)cmd :
							(unsigned long)iob);
1089
	spin_unlock_irqrestore(&request->lock, flags);
1090

1091
no_callback:
1092
	if (rc <= 0)
1093 1094
		qeth_notify_cmd(request, rc);
	qeth_put_cmd(request);
F
Frank Blaschka 已提交
1095 1096 1097 1098
out:
	memcpy(&card->seqno.pdu_hdr_ack,
		QETH_PDU_HEADER_SEQ_NO(iob->data),
		QETH_SEQ_NO_LENGTH);
1099
	__qeth_issue_next_read(card);
1100 1101
err_idx:
	qeth_put_cmd(iob);
F
Frank Blaschka 已提交
1102 1103 1104 1105 1106 1107
}

static int qeth_set_thread_start_bit(struct qeth_card *card,
		unsigned long thread)
{
	unsigned long flags;
1108
	int rc = 0;
F
Frank Blaschka 已提交
1109 1110

	spin_lock_irqsave(&card->thread_mask_lock, flags);
1111 1112 1113 1114 1115 1116
	if (!(card->thread_allowed_mask & thread))
		rc = -EPERM;
	else if (card->thread_start_mask & thread)
		rc = -EBUSY;
	else
		card->thread_start_mask |= thread;
F
Frank Blaschka 已提交
1117
	spin_unlock_irqrestore(&card->thread_mask_lock, flags);
1118 1119

	return rc;
F
Frank Blaschka 已提交
1120 1121
}

1122 1123
static void qeth_clear_thread_start_bit(struct qeth_card *card,
					unsigned long thread)
F
Frank Blaschka 已提交
1124 1125 1126 1127 1128 1129 1130 1131 1132
{
	unsigned long flags;

	spin_lock_irqsave(&card->thread_mask_lock, flags);
	card->thread_start_mask &= ~thread;
	spin_unlock_irqrestore(&card->thread_mask_lock, flags);
	wake_up(&card->wait_q);
}

1133 1134
static void qeth_clear_thread_running_bit(struct qeth_card *card,
					  unsigned long thread)
F
Frank Blaschka 已提交
1135 1136 1137 1138 1139 1140
{
	unsigned long flags;

	spin_lock_irqsave(&card->thread_mask_lock, flags);
	card->thread_running_mask &= ~thread;
	spin_unlock_irqrestore(&card->thread_mask_lock, flags);
1141
	wake_up_all(&card->wait_q);
F
Frank Blaschka 已提交
1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162
}

static int __qeth_do_run_thread(struct qeth_card *card, unsigned long thread)
{
	unsigned long flags;
	int rc = 0;

	spin_lock_irqsave(&card->thread_mask_lock, flags);
	if (card->thread_start_mask & thread) {
		if ((card->thread_allowed_mask & thread) &&
		    !(card->thread_running_mask & thread)) {
			rc = 1;
			card->thread_start_mask &= ~thread;
			card->thread_running_mask |= thread;
		} else
			rc = -EPERM;
	}
	spin_unlock_irqrestore(&card->thread_mask_lock, flags);
	return rc;
}

1163
static int qeth_do_run_thread(struct qeth_card *card, unsigned long thread)
F
Frank Blaschka 已提交
1164 1165 1166 1167 1168 1169 1170 1171
{
	int rc = 0;

	wait_event(card->wait_q,
		   (rc = __qeth_do_run_thread(card, thread)) >= 0);
	return rc;
}

1172
int qeth_schedule_recovery(struct qeth_card *card)
F
Frank Blaschka 已提交
1173
{
1174 1175
	int rc;

C
Carsten Otte 已提交
1176
	QETH_CARD_TEXT(card, 2, "startrec");
1177 1178 1179

	rc = qeth_set_thread_start_bit(card, QETH_RECOVER_THREAD);
	if (!rc)
F
Frank Blaschka 已提交
1180
		schedule_work(&card->kernel_thread_starter);
1181 1182

	return rc;
F
Frank Blaschka 已提交
1183 1184
}

1185 1186
static int qeth_get_problem(struct qeth_card *card, struct ccw_device *cdev,
			    struct irb *irb)
F
Frank Blaschka 已提交
1187 1188 1189 1190 1191
{
	int dstat, cstat;
	char *sense;

	sense = (char *) irb->ecw;
1192 1193
	cstat = irb->scsw.cmd.cstat;
	dstat = irb->scsw.cmd.dstat;
F
Frank Blaschka 已提交
1194 1195 1196 1197

	if (cstat & (SCHN_STAT_CHN_CTRL_CHK | SCHN_STAT_INTF_CTRL_CHK |
		     SCHN_STAT_CHN_DATA_CHK | SCHN_STAT_CHAIN_CHECK |
		     SCHN_STAT_PROT_CHECK | SCHN_STAT_PROG_CHECK)) {
C
Carsten Otte 已提交
1198
		QETH_CARD_TEXT(card, 2, "CGENCHK");
1199 1200
		dev_warn(&cdev->dev, "The qeth device driver "
			"failed to recover an error on the device\n");
1201 1202
		QETH_DBF_MESSAGE(2, "check on channel %x with dstat=%#x, cstat=%#x\n",
				 CCW_DEVID(cdev), dstat, cstat);
F
Frank Blaschka 已提交
1203 1204
		print_hex_dump(KERN_WARNING, "qeth: irb ", DUMP_PREFIX_OFFSET,
				16, 1, irb, 64, 1);
1205
		return -EIO;
F
Frank Blaschka 已提交
1206 1207 1208 1209 1210
	}

	if (dstat & DEV_STAT_UNIT_CHECK) {
		if (sense[SENSE_RESETTING_EVENT_BYTE] &
		    SENSE_RESETTING_EVENT_FLAG) {
C
Carsten Otte 已提交
1211
			QETH_CARD_TEXT(card, 2, "REVIND");
1212
			return -EIO;
F
Frank Blaschka 已提交
1213 1214 1215
		}
		if (sense[SENSE_COMMAND_REJECT_BYTE] &
		    SENSE_COMMAND_REJECT_FLAG) {
C
Carsten Otte 已提交
1216
			QETH_CARD_TEXT(card, 2, "CMDREJi");
1217
			return -EIO;
F
Frank Blaschka 已提交
1218 1219
		}
		if ((sense[2] == 0xaf) && (sense[3] == 0xfe)) {
C
Carsten Otte 已提交
1220
			QETH_CARD_TEXT(card, 2, "AFFE");
1221
			return -EIO;
F
Frank Blaschka 已提交
1222 1223
		}
		if ((!sense[0]) && (!sense[1]) && (!sense[2]) && (!sense[3])) {
C
Carsten Otte 已提交
1224
			QETH_CARD_TEXT(card, 2, "ZEROSEN");
F
Frank Blaschka 已提交
1225 1226
			return 0;
		}
C
Carsten Otte 已提交
1227
		QETH_CARD_TEXT(card, 2, "DGENCHK");
1228
		return -EIO;
F
Frank Blaschka 已提交
1229 1230 1231 1232
	}
	return 0;
}

1233
static int qeth_check_irb_error(struct qeth_card *card, struct ccw_device *cdev,
1234
				struct irb *irb)
F
Frank Blaschka 已提交
1235
{
1236
	if (!IS_ERR(irb))
F
Frank Blaschka 已提交
1237 1238 1239 1240
		return 0;

	switch (PTR_ERR(irb)) {
	case -EIO:
1241 1242
		QETH_DBF_MESSAGE(2, "i/o-error on channel %x\n",
				 CCW_DEVID(cdev));
C
Carsten Otte 已提交
1243 1244
		QETH_CARD_TEXT(card, 2, "ckirberr");
		QETH_CARD_TEXT_(card, 2, "  rc%d", -EIO);
1245
		return -EIO;
F
Frank Blaschka 已提交
1246
	case -ETIMEDOUT:
1247 1248
		dev_warn(&cdev->dev, "A hardware operation timed out"
			" on the device\n");
C
Carsten Otte 已提交
1249 1250
		QETH_CARD_TEXT(card, 2, "ckirberr");
		QETH_CARD_TEXT_(card, 2, "  rc%d", -ETIMEDOUT);
1251
		return -ETIMEDOUT;
F
Frank Blaschka 已提交
1252
	default:
1253 1254
		QETH_DBF_MESSAGE(2, "unknown error %ld on channel %x\n",
				 PTR_ERR(irb), CCW_DEVID(cdev));
C
Carsten Otte 已提交
1255 1256
		QETH_CARD_TEXT(card, 2, "ckirberr");
		QETH_CARD_TEXT(card, 2, "  rc???");
1257
		return PTR_ERR(irb);
F
Frank Blaschka 已提交
1258 1259 1260 1261 1262 1263 1264 1265
	}
}

static void qeth_irq(struct ccw_device *cdev, unsigned long intparm,
		struct irb *irb)
{
	int rc;
	int cstat, dstat;
1266
	struct qeth_cmd_buffer *iob = NULL;
1267
	struct ccwgroup_device *gdev;
F
Frank Blaschka 已提交
1268 1269 1270
	struct qeth_channel *channel;
	struct qeth_card *card;

1271 1272 1273
	/* while we hold the ccwdev lock, this stays valid: */
	gdev = dev_get_drvdata(&cdev->dev);
	card = dev_get_drvdata(&gdev->dev);
F
Frank Blaschka 已提交
1274

C
Carsten Otte 已提交
1275 1276
	QETH_CARD_TEXT(card, 5, "irq");

F
Frank Blaschka 已提交
1277 1278
	if (card->read.ccwdev == cdev) {
		channel = &card->read;
C
Carsten Otte 已提交
1279
		QETH_CARD_TEXT(card, 5, "read");
F
Frank Blaschka 已提交
1280 1281
	} else if (card->write.ccwdev == cdev) {
		channel = &card->write;
C
Carsten Otte 已提交
1282
		QETH_CARD_TEXT(card, 5, "write");
F
Frank Blaschka 已提交
1283 1284
	} else {
		channel = &card->data;
C
Carsten Otte 已提交
1285
		QETH_CARD_TEXT(card, 5, "data");
F
Frank Blaschka 已提交
1286
	}
1287

1288 1289 1290 1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302
	if (intparm == 0) {
		QETH_CARD_TEXT(card, 5, "irqunsol");
	} else if ((addr_t)intparm != (addr_t)channel->active_cmd) {
		QETH_CARD_TEXT(card, 5, "irqunexp");

		dev_err(&cdev->dev,
			"Received IRQ with intparm %lx, expected %px\n",
			intparm, channel->active_cmd);
		if (channel->active_cmd)
			qeth_cancel_cmd(channel->active_cmd, -EIO);
	} else {
		iob = (struct qeth_cmd_buffer *) (addr_t)intparm;
	}

	channel->active_cmd = NULL;
1303
	qeth_unlock_channel(card, channel);
1304

1305
	rc = qeth_check_irb_error(card, cdev, irb);
1306
	if (rc) {
1307 1308
		/* IO was terminated, free its resources. */
		if (iob)
1309
			qeth_cancel_cmd(iob, rc);
1310 1311 1312
		return;
	}

1313
	if (irb->scsw.cmd.fctl & SCSW_FCTL_CLEAR_FUNC) {
F
Frank Blaschka 已提交
1314
		channel->state = CH_STATE_STOPPED;
1315 1316
		wake_up(&card->wait_q);
	}
F
Frank Blaschka 已提交
1317

1318
	if (irb->scsw.cmd.fctl & SCSW_FCTL_HALT_FUNC) {
F
Frank Blaschka 已提交
1319
		channel->state = CH_STATE_HALTED;
1320 1321
		wake_up(&card->wait_q);
	}
F
Frank Blaschka 已提交
1322

1323 1324 1325 1326
	if (iob && (irb->scsw.cmd.fctl & (SCSW_FCTL_CLEAR_FUNC |
					  SCSW_FCTL_HALT_FUNC))) {
		qeth_cancel_cmd(iob, -ECANCELED);
		iob = NULL;
F
Frank Blaschka 已提交
1327
	}
1328 1329 1330 1331

	cstat = irb->scsw.cmd.cstat;
	dstat = irb->scsw.cmd.dstat;

F
Frank Blaschka 已提交
1332 1333 1334 1335
	if ((dstat & DEV_STAT_UNIT_EXCEP) ||
	    (dstat & DEV_STAT_UNIT_CHECK) ||
	    (cstat)) {
		if (irb->esw.esw0.erw.cons) {
1336 1337 1338
			dev_warn(&channel->ccwdev->dev,
				"The qeth device driver failed to recover "
				"an error on the device\n");
1339 1340 1341
			QETH_DBF_MESSAGE(2, "sense data available on channel %x: cstat %#X dstat %#X\n",
					 CCW_DEVID(channel->ccwdev), cstat,
					 dstat);
F
Frank Blaschka 已提交
1342 1343 1344 1345 1346
			print_hex_dump(KERN_WARNING, "qeth: irb ",
				DUMP_PREFIX_OFFSET, 16, 1, irb, 32, 1);
			print_hex_dump(KERN_WARNING, "qeth: sense data ",
				DUMP_PREFIX_OFFSET, 16, 1, irb->ecw, 32, 1);
		}
1347

1348
		rc = qeth_get_problem(card, cdev, irb);
F
Frank Blaschka 已提交
1349
		if (rc) {
1350
			card->read_or_write_problem = 1;
1351
			if (iob)
1352
				qeth_cancel_cmd(iob, rc);
1353
			qeth_clear_ipacmd_list(card);
F
Frank Blaschka 已提交
1354
			qeth_schedule_recovery(card);
1355
			return;
F
Frank Blaschka 已提交
1356 1357 1358
		}
	}

1359 1360 1361 1362
	if (iob) {
		/* sanity check: */
		if (irb->scsw.cmd.count > iob->length) {
			qeth_cancel_cmd(iob, -EIO);
1363
			return;
1364 1365 1366 1367 1368
		}
		if (iob->callback)
			iob->callback(card, iob,
				      iob->length - irb->scsw.cmd.count);
	}
F
Frank Blaschka 已提交
1369 1370
}

1371
static void qeth_notify_skbs(struct qeth_qdio_out_q *q,
1372
		struct qeth_qdio_out_buffer *buf,
1373
		enum iucv_tx_notify notification)
F
Frank Blaschka 已提交
1374 1375 1376
{
	struct sk_buff *skb;

1377
	skb_queue_walk(&buf->skb_list, skb) {
1378 1379
		struct sock *sk = skb->sk;

1380 1381
		QETH_CARD_TEXT_(q->card, 5, "skbn%d", notification);
		QETH_CARD_TEXT_(q->card, 5, "%lx", (long) skb);
1382 1383
		if (sk && sk->sk_family == PF_IUCV)
			iucv_sk(sk)->sk_txnotify(sk, notification);
1384 1385 1386
	}
}

1387 1388
static void qeth_tx_complete_buf(struct qeth_qdio_out_buffer *buf, bool error,
				 int budget)
1389
{
1390
	struct qeth_qdio_out_q *queue = buf->q;
1391 1392
	struct sk_buff *skb;

1393 1394 1395 1396 1397 1398
	/* Empty buffer? */
	if (buf->next_element_to_fill == 0)
		return;

	QETH_TXQ_STAT_INC(queue, bufs);
	QETH_TXQ_STAT_ADD(queue, buf_elements, buf->next_element_to_fill);
1399 1400 1401 1402 1403 1404 1405
	if (error) {
		QETH_TXQ_STAT_ADD(queue, tx_errors, buf->frames);
	} else {
		QETH_TXQ_STAT_ADD(queue, tx_packets, buf->frames);
		QETH_TXQ_STAT_ADD(queue, tx_bytes, buf->bytes);
	}

1406 1407 1408 1409 1410 1411
	while ((skb = __skb_dequeue(&buf->skb_list)) != NULL) {
		unsigned int bytes = qdisc_pkt_len(skb);
		bool is_tso = skb_is_gso(skb);
		unsigned int packets;

		packets = is_tso ? skb_shinfo(skb)->gso_segs : 1;
1412
		if (!error) {
1413 1414 1415 1416 1417 1418 1419 1420 1421
			if (skb->ip_summed == CHECKSUM_PARTIAL)
				QETH_TXQ_STAT_ADD(queue, skbs_csum, packets);
			if (skb_is_nonlinear(skb))
				QETH_TXQ_STAT_INC(queue, skbs_sg);
			if (is_tso) {
				QETH_TXQ_STAT_INC(queue, skbs_tso);
				QETH_TXQ_STAT_ADD(queue, tso_bytes, bytes);
			}
		}
1422

1423
		napi_consume_skb(skb, budget);
1424
	}
1425 1426 1427
}

static void qeth_clear_output_buffer(struct qeth_qdio_out_q *queue,
1428
				     struct qeth_qdio_out_buffer *buf,
1429
				     bool error, int budget)
1430 1431 1432 1433 1434 1435 1436
{
	int i;

	/* is PCI flag set on buffer? */
	if (buf->buffer->element[0].sflags & SBAL_SFLAGS0_PCI_REQ)
		atomic_dec(&queue->set_pci_flags_count);

1437
	qeth_tx_complete_buf(buf, error, budget);
1438

1439
	for (i = 0; i < queue->max_elements; ++i) {
1440 1441 1442 1443
		void *data = phys_to_virt(buf->buffer->element[i].addr);

		if (data && buf->is_header[i])
			kmem_cache_free(qeth_core_header_cache, data);
1444
		buf->is_header[i] = 0;
F
Frank Blaschka 已提交
1445
	}
1446

1447
	qeth_scrub_qdio_buffer(buf->buffer, queue->max_elements);
F
Frank Blaschka 已提交
1448
	buf->next_element_to_fill = 0;
1449
	buf->frames = 0;
1450
	buf->bytes = 0;
1451
	atomic_set(&buf->state, QETH_QDIO_BUF_EMPTY);
1452 1453
}

1454 1455 1456 1457 1458 1459 1460 1461 1462 1463 1464
static void qeth_tx_complete_pending_bufs(struct qeth_card *card,
					  struct qeth_qdio_out_q *queue,
					  bool drain)
{
	struct qeth_qdio_out_buffer *buf, *tmp;

	list_for_each_entry_safe(buf, tmp, &queue->pending_bufs, list_entry) {
		if (drain || atomic_read(&buf->state) == QETH_QDIO_BUF_EMPTY) {
			QETH_CARD_TEXT(card, 5, "fp");
			QETH_CARD_TEXT_(card, 5, "%lx", (long) buf);

1465 1466 1467
			if (drain)
				qeth_notify_skbs(queue, buf,
						 TX_NOTIFY_GENERALERROR);
1468 1469 1470 1471 1472 1473 1474 1475
			qeth_tx_complete_buf(buf, drain, 0);

			list_del(&buf->list_entry);
			kmem_cache_free(qeth_qdio_outbuf_cache, buf);
		}
	}
}

1476
static void qeth_drain_output_queue(struct qeth_qdio_out_q *q, bool free)
1477 1478 1479
{
	int j;

1480 1481
	qeth_tx_complete_pending_bufs(q->card, q, true);

1482 1483 1484
	for (j = 0; j < QDIO_MAX_BUFFERS_PER_Q; ++j) {
		if (!q->bufs[j])
			continue;
1485

1486
		qeth_clear_output_buffer(q, q->bufs[j], true, 0);
1487 1488 1489 1490 1491
		if (free) {
			kmem_cache_free(qeth_qdio_outbuf_cache, q->bufs[j]);
			q->bufs[j] = NULL;
		}
	}
F
Frank Blaschka 已提交
1492 1493
}

1494
static void qeth_drain_output_queues(struct qeth_card *card)
F
Frank Blaschka 已提交
1495
{
1496
	int i;
F
Frank Blaschka 已提交
1497

C
Carsten Otte 已提交
1498
	QETH_CARD_TEXT(card, 2, "clearqdbf");
F
Frank Blaschka 已提交
1499
	/* clear outbound buffers to free skbs */
1500
	for (i = 0; i < card->qdio.no_out_queues; ++i) {
1501 1502
		if (card->qdio.out_qs[i])
			qeth_drain_output_queue(card->qdio.out_qs[i], false);
1503
	}
F
Frank Blaschka 已提交
1504 1505
}

1506
static void qeth_osa_set_output_queues(struct qeth_card *card, bool single)
1507
{
1508
	unsigned int max = single ? 1 : card->dev->num_tx_queues;
1509

1510
	if (card->qdio.no_out_queues == max)
1511
		return;
1512

1513
	if (atomic_read(&card->qdio.state) != QETH_QDIO_UNINITIALIZED)
1514
		qeth_free_qdio_queues(card);
1515

1516
	if (max == 1 && card->qdio.do_prio_queueing != QETH_PRIOQ_DEFAULT)
1517 1518
		dev_info(&card->gdev->dev, "Priority Queueing not supported\n");

1519
	card->qdio.no_out_queues = max;
1520 1521
}

1522
static int qeth_update_from_chp_desc(struct qeth_card *card)
F
Frank Blaschka 已提交
1523 1524
{
	struct ccw_device *ccwdev;
1525
	struct channel_path_desc_fmt0 *chp_dsc;
F
Frank Blaschka 已提交
1526

1527
	QETH_CARD_TEXT(card, 2, "chp_desc");
F
Frank Blaschka 已提交
1528 1529

	ccwdev = card->data.ccwdev;
1530 1531
	chp_dsc = ccw_device_get_chp_desc(ccwdev, 0);
	if (!chp_dsc)
1532
		return -ENOMEM;
1533 1534 1535

	card->info.func_level = 0x4100 + chp_dsc->desc;

1536 1537
	if (IS_OSD(card) || IS_OSX(card))
		/* CHPP field bit 6 == 1 -> single queue */
1538
		qeth_osa_set_output_queues(card, chp_dsc->chpp & 0x02);
1539

1540
	kfree(chp_dsc);
1541 1542
	QETH_CARD_TEXT_(card, 2, "nr:%x", card->qdio.no_out_queues);
	QETH_CARD_TEXT_(card, 2, "lvl:%02x", card->info.func_level);
1543
	return 0;
F
Frank Blaschka 已提交
1544 1545 1546 1547
}

static void qeth_init_qdio_info(struct qeth_card *card)
{
1548
	QETH_CARD_TEXT(card, 4, "intqdinf");
F
Frank Blaschka 已提交
1549
	atomic_set(&card->qdio.state, QETH_QDIO_UNINITIALIZED);
1550 1551 1552
	card->qdio.do_prio_queueing = QETH_PRIOQ_DEFAULT;
	card->qdio.default_out_queue = QETH_DEFAULT_QUEUE;

F
Frank Blaschka 已提交
1553
	/* inbound */
1554
	card->qdio.no_in_queues = 1;
F
Frank Blaschka 已提交
1555
	card->qdio.in_buf_size = QETH_IN_BUF_SIZE_DEFAULT;
1556
	if (IS_IQD(card))
1557 1558 1559
		card->qdio.init_pool.buf_count = QETH_IN_BUF_COUNT_HSDEFAULT;
	else
		card->qdio.init_pool.buf_count = QETH_IN_BUF_COUNT_DEFAULT;
F
Frank Blaschka 已提交
1560 1561 1562 1563 1564
	card->qdio.in_buf_pool.buf_count = card->qdio.init_pool.buf_count;
	INIT_LIST_HEAD(&card->qdio.in_buf_pool.entry_list);
	INIT_LIST_HEAD(&card->qdio.init_pool.entry_list);
}

1565
static void qeth_set_initial_options(struct qeth_card *card)
F
Frank Blaschka 已提交
1566 1567 1568
{
	card->options.route4.type = NO_ROUTER;
	card->options.route6.type = NO_ROUTER;
E
Einar Lueck 已提交
1569
	card->options.isolation = ISOLATION_MODE_NONE;
1570
	card->options.cq = QETH_CQ_DISABLED;
1571
	card->options.layer = QETH_DISCIPLINE_UNDETERMINED;
F
Frank Blaschka 已提交
1572 1573 1574 1575 1576 1577 1578 1579
}

static int qeth_do_start_thread(struct qeth_card *card, unsigned long thread)
{
	unsigned long flags;
	int rc = 0;

	spin_lock_irqsave(&card->thread_mask_lock, flags);
C
Carsten Otte 已提交
1580
	QETH_CARD_TEXT_(card, 4, "  %02x%02x%02x",
F
Frank Blaschka 已提交
1581 1582 1583 1584 1585 1586 1587 1588
			(u8) card->thread_start_mask,
			(u8) card->thread_allowed_mask,
			(u8) card->thread_running_mask);
	rc = (card->thread_start_mask & thread);
	spin_unlock_irqrestore(&card->thread_mask_lock, flags);
	return rc;
}

1589
static int qeth_do_reset(void *data);
F
Frank Blaschka 已提交
1590 1591
static void qeth_start_kernel_thread(struct work_struct *work)
{
1592
	struct task_struct *ts;
F
Frank Blaschka 已提交
1593 1594
	struct qeth_card *card = container_of(work, struct qeth_card,
					kernel_thread_starter);
1595
	QETH_CARD_TEXT(card, 2, "strthrd");
F
Frank Blaschka 已提交
1596 1597 1598 1599

	if (card->read.state != CH_STATE_UP &&
	    card->write.state != CH_STATE_UP)
		return;
1600
	if (qeth_do_start_thread(card, QETH_RECOVER_THREAD)) {
1601
		ts = kthread_run(qeth_do_reset, card, "qeth_recover");
1602 1603 1604 1605 1606 1607
		if (IS_ERR(ts)) {
			qeth_clear_thread_start_bit(card, QETH_RECOVER_THREAD);
			qeth_clear_thread_running_bit(card,
				QETH_RECOVER_THREAD);
		}
	}
F
Frank Blaschka 已提交
1608 1609
}

1610
static void qeth_buffer_reclaim_work(struct work_struct *);
1611
static void qeth_setup_card(struct qeth_card *card)
F
Frank Blaschka 已提交
1612
{
1613
	QETH_CARD_TEXT(card, 2, "setupcrd");
F
Frank Blaschka 已提交
1614

1615
	card->info.type = CARD_RDEV(card)->id.driver_info;
F
Frank Blaschka 已提交
1616 1617 1618
	card->state = CARD_STATE_DOWN;
	spin_lock_init(&card->lock);
	spin_lock_init(&card->thread_mask_lock);
1619
	mutex_init(&card->conf_mutex);
1620
	mutex_init(&card->discipline_mutex);
F
Frank Blaschka 已提交
1621 1622 1623
	INIT_WORK(&card->kernel_thread_starter, qeth_start_kernel_thread);
	INIT_LIST_HEAD(&card->cmd_waiter_list);
	init_waitqueue_head(&card->wait_q);
1624
	qeth_set_initial_options(card);
F
Frank Blaschka 已提交
1625 1626 1627
	/* IP address takeover */
	INIT_LIST_HEAD(&card->ipato.entries);
	qeth_init_qdio_info(card);
1628
	INIT_DELAYED_WORK(&card->buffer_reclaim_work, qeth_buffer_reclaim_work);
S
Stefan Raspl 已提交
1629
	INIT_WORK(&card->close_dev_work, qeth_close_dev_handler);
1630
	hash_init(card->rx_mode_addrs);
1631 1632 1633 1634
	hash_init(card->local_addrs4);
	hash_init(card->local_addrs6);
	spin_lock_init(&card->local_addrs4_lock);
	spin_lock_init(&card->local_addrs6_lock);
F
Frank Blaschka 已提交
1635 1636
}

1637 1638 1639 1640
static void qeth_core_sl_print(struct seq_file *m, struct service_level *slr)
{
	struct qeth_card *card = container_of(slr, struct qeth_card,
					qeth_service_level);
1641 1642 1643
	if (card->info.mcl_level[0])
		seq_printf(m, "qeth: %s firmware level %s\n",
			CARD_BUS_ID(card), card->info.mcl_level);
1644 1645
}

1646
static struct qeth_card *qeth_alloc_card(struct ccwgroup_device *gdev)
F
Frank Blaschka 已提交
1647 1648 1649
{
	struct qeth_card *card;

1650
	QETH_DBF_TEXT(SETUP, 2, "alloccrd");
1651
	card = kzalloc(sizeof(*card), GFP_KERNEL);
F
Frank Blaschka 已提交
1652
	if (!card)
1653
		goto out;
1654
	QETH_DBF_HEX(SETUP, 2, &card, sizeof(void *));
1655 1656

	card->gdev = gdev;
1657
	dev_set_drvdata(&gdev->dev, card);
1658 1659 1660
	CARD_RDEV(card) = gdev->cdev[0];
	CARD_WDEV(card) = gdev->cdev[1];
	CARD_DDEV(card) = gdev->cdev[2];
1661

1662 1663
	card->event_wq = alloc_ordered_workqueue("%s_event", 0,
						 dev_name(&gdev->dev));
1664 1665
	if (!card->event_wq)
		goto out_wq;
1666 1667 1668 1669

	card->read_cmd = qeth_alloc_cmd(&card->read, QETH_BUFSIZE, 1, 0);
	if (!card->read_cmd)
		goto out_read_cmd;
1670

1671 1672 1673 1674 1675
	card->debugfs = debugfs_create_dir(dev_name(&gdev->dev),
					   qeth_debugfs_root);
	debugfs_create_file("local_addrs", 0400, card->debugfs, card,
			    &qeth_debugfs_local_addr_fops);

1676 1677
	card->qeth_service_level.seq_print = qeth_core_sl_print;
	register_service_level(&card->qeth_service_level);
F
Frank Blaschka 已提交
1678
	return card;
1679

1680
out_read_cmd:
1681 1682
	destroy_workqueue(card->event_wq);
out_wq:
1683
	dev_set_drvdata(&gdev->dev, NULL);
1684 1685 1686
	kfree(card);
out:
	return NULL;
F
Frank Blaschka 已提交
1687 1688
}

1689 1690
static int qeth_clear_channel(struct qeth_card *card,
			      struct qeth_channel *channel)
F
Frank Blaschka 已提交
1691 1692 1693
{
	int rc;

C
Carsten Otte 已提交
1694
	QETH_CARD_TEXT(card, 3, "clearch");
J
Julian Wiedmann 已提交
1695
	spin_lock_irq(get_ccwdev_lock(channel->ccwdev));
1696
	rc = ccw_device_clear(channel->ccwdev, (addr_t)channel->active_cmd);
J
Julian Wiedmann 已提交
1697
	spin_unlock_irq(get_ccwdev_lock(channel->ccwdev));
F
Frank Blaschka 已提交
1698 1699 1700 1701 1702 1703 1704 1705 1706 1707 1708 1709 1710

	if (rc)
		return rc;
	rc = wait_event_interruptible_timeout(card->wait_q,
			channel->state == CH_STATE_STOPPED, QETH_TIMEOUT);
	if (rc == -ERESTARTSYS)
		return rc;
	if (channel->state != CH_STATE_STOPPED)
		return -ETIME;
	channel->state = CH_STATE_DOWN;
	return 0;
}

1711 1712
static int qeth_halt_channel(struct qeth_card *card,
			     struct qeth_channel *channel)
F
Frank Blaschka 已提交
1713 1714 1715
{
	int rc;

C
Carsten Otte 已提交
1716
	QETH_CARD_TEXT(card, 3, "haltch");
J
Julian Wiedmann 已提交
1717
	spin_lock_irq(get_ccwdev_lock(channel->ccwdev));
1718
	rc = ccw_device_halt(channel->ccwdev, (addr_t)channel->active_cmd);
J
Julian Wiedmann 已提交
1719
	spin_unlock_irq(get_ccwdev_lock(channel->ccwdev));
F
Frank Blaschka 已提交
1720 1721 1722 1723 1724 1725 1726 1727 1728 1729 1730 1731

	if (rc)
		return rc;
	rc = wait_event_interruptible_timeout(card->wait_q,
			channel->state == CH_STATE_HALTED, QETH_TIMEOUT);
	if (rc == -ERESTARTSYS)
		return rc;
	if (channel->state != CH_STATE_HALTED)
		return -ETIME;
	return 0;
}

1732
static int qeth_stop_channel(struct qeth_channel *channel)
1733 1734 1735 1736 1737 1738 1739 1740 1741 1742 1743 1744
{
	struct ccw_device *cdev = channel->ccwdev;
	int rc;

	rc = ccw_device_set_offline(cdev);

	spin_lock_irq(get_ccwdev_lock(cdev));
	if (channel->active_cmd) {
		dev_err(&cdev->dev, "Stopped channel while cmd %px was still active\n",
			channel->active_cmd);
		channel->active_cmd = NULL;
	}
1745
	cdev->handler = NULL;
1746 1747 1748 1749 1750
	spin_unlock_irq(get_ccwdev_lock(cdev));

	return rc;
}

1751 1752 1753 1754 1755 1756 1757 1758 1759 1760 1761 1762 1763 1764 1765 1766 1767 1768 1769 1770 1771 1772 1773 1774 1775
static int qeth_start_channel(struct qeth_channel *channel)
{
	struct ccw_device *cdev = channel->ccwdev;
	int rc;

	channel->state = CH_STATE_DOWN;
	atomic_set(&channel->irq_pending, 0);

	spin_lock_irq(get_ccwdev_lock(cdev));
	cdev->handler = qeth_irq;
	spin_unlock_irq(get_ccwdev_lock(cdev));

	rc = ccw_device_set_online(cdev);
	if (rc)
		goto err;

	return 0;

err:
	spin_lock_irq(get_ccwdev_lock(cdev));
	cdev->handler = NULL;
	spin_unlock_irq(get_ccwdev_lock(cdev));
	return rc;
}

F
Frank Blaschka 已提交
1776 1777 1778 1779
static int qeth_halt_channels(struct qeth_card *card)
{
	int rc1 = 0, rc2 = 0, rc3 = 0;

C
Carsten Otte 已提交
1780
	QETH_CARD_TEXT(card, 3, "haltchs");
1781 1782 1783
	rc1 = qeth_halt_channel(card, &card->read);
	rc2 = qeth_halt_channel(card, &card->write);
	rc3 = qeth_halt_channel(card, &card->data);
F
Frank Blaschka 已提交
1784 1785 1786 1787 1788 1789 1790 1791 1792 1793 1794
	if (rc1)
		return rc1;
	if (rc2)
		return rc2;
	return rc3;
}

static int qeth_clear_channels(struct qeth_card *card)
{
	int rc1 = 0, rc2 = 0, rc3 = 0;

C
Carsten Otte 已提交
1795
	QETH_CARD_TEXT(card, 3, "clearchs");
1796 1797 1798
	rc1 = qeth_clear_channel(card, &card->read);
	rc2 = qeth_clear_channel(card, &card->write);
	rc3 = qeth_clear_channel(card, &card->data);
F
Frank Blaschka 已提交
1799 1800 1801 1802 1803 1804 1805 1806 1807 1808 1809
	if (rc1)
		return rc1;
	if (rc2)
		return rc2;
	return rc3;
}

static int qeth_clear_halt_card(struct qeth_card *card, int halt)
{
	int rc = 0;

C
Carsten Otte 已提交
1810
	QETH_CARD_TEXT(card, 3, "clhacrd");
F
Frank Blaschka 已提交
1811 1812 1813 1814 1815 1816 1817 1818

	if (halt)
		rc = qeth_halt_channels(card);
	if (rc)
		return rc;
	return qeth_clear_channels(card);
}

1819
static int qeth_qdio_clear_card(struct qeth_card *card, int use_halt)
F
Frank Blaschka 已提交
1820 1821 1822
{
	int rc = 0;

C
Carsten Otte 已提交
1823
	QETH_CARD_TEXT(card, 3, "qdioclr");
F
Frank Blaschka 已提交
1824 1825 1826
	switch (atomic_cmpxchg(&card->qdio.state, QETH_QDIO_ESTABLISHED,
		QETH_QDIO_CLEANING)) {
	case QETH_QDIO_ESTABLISHED:
1827
		if (IS_IQD(card))
J
Jan Glauber 已提交
1828
			rc = qdio_shutdown(CARD_DDEV(card),
F
Frank Blaschka 已提交
1829 1830
				QDIO_FLAG_CLEANUP_USING_HALT);
		else
J
Jan Glauber 已提交
1831
			rc = qdio_shutdown(CARD_DDEV(card),
F
Frank Blaschka 已提交
1832 1833
				QDIO_FLAG_CLEANUP_USING_CLEAR);
		if (rc)
C
Carsten Otte 已提交
1834
			QETH_CARD_TEXT_(card, 3, "1err%d", rc);
F
Frank Blaschka 已提交
1835 1836 1837 1838 1839 1840 1841 1842 1843
		atomic_set(&card->qdio.state, QETH_QDIO_ALLOCATED);
		break;
	case QETH_QDIO_CLEANING:
		return rc;
	default:
		break;
	}
	rc = qeth_clear_halt_card(card, use_halt);
	if (rc)
C
Carsten Otte 已提交
1844
		QETH_CARD_TEXT_(card, 3, "2err%d", rc);
F
Frank Blaschka 已提交
1845 1846 1847
	return rc;
}

1848 1849 1850 1851 1852 1853 1854 1855 1856
static enum qeth_discipline_id qeth_vm_detect_layer(struct qeth_card *card)
{
	enum qeth_discipline_id disc = QETH_DISCIPLINE_UNDETERMINED;
	struct diag26c_vnic_resp *response = NULL;
	struct diag26c_vnic_req *request = NULL;
	struct ccw_dev_id id;
	char userid[80];
	int rc = 0;

1857
	QETH_CARD_TEXT(card, 2, "vmlayer");
1858 1859 1860 1861 1862 1863 1864 1865 1866 1867 1868 1869 1870 1871 1872 1873 1874 1875 1876 1877 1878 1879 1880 1881 1882 1883 1884 1885 1886 1887 1888 1889 1890 1891 1892 1893 1894 1895 1896 1897 1898 1899

	cpcmd("QUERY USERID", userid, sizeof(userid), &rc);
	if (rc)
		goto out;

	request = kzalloc(sizeof(*request), GFP_KERNEL | GFP_DMA);
	response = kzalloc(sizeof(*response), GFP_KERNEL | GFP_DMA);
	if (!request || !response) {
		rc = -ENOMEM;
		goto out;
	}

	ccw_device_get_id(CARD_RDEV(card), &id);
	request->resp_buf_len = sizeof(*response);
	request->resp_version = DIAG26C_VERSION6_VM65918;
	request->req_format = DIAG26C_VNIC_INFO;
	ASCEBC(userid, 8);
	memcpy(&request->sys_name, userid, 8);
	request->devno = id.devno;

	QETH_DBF_HEX(CTRL, 2, request, sizeof(*request));
	rc = diag26c(request, response, DIAG26C_PORT_VNIC);
	QETH_DBF_HEX(CTRL, 2, request, sizeof(*request));
	if (rc)
		goto out;
	QETH_DBF_HEX(CTRL, 2, response, sizeof(*response));

	if (request->resp_buf_len < sizeof(*response) ||
	    response->version != request->resp_version) {
		rc = -EIO;
		goto out;
	}

	if (response->protocol == VNIC_INFO_PROT_L2)
		disc = QETH_DISCIPLINE_LAYER2;
	else if (response->protocol == VNIC_INFO_PROT_L3)
		disc = QETH_DISCIPLINE_LAYER3;

out:
	kfree(response);
	kfree(request);
	if (rc)
1900
		QETH_CARD_TEXT_(card, 2, "err%x", rc);
1901 1902 1903
	return disc;
}

1904 1905 1906
/* Determine whether the device requires a specific layer discipline */
static enum qeth_discipline_id qeth_enforce_discipline(struct qeth_card *card)
{
1907 1908
	enum qeth_discipline_id disc = QETH_DISCIPLINE_UNDETERMINED;

1909
	if (IS_OSM(card) || IS_OSN(card))
1910
		disc = QETH_DISCIPLINE_LAYER2;
1911 1912 1913
	else if (IS_VM_NIC(card))
		disc = IS_IQD(card) ? QETH_DISCIPLINE_LAYER3 :
				      qeth_vm_detect_layer(card);
1914 1915 1916

	switch (disc) {
	case QETH_DISCIPLINE_LAYER2:
1917
		QETH_CARD_TEXT(card, 3, "force l2");
1918 1919
		break;
	case QETH_DISCIPLINE_LAYER3:
1920
		QETH_CARD_TEXT(card, 3, "force l3");
1921 1922
		break;
	default:
1923
		QETH_CARD_TEXT(card, 3, "force no");
1924 1925
	}

1926
	return disc;
1927 1928
}

1929
static void qeth_set_blkt_defaults(struct qeth_card *card)
1930
{
1931
	QETH_CARD_TEXT(card, 2, "cfgblkt");
1932

1933
	if (card->info.use_v1_blkt) {
1934 1935 1936
		card->info.blkt.time_total = 0;
		card->info.blkt.inter_packet = 0;
		card->info.blkt.inter_packet_jumbo = 0;
1937 1938 1939 1940
	} else {
		card->info.blkt.time_total = 250;
		card->info.blkt.inter_packet = 5;
		card->info.blkt.inter_packet_jumbo = 15;
1941
	}
F
Frank Blaschka 已提交
1942 1943
}

1944
static void qeth_idx_init(struct qeth_card *card)
F
Frank Blaschka 已提交
1945
{
1946 1947
	memset(&card->seqno, 0, sizeof(card->seqno));

F
Frank Blaschka 已提交
1948 1949 1950 1951 1952 1953
	card->token.issuer_rm_w = 0x00010103UL;
	card->token.cm_filter_w = 0x00010108UL;
	card->token.cm_connection_w = 0x0001010aUL;
	card->token.ulp_filter_w = 0x0001010bUL;
	card->token.ulp_connection_w = 0x0001010dUL;

1954 1955
	switch (card->info.type) {
	case QETH_CARD_TYPE_IQD:
1956
		card->info.func_level =	QETH_IDX_FUNC_LEVEL_IQD;
1957 1958
		break;
	case QETH_CARD_TYPE_OSD:
1959
	case QETH_CARD_TYPE_OSN:
1960 1961 1962 1963
		card->info.func_level = QETH_IDX_FUNC_LEVEL_OSD;
		break;
	default:
		break;
F
Frank Blaschka 已提交
1964 1965 1966
	}
}

1967
static void qeth_idx_finalize_cmd(struct qeth_card *card,
1968
				  struct qeth_cmd_buffer *iob)
1969 1970 1971 1972 1973 1974 1975
{
	memcpy(QETH_TRANSPORT_HEADER_SEQ_NO(iob->data), &card->seqno.trans_hdr,
	       QETH_SEQ_NO_LENGTH);
	if (iob->channel == &card->write)
		card->seqno.trans_hdr++;
}

F
Frank Blaschka 已提交
1976 1977 1978 1979 1980 1981 1982 1983 1984
static int qeth_peer_func_level(int level)
{
	if ((level & 0xff) == 8)
		return (level & 0xff) + 0x400;
	if (((level >> 8) & 3) == 1)
		return (level & 0xff) + 0x200;
	return level;
}

1985
static void qeth_mpc_finalize_cmd(struct qeth_card *card,
1986
				  struct qeth_cmd_buffer *iob)
F
Frank Blaschka 已提交
1987
{
1988
	qeth_idx_finalize_cmd(card, iob);
F
Frank Blaschka 已提交
1989 1990 1991 1992 1993 1994

	memcpy(QETH_PDU_HEADER_SEQ_NO(iob->data),
	       &card->seqno.pdu_hdr, QETH_SEQ_NO_LENGTH);
	card->seqno.pdu_hdr++;
	memcpy(QETH_PDU_HEADER_ACK_SEQ_NO(iob->data),
	       &card->seqno.pdu_hdr_ack, QETH_SEQ_NO_LENGTH);
1995 1996

	iob->callback = qeth_release_buffer_cb;
F
Frank Blaschka 已提交
1997 1998
}

1999 2000 2001 2002 2003 2004 2005
static bool qeth_mpc_match_reply(struct qeth_cmd_buffer *iob,
				 struct qeth_cmd_buffer *reply)
{
	/* MPC cmds are issued strictly in sequence. */
	return !IS_IPA(reply->data);
}

2006
static struct qeth_cmd_buffer *qeth_mpc_alloc_cmd(struct qeth_card *card,
2007
						  const void *data,
2008
						  unsigned int data_length)
2009 2010 2011
{
	struct qeth_cmd_buffer *iob;

2012 2013 2014 2015 2016 2017 2018 2019
	iob = qeth_alloc_cmd(&card->write, data_length, 1, QETH_TIMEOUT);
	if (!iob)
		return NULL;

	memcpy(iob->data, data, data_length);
	qeth_setup_ccw(__ccw_from_cmd(iob), CCW_CMD_WRITE, 0, data_length,
		       iob->data);
	iob->finalize = qeth_mpc_finalize_cmd;
2020
	iob->match = qeth_mpc_match_reply;
2021 2022 2023
	return iob;
}

E
Eugene Crosser 已提交
2024 2025 2026 2027 2028 2029 2030 2031 2032 2033 2034 2035 2036 2037
/**
 * qeth_send_control_data() -	send control command to the card
 * @card:			qeth_card structure pointer
 * @iob:			qeth_cmd_buffer pointer
 * @reply_cb:			callback function pointer
 * @cb_card:			pointer to the qeth_card structure
 * @cb_reply:			pointer to the qeth_reply structure
 * @cb_cmd:			pointer to the original iob for non-IPA
 *				commands, or to the qeth_ipa_cmd structure
 *				for the IPA commands.
 * @reply_param:		private pointer passed to the callback
 *
 * Callback function gets called one or more times, with cb_cmd
 * pointing to the response returned by the hardware. Callback
2038 2039 2040 2041 2042
 * function must return
 *   > 0 if more reply blocks are expected,
 *     0 if the last or only reply block is received, and
 *   < 0 on error.
 * Callback function can get the value of the reply_param pointer from the
E
Eugene Crosser 已提交
2043 2044 2045
 * field 'param' of the structure qeth_reply.
 */

2046
static int qeth_send_control_data(struct qeth_card *card,
2047 2048 2049 2050 2051
				  struct qeth_cmd_buffer *iob,
				  int (*reply_cb)(struct qeth_card *cb_card,
						  struct qeth_reply *cb_reply,
						  unsigned long cb_cmd),
				  void *reply_param)
F
Frank Blaschka 已提交
2052
{
2053
	struct qeth_channel *channel = iob->channel;
2054
	struct qeth_reply *reply = &iob->reply;
2055
	long timeout = iob->timeout;
F
Frank Blaschka 已提交
2056 2057
	int rc;

C
Carsten Otte 已提交
2058
	QETH_CARD_TEXT(card, 2, "sendctl");
F
Frank Blaschka 已提交
2059 2060 2061

	reply->callback = reply_cb;
	reply->param = reply_param;
2062

2063 2064 2065 2066
	timeout = wait_event_interruptible_timeout(card->wait_q,
						   qeth_trylock_channel(channel),
						   timeout);
	if (timeout <= 0) {
2067
		qeth_put_cmd(iob);
2068 2069
		return (timeout == -ERESTARTSYS) ? -EINTR : -ETIME;
	}
F
Frank Blaschka 已提交
2070

2071
	if (iob->finalize)
2072 2073
		iob->finalize(card, iob);
	QETH_DBF_HEX(CTRL, 2, iob->data, min(iob->length, QETH_DBF_CTRL_LEN));
2074

2075
	qeth_enqueue_cmd(card, iob);
2076

2077 2078 2079
	/* This pairs with iob->callback, and keeps the iob alive after IO: */
	qeth_get_cmd(iob);

C
Carsten Otte 已提交
2080
	QETH_CARD_TEXT(card, 6, "noirqpnd");
J
Julian Wiedmann 已提交
2081
	spin_lock_irq(get_ccwdev_lock(channel->ccwdev));
2082
	rc = ccw_device_start_timeout(channel->ccwdev, __ccw_from_cmd(iob),
2083
				      (addr_t) iob, 0, 0, timeout);
2084 2085
	if (!rc)
		channel->active_cmd = iob;
J
Julian Wiedmann 已提交
2086
	spin_unlock_irq(get_ccwdev_lock(channel->ccwdev));
F
Frank Blaschka 已提交
2087
	if (rc) {
2088 2089
		QETH_DBF_MESSAGE(2, "qeth_send_control_data on device %x: ccw_device_start rc = %i\n",
				 CARD_DEVID(card), rc);
C
Carsten Otte 已提交
2090
		QETH_CARD_TEXT_(card, 2, " err%d", rc);
2091
		qeth_dequeue_cmd(card, iob);
2092
		qeth_put_cmd(iob);
2093
		qeth_unlock_channel(card, channel);
2094
		goto out;
F
Frank Blaschka 已提交
2095
	}
2096

2097
	timeout = wait_for_completion_interruptible_timeout(&iob->done,
2098 2099 2100
							    timeout);
	if (timeout <= 0)
		rc = (timeout == -ERESTARTSYS) ? -EINTR : -ETIME;
2101

2102
	qeth_dequeue_cmd(card, iob);
2103 2104 2105

	if (reply_cb) {
		/* Wait until the callback for a late reply has completed: */
2106
		spin_lock_irq(&iob->lock);
2107 2108
		if (rc)
			/* Zap any callback that's still pending: */
2109 2110
			iob->rc = rc;
		spin_unlock_irq(&iob->lock);
2111 2112
	}

2113
	if (!rc)
2114
		rc = iob->rc;
2115 2116 2117

out:
	qeth_put_cmd(iob);
2118
	return rc;
F
Frank Blaschka 已提交
2119 2120
}

2121 2122 2123 2124 2125 2126
struct qeth_node_desc {
	struct node_descriptor nd1;
	struct node_descriptor nd2;
	struct node_descriptor nd3;
};

2127
static void qeth_read_conf_data_cb(struct qeth_card *card,
2128 2129
				   struct qeth_cmd_buffer *iob,
				   unsigned int data_length)
2130
{
2131
	struct qeth_node_desc *nd = (struct qeth_node_desc *) iob->data;
2132
	int rc = 0;
2133
	u8 *tag;
2134 2135

	QETH_CARD_TEXT(card, 2, "cfgunit");
2136 2137 2138 2139 2140 2141

	if (data_length < sizeof(*nd)) {
		rc = -EINVAL;
		goto out;
	}

2142 2143 2144 2145 2146 2147 2148 2149 2150 2151 2152 2153 2154
	card->info.is_vm_nic = nd->nd1.plant[0] == _ascebc['V'] &&
			       nd->nd1.plant[1] == _ascebc['M'];
	tag = (u8 *)&nd->nd1.tag;
	card->info.chpid = tag[0];
	card->info.unit_addr2 = tag[1];

	tag = (u8 *)&nd->nd2.tag;
	card->info.cula = tag[1];

	card->info.use_v1_blkt = nd->nd3.model[0] == 0xF0 &&
				 nd->nd3.model[1] == 0xF0 &&
				 nd->nd3.model[2] >= 0xF1 &&
				 nd->nd3.model[2] <= 0xF4;
2155

2156
out:
2157
	qeth_notify_cmd(iob, rc);
2158
	qeth_put_cmd(iob);
2159 2160 2161 2162 2163 2164 2165 2166 2167 2168 2169 2170
}

static int qeth_read_conf_data(struct qeth_card *card)
{
	struct qeth_channel *channel = &card->data;
	struct qeth_cmd_buffer *iob;
	struct ciw *ciw;

	/* scan for RCD command in extended SenseID data */
	ciw = ccw_device_get_ciw(channel->ccwdev, CIW_TYPE_RCD);
	if (!ciw || ciw->cmd == 0)
		return -EOPNOTSUPP;
2171 2172
	if (ciw->count < sizeof(struct qeth_node_desc))
		return -EINVAL;
2173 2174 2175 2176 2177 2178 2179 2180 2181

	iob = qeth_alloc_cmd(channel, ciw->count, 1, QETH_RCD_TIMEOUT);
	if (!iob)
		return -ENOMEM;

	iob->callback = qeth_read_conf_data_cb;
	qeth_setup_ccw(__ccw_from_cmd(iob), ciw->cmd, 0, iob->length,
		       iob->data);

2182
	return qeth_send_control_data(card, iob, NULL, NULL);
2183 2184
}

2185 2186 2187 2188 2189 2190 2191 2192 2193 2194 2195 2196 2197 2198
static int qeth_idx_check_activate_response(struct qeth_card *card,
					    struct qeth_channel *channel,
					    struct qeth_cmd_buffer *iob)
{
	int rc;

	rc = qeth_check_idx_response(card, iob->data);
	if (rc)
		return rc;

	if (QETH_IS_IDX_ACT_POS_REPLY(iob->data))
		return 0;

	/* negative reply: */
2199 2200
	QETH_CARD_TEXT_(card, 2, "idxneg%c",
			QETH_IDX_ACT_CAUSE_CODE(iob->data));
2201 2202 2203 2204 2205 2206 2207 2208 2209 2210 2211 2212 2213 2214 2215 2216 2217 2218

	switch (QETH_IDX_ACT_CAUSE_CODE(iob->data)) {
	case QETH_IDX_ACT_ERR_EXCL:
		dev_err(&channel->ccwdev->dev,
			"The adapter is used exclusively by another host\n");
		return -EBUSY;
	case QETH_IDX_ACT_ERR_AUTH:
	case QETH_IDX_ACT_ERR_AUTH_USER:
		dev_err(&channel->ccwdev->dev,
			"Setting the device online failed because of insufficient authorization\n");
		return -EPERM;
	default:
		QETH_DBF_MESSAGE(2, "IDX_ACTIVATE on channel %x: negative reply\n",
				 CCW_DEVID(channel->ccwdev));
		return -EIO;
	}
}

2219
static void qeth_idx_activate_read_channel_cb(struct qeth_card *card,
2220 2221
					      struct qeth_cmd_buffer *iob,
					      unsigned int data_length)
2222
{
2223
	struct qeth_channel *channel = iob->channel;
2224 2225 2226
	u16 peer_level;
	int rc;

2227
	QETH_CARD_TEXT(card, 2, "idxrdcb");
2228 2229 2230 2231 2232 2233 2234 2235 2236 2237 2238 2239 2240 2241 2242 2243 2244 2245 2246 2247 2248

	rc = qeth_idx_check_activate_response(card, channel, iob);
	if (rc)
		goto out;

	memcpy(&peer_level, QETH_IDX_ACT_FUNC_LEVEL(iob->data), 2);
	if (peer_level != qeth_peer_func_level(card->info.func_level)) {
		QETH_DBF_MESSAGE(2, "IDX_ACTIVATE on channel %x: function level mismatch (sent: %#x, received: %#x)\n",
				 CCW_DEVID(channel->ccwdev),
				 card->info.func_level, peer_level);
		rc = -EINVAL;
		goto out;
	}

	memcpy(&card->token.issuer_rm_r,
	       QETH_IDX_ACT_ISSUER_RM_TOKEN(iob->data),
	       QETH_MPC_TOKEN_LENGTH);
	memcpy(&card->info.mcl_level[0],
	       QETH_IDX_REPLY_LEVEL(iob->data), QETH_MCL_LENGTH);

out:
2249
	qeth_notify_cmd(iob, rc);
2250
	qeth_put_cmd(iob);
2251 2252
}

2253
static void qeth_idx_activate_write_channel_cb(struct qeth_card *card,
2254 2255
					       struct qeth_cmd_buffer *iob,
					       unsigned int data_length)
2256
{
2257
	struct qeth_channel *channel = iob->channel;
2258 2259 2260
	u16 peer_level;
	int rc;

2261
	QETH_CARD_TEXT(card, 2, "idxwrcb");
2262 2263 2264 2265 2266 2267 2268 2269 2270 2271 2272 2273 2274 2275 2276

	rc = qeth_idx_check_activate_response(card, channel, iob);
	if (rc)
		goto out;

	memcpy(&peer_level, QETH_IDX_ACT_FUNC_LEVEL(iob->data), 2);
	if ((peer_level & ~0x0100) !=
	    qeth_peer_func_level(card->info.func_level)) {
		QETH_DBF_MESSAGE(2, "IDX_ACTIVATE on channel %x: function level mismatch (sent: %#x, received: %#x)\n",
				 CCW_DEVID(channel->ccwdev),
				 card->info.func_level, peer_level);
		rc = -EINVAL;
	}

out:
2277
	qeth_notify_cmd(iob, rc);
2278
	qeth_put_cmd(iob);
2279 2280 2281 2282 2283 2284 2285
}

static void qeth_idx_setup_activate_cmd(struct qeth_card *card,
					struct qeth_cmd_buffer *iob)
{
	u16 addr = (card->info.cula << 8) + card->info.unit_addr2;
	u8 port = ((u8)card->dev->dev_port) | 0x80;
2286
	struct ccw1 *ccw = __ccw_from_cmd(iob);
2287

2288 2289 2290
	qeth_setup_ccw(&ccw[0], CCW_CMD_WRITE, CCW_FLAG_CC, IDX_ACTIVATE_SIZE,
		       iob->data);
	qeth_setup_ccw(&ccw[1], CCW_CMD_READ, 0, iob->length, iob->data);
2291 2292
	iob->finalize = qeth_idx_finalize_cmd;

2293
	port |= QETH_IDX_ACT_INVAL_FRAME;
2294 2295 2296 2297 2298
	memcpy(QETH_IDX_ACT_PNO(iob->data), &port, 1);
	memcpy(QETH_IDX_ACT_ISSUER_RM_TOKEN(iob->data),
	       &card->token.issuer_rm_w, QETH_MPC_TOKEN_LENGTH);
	memcpy(QETH_IDX_ACT_FUNC_LEVEL(iob->data),
	       &card->info.func_level, 2);
2299
	memcpy(QETH_IDX_ACT_QDIO_DEV_CUA(iob->data), &card->info.ddev_devno, 2);
2300 2301 2302 2303 2304 2305 2306 2307 2308
	memcpy(QETH_IDX_ACT_QDIO_DEV_REALADDR(iob->data), &addr, 2);
}

static int qeth_idx_activate_read_channel(struct qeth_card *card)
{
	struct qeth_channel *channel = &card->read;
	struct qeth_cmd_buffer *iob;
	int rc;

2309
	QETH_CARD_TEXT(card, 2, "idxread");
2310

2311
	iob = qeth_alloc_cmd(channel, QETH_BUFSIZE, 2, QETH_TIMEOUT);
2312 2313 2314 2315 2316
	if (!iob)
		return -ENOMEM;

	memcpy(iob->data, IDX_ACTIVATE_READ, IDX_ACTIVATE_SIZE);
	qeth_idx_setup_activate_cmd(card, iob);
2317
	iob->callback = qeth_idx_activate_read_channel_cb;
2318

2319
	rc = qeth_send_control_data(card, iob, NULL, NULL);
2320 2321 2322 2323 2324 2325 2326 2327 2328 2329 2330 2331 2332
	if (rc)
		return rc;

	channel->state = CH_STATE_UP;
	return 0;
}

static int qeth_idx_activate_write_channel(struct qeth_card *card)
{
	struct qeth_channel *channel = &card->write;
	struct qeth_cmd_buffer *iob;
	int rc;

2333
	QETH_CARD_TEXT(card, 2, "idxwrite");
2334

2335
	iob = qeth_alloc_cmd(channel, QETH_BUFSIZE, 2, QETH_TIMEOUT);
2336 2337 2338 2339 2340
	if (!iob)
		return -ENOMEM;

	memcpy(iob->data, IDX_ACTIVATE_WRITE, IDX_ACTIVATE_SIZE);
	qeth_idx_setup_activate_cmd(card, iob);
2341
	iob->callback = qeth_idx_activate_write_channel_cb;
2342

2343
	rc = qeth_send_control_data(card, iob, NULL, NULL);
2344 2345 2346 2347 2348 2349 2350
	if (rc)
		return rc;

	channel->state = CH_STATE_UP;
	return 0;
}

F
Frank Blaschka 已提交
2351 2352 2353 2354 2355
static int qeth_cm_enable_cb(struct qeth_card *card, struct qeth_reply *reply,
		unsigned long data)
{
	struct qeth_cmd_buffer *iob;

2356
	QETH_CARD_TEXT(card, 2, "cmenblcb");
F
Frank Blaschka 已提交
2357 2358 2359 2360 2361 2362 2363 2364 2365 2366 2367 2368

	iob = (struct qeth_cmd_buffer *) data;
	memcpy(&card->token.cm_filter_r,
	       QETH_CM_ENABLE_RESP_FILTER_TOKEN(iob->data),
	       QETH_MPC_TOKEN_LENGTH);
	return 0;
}

static int qeth_cm_enable(struct qeth_card *card)
{
	struct qeth_cmd_buffer *iob;

2369
	QETH_CARD_TEXT(card, 2, "cmenable");
F
Frank Blaschka 已提交
2370

2371
	iob = qeth_mpc_alloc_cmd(card, CM_ENABLE, CM_ENABLE_SIZE);
2372 2373
	if (!iob)
		return -ENOMEM;
2374

F
Frank Blaschka 已提交
2375 2376 2377 2378 2379
	memcpy(QETH_CM_ENABLE_ISSUER_RM_TOKEN(iob->data),
	       &card->token.issuer_rm_r, QETH_MPC_TOKEN_LENGTH);
	memcpy(QETH_CM_ENABLE_FILTER_TOKEN(iob->data),
	       &card->token.cm_filter_w, QETH_MPC_TOKEN_LENGTH);

2380
	return qeth_send_control_data(card, iob, qeth_cm_enable_cb, NULL);
F
Frank Blaschka 已提交
2381 2382 2383 2384 2385 2386 2387
}

static int qeth_cm_setup_cb(struct qeth_card *card, struct qeth_reply *reply,
		unsigned long data)
{
	struct qeth_cmd_buffer *iob;

2388
	QETH_CARD_TEXT(card, 2, "cmsetpcb");
F
Frank Blaschka 已提交
2389 2390 2391 2392 2393 2394 2395 2396 2397 2398 2399 2400

	iob = (struct qeth_cmd_buffer *) data;
	memcpy(&card->token.cm_connection_r,
	       QETH_CM_SETUP_RESP_DEST_ADDR(iob->data),
	       QETH_MPC_TOKEN_LENGTH);
	return 0;
}

static int qeth_cm_setup(struct qeth_card *card)
{
	struct qeth_cmd_buffer *iob;

2401
	QETH_CARD_TEXT(card, 2, "cmsetup");
F
Frank Blaschka 已提交
2402

2403
	iob = qeth_mpc_alloc_cmd(card, CM_SETUP, CM_SETUP_SIZE);
2404 2405
	if (!iob)
		return -ENOMEM;
2406

F
Frank Blaschka 已提交
2407 2408 2409 2410 2411 2412
	memcpy(QETH_CM_SETUP_DEST_ADDR(iob->data),
	       &card->token.issuer_rm_r, QETH_MPC_TOKEN_LENGTH);
	memcpy(QETH_CM_SETUP_CONNECTION_TOKEN(iob->data),
	       &card->token.cm_connection_w, QETH_MPC_TOKEN_LENGTH);
	memcpy(QETH_CM_SETUP_FILTER_TOKEN(iob->data),
	       &card->token.cm_filter_r, QETH_MPC_TOKEN_LENGTH);
2413
	return qeth_send_control_data(card, iob, qeth_cm_setup_cb, NULL);
F
Frank Blaschka 已提交
2414 2415
}

2416 2417 2418 2419 2420 2421 2422 2423 2424 2425 2426
static bool qeth_is_supported_link_type(struct qeth_card *card, u8 link_type)
{
	if (link_type == QETH_LINK_TYPE_LANE_TR ||
	    link_type == QETH_LINK_TYPE_HSTR) {
		dev_err(&card->gdev->dev, "Unsupported Token Ring device\n");
		return false;
	}

	return true;
}

2427
static int qeth_update_max_mtu(struct qeth_card *card, unsigned int max_mtu)
F
Frank Blaschka 已提交
2428
{
2429 2430 2431 2432 2433 2434 2435 2436 2437 2438 2439 2440 2441 2442 2443 2444 2445 2446 2447
	struct net_device *dev = card->dev;
	unsigned int new_mtu;

	if (!max_mtu) {
		/* IQD needs accurate max MTU to set up its RX buffers: */
		if (IS_IQD(card))
			return -EINVAL;
		/* tolerate quirky HW: */
		max_mtu = ETH_MAX_MTU;
	}

	rtnl_lock();
	if (IS_IQD(card)) {
		/* move any device with default MTU to new max MTU: */
		new_mtu = (dev->mtu == dev->max_mtu) ? max_mtu : dev->mtu;

		/* adjust RX buffer size to new max MTU: */
		card->qdio.in_buf_size = max_mtu + 2 * PAGE_SIZE;
		if (dev->max_mtu && dev->max_mtu != max_mtu)
2448
			qeth_free_qdio_queues(card);
2449 2450 2451 2452
	} else {
		if (dev->mtu)
			new_mtu = dev->mtu;
		/* default MTUs for first setup: */
2453
		else if (IS_LAYER2(card))
2454 2455 2456
			new_mtu = ETH_DATA_LEN;
		else
			new_mtu = ETH_DATA_LEN - 8; /* allow for LLC + SNAP */
F
Frank Blaschka 已提交
2457
	}
2458 2459 2460 2461 2462

	dev->max_mtu = max_mtu;
	dev->mtu = min(new_mtu, max_mtu);
	rtnl_unlock();
	return 0;
F
Frank Blaschka 已提交
2463 2464
}

J
Julian Wiedmann 已提交
2465
static int qeth_get_mtu_outof_framesize(int framesize)
F
Frank Blaschka 已提交
2466 2467 2468 2469 2470 2471 2472 2473 2474 2475 2476 2477 2478 2479 2480 2481 2482 2483 2484 2485 2486
{
	switch (framesize) {
	case 0x4000:
		return 8192;
	case 0x6000:
		return 16384;
	case 0xa000:
		return 32768;
	case 0xffff:
		return 57344;
	default:
		return 0;
	}
}

static int qeth_ulp_enable_cb(struct qeth_card *card, struct qeth_reply *reply,
		unsigned long data)
{
	__u16 mtu, framesize;
	__u16 len;
	struct qeth_cmd_buffer *iob;
2487
	u8 link_type = 0;
F
Frank Blaschka 已提交
2488

2489
	QETH_CARD_TEXT(card, 2, "ulpenacb");
F
Frank Blaschka 已提交
2490 2491 2492 2493 2494

	iob = (struct qeth_cmd_buffer *) data;
	memcpy(&card->token.ulp_filter_r,
	       QETH_ULP_ENABLE_RESP_FILTER_TOKEN(iob->data),
	       QETH_MPC_TOKEN_LENGTH);
2495
	if (IS_IQD(card)) {
F
Frank Blaschka 已提交
2496 2497 2498
		memcpy(&framesize, QETH_ULP_ENABLE_RESP_MAX_MTU(iob->data), 2);
		mtu = qeth_get_mtu_outof_framesize(framesize);
	} else {
2499
		mtu = *(__u16 *)QETH_ULP_ENABLE_RESP_MAX_MTU(iob->data);
F
Frank Blaschka 已提交
2500
	}
2501
	*(u16 *)reply->param = mtu;
F
Frank Blaschka 已提交
2502 2503 2504 2505 2506

	memcpy(&len, QETH_ULP_ENABLE_RESP_DIFINFO_LEN(iob->data), 2);
	if (len >= QETH_MPC_DIFINFO_LEN_INDICATES_LINK_TYPE) {
		memcpy(&link_type,
		       QETH_ULP_ENABLE_RESP_LINK_TYPE(iob->data), 1);
2507 2508 2509 2510 2511
		if (!qeth_is_supported_link_type(card, link_type))
			return -EPROTONOSUPPORT;
	}

	card->info.link_type = link_type;
2512
	QETH_CARD_TEXT_(card, 2, "link%d", card->info.link_type);
F
Frank Blaschka 已提交
2513 2514 2515
	return 0;
}

2516 2517 2518 2519
static u8 qeth_mpc_select_prot_type(struct qeth_card *card)
{
	if (IS_OSN(card))
		return QETH_PROT_OSN2;
2520
	return IS_LAYER2(card) ? QETH_PROT_LAYER2 : QETH_PROT_TCPIP;
2521 2522
}

F
Frank Blaschka 已提交
2523 2524
static int qeth_ulp_enable(struct qeth_card *card)
{
2525
	u8 prot_type = qeth_mpc_select_prot_type(card);
F
Frank Blaschka 已提交
2526
	struct qeth_cmd_buffer *iob;
2527
	u16 max_mtu;
2528
	int rc;
F
Frank Blaschka 已提交
2529

2530
	QETH_CARD_TEXT(card, 2, "ulpenabl");
F
Frank Blaschka 已提交
2531

2532
	iob = qeth_mpc_alloc_cmd(card, ULP_ENABLE, ULP_ENABLE_SIZE);
2533 2534
	if (!iob)
		return -ENOMEM;
F
Frank Blaschka 已提交
2535

2536
	*(QETH_ULP_ENABLE_LINKNUM(iob->data)) = (u8) card->dev->dev_port;
F
Frank Blaschka 已提交
2537 2538 2539 2540 2541
	memcpy(QETH_ULP_ENABLE_PROT_TYPE(iob->data), &prot_type, 1);
	memcpy(QETH_ULP_ENABLE_DEST_ADDR(iob->data),
	       &card->token.cm_connection_r, QETH_MPC_TOKEN_LENGTH);
	memcpy(QETH_ULP_ENABLE_FILTER_TOKEN(iob->data),
	       &card->token.ulp_filter_w, QETH_MPC_TOKEN_LENGTH);
2542
	rc = qeth_send_control_data(card, iob, qeth_ulp_enable_cb, &max_mtu);
2543 2544 2545
	if (rc)
		return rc;
	return qeth_update_max_mtu(card, max_mtu);
F
Frank Blaschka 已提交
2546 2547 2548 2549 2550 2551 2552
}

static int qeth_ulp_setup_cb(struct qeth_card *card, struct qeth_reply *reply,
		unsigned long data)
{
	struct qeth_cmd_buffer *iob;

2553
	QETH_CARD_TEXT(card, 2, "ulpstpcb");
F
Frank Blaschka 已提交
2554 2555 2556 2557 2558

	iob = (struct qeth_cmd_buffer *) data;
	memcpy(&card->token.ulp_connection_r,
	       QETH_ULP_SETUP_RESP_CONNECTION_TOKEN(iob->data),
	       QETH_MPC_TOKEN_LENGTH);
2559 2560
	if (!strncmp("00S", QETH_ULP_SETUP_RESP_CONNECTION_TOKEN(iob->data),
		     3)) {
2561
		QETH_CARD_TEXT(card, 2, "olmlimit");
2562 2563
		dev_err(&card->gdev->dev, "A connection could not be "
			"established because of an OLM limit\n");
2564
		return -EMLINK;
2565
	}
S
Stefan Raspl 已提交
2566
	return 0;
F
Frank Blaschka 已提交
2567 2568 2569 2570 2571 2572 2573
}

static int qeth_ulp_setup(struct qeth_card *card)
{
	__u16 temp;
	struct qeth_cmd_buffer *iob;

2574
	QETH_CARD_TEXT(card, 2, "ulpsetup");
F
Frank Blaschka 已提交
2575

2576
	iob = qeth_mpc_alloc_cmd(card, ULP_SETUP, ULP_SETUP_SIZE);
2577 2578
	if (!iob)
		return -ENOMEM;
F
Frank Blaschka 已提交
2579 2580 2581 2582 2583 2584 2585 2586

	memcpy(QETH_ULP_SETUP_DEST_ADDR(iob->data),
	       &card->token.cm_connection_r, QETH_MPC_TOKEN_LENGTH);
	memcpy(QETH_ULP_SETUP_CONNECTION_TOKEN(iob->data),
	       &card->token.ulp_connection_w, QETH_MPC_TOKEN_LENGTH);
	memcpy(QETH_ULP_SETUP_FILTER_TOKEN(iob->data),
	       &card->token.ulp_filter_r, QETH_MPC_TOKEN_LENGTH);

2587
	memcpy(QETH_ULP_SETUP_CUA(iob->data), &card->info.ddev_devno, 2);
F
Frank Blaschka 已提交
2588 2589
	temp = (card->info.cula << 8) + card->info.unit_addr2;
	memcpy(QETH_ULP_SETUP_REAL_DEVADDR(iob->data), &temp, 2);
2590
	return qeth_send_control_data(card, iob, qeth_ulp_setup_cb, NULL);
F
Frank Blaschka 已提交
2591 2592
}

2593 2594
static int qeth_alloc_out_buf(struct qeth_qdio_out_q *q, unsigned int bidx,
			      gfp_t gfp)
2595 2596 2597
{
	struct qeth_qdio_out_buffer *newbuf;

2598
	newbuf = kmem_cache_zalloc(qeth_qdio_outbuf_cache, gfp);
2599 2600 2601
	if (!newbuf)
		return -ENOMEM;

2602
	newbuf->buffer = q->qdio_bufs[bidx];
2603 2604 2605 2606 2607
	skb_queue_head_init(&newbuf->skb_list);
	lockdep_set_class(&newbuf->skb_list.lock, &qdio_out_skb_queue_key);
	newbuf->q = q;
	atomic_set(&newbuf->state, QETH_QDIO_BUF_EMPTY);
	q->bufs[bidx] = newbuf;
2608
	return 0;
2609 2610
}

2611
static void qeth_free_output_queue(struct qeth_qdio_out_q *q)
2612 2613 2614 2615
{
	if (!q)
		return;

2616
	qeth_drain_output_queue(q, true);
2617 2618 2619 2620
	qdio_free_buffers(q->qdio_bufs, QDIO_MAX_BUFFERS_PER_Q);
	kfree(q);
}

2621
static struct qeth_qdio_out_q *qeth_alloc_output_queue(void)
2622 2623
{
	struct qeth_qdio_out_q *q = kzalloc(sizeof(*q), GFP_KERNEL);
2624
	unsigned int i;
2625 2626 2627 2628

	if (!q)
		return NULL;

2629 2630 2631 2632
	if (qdio_alloc_buffers(q->qdio_bufs, QDIO_MAX_BUFFERS_PER_Q))
		goto err_qdio_bufs;

	for (i = 0; i < QDIO_MAX_BUFFERS_PER_Q; i++) {
2633
		if (qeth_alloc_out_buf(q, i, GFP_KERNEL))
2634
			goto err_out_bufs;
2635
	}
2636

2637
	return q;
2638 2639 2640 2641 2642 2643 2644 2645

err_out_bufs:
	while (i > 0)
		kmem_cache_free(qeth_qdio_outbuf_cache, q->bufs[--i]);
	qdio_free_buffers(q->qdio_bufs, QDIO_MAX_BUFFERS_PER_Q);
err_qdio_bufs:
	kfree(q);
	return NULL;
2646
}
2647

2648 2649 2650 2651 2652 2653 2654 2655
static void qeth_tx_completion_timer(struct timer_list *timer)
{
	struct qeth_qdio_out_q *queue = from_timer(queue, timer, timer);

	napi_schedule(&queue->napi);
	QETH_TXQ_STAT_INC(queue, completion_timer);
}

2656
static int qeth_alloc_qdio_queues(struct qeth_card *card)
F
Frank Blaschka 已提交
2657
{
2658
	unsigned int i;
F
Frank Blaschka 已提交
2659

2660
	QETH_CARD_TEXT(card, 2, "allcqdbf");
F
Frank Blaschka 已提交
2661 2662 2663 2664 2665

	if (atomic_cmpxchg(&card->qdio.state, QETH_QDIO_UNINITIALIZED,
		QETH_QDIO_ALLOCATED) != QETH_QDIO_UNINITIALIZED)
		return 0;

2666
	QETH_CARD_TEXT(card, 2, "inq");
S
Sebastian Ott 已提交
2667
	card->qdio.in_q = qeth_alloc_qdio_queue();
F
Frank Blaschka 已提交
2668 2669
	if (!card->qdio.in_q)
		goto out_nomem;
S
Sebastian Ott 已提交
2670

F
Frank Blaschka 已提交
2671 2672 2673
	/* inbound buffer pool */
	if (qeth_alloc_buffer_pool(card))
		goto out_freeinq;
2674

F
Frank Blaschka 已提交
2675 2676
	/* outbound */
	for (i = 0; i < card->qdio.no_out_queues; ++i) {
2677 2678 2679 2680
		struct qeth_qdio_out_q *queue;

		queue = qeth_alloc_output_queue();
		if (!queue)
F
Frank Blaschka 已提交
2681
			goto out_freeoutq;
2682
		QETH_CARD_TEXT_(card, 2, "outq %i", i);
2683 2684 2685 2686
		QETH_CARD_HEX(card, 2, &queue, sizeof(void *));
		card->qdio.out_qs[i] = queue;
		queue->card = card;
		queue->queue_no = i;
2687
		INIT_LIST_HEAD(&queue->pending_bufs);
2688
		spin_lock_init(&queue->lock);
2689
		timer_setup(&queue->timer, qeth_tx_completion_timer, 0);
2690 2691
		queue->coalesce_usecs = QETH_TX_COALESCE_USECS;
		queue->max_coalesced_frames = QETH_TX_MAX_COALESCED_FRAMES;
2692
		queue->priority = QETH_QIB_PQUE_PRIO_DEFAULT;
F
Frank Blaschka 已提交
2693
	}
2694 2695 2696 2697 2698

	/* completion */
	if (qeth_alloc_cq(card))
		goto out_freeoutq;

F
Frank Blaschka 已提交
2699 2700 2701
	return 0;

out_freeoutq:
2702
	while (i > 0) {
2703
		qeth_free_output_queue(card->qdio.out_qs[--i]);
2704 2705
		card->qdio.out_qs[i] = NULL;
	}
F
Frank Blaschka 已提交
2706 2707
	qeth_free_buffer_pool(card);
out_freeinq:
S
Sebastian Ott 已提交
2708
	qeth_free_qdio_queue(card->qdio.in_q);
F
Frank Blaschka 已提交
2709 2710 2711 2712 2713 2714
	card->qdio.in_q = NULL;
out_nomem:
	atomic_set(&card->qdio.state, QETH_QDIO_UNINITIALIZED);
	return -ENOMEM;
}

2715
static void qeth_free_qdio_queues(struct qeth_card *card)
2716 2717 2718 2719 2720 2721 2722 2723 2724 2725 2726 2727 2728 2729 2730 2731 2732
{
	int i, j;

	if (atomic_xchg(&card->qdio.state, QETH_QDIO_UNINITIALIZED) ==
		QETH_QDIO_UNINITIALIZED)
		return;

	qeth_free_cq(card);
	for (j = 0; j < QDIO_MAX_BUFFERS_PER_Q; ++j) {
		if (card->qdio.in_q->bufs[j].rx_skb)
			dev_kfree_skb_any(card->qdio.in_q->bufs[j].rx_skb);
	}
	qeth_free_qdio_queue(card->qdio.in_q);
	card->qdio.in_q = NULL;
	/* inbound buffer pool */
	qeth_free_buffer_pool(card);
	/* free outbound qdio_qs */
2733 2734 2735
	for (i = 0; i < card->qdio.no_out_queues; i++) {
		qeth_free_output_queue(card->qdio.out_qs[i]);
		card->qdio.out_qs[i] = NULL;
2736 2737 2738
	}
}

2739 2740 2741
static void qeth_fill_qib_parms(struct qeth_card *card,
				struct qeth_qib_parms *parms)
{
2742 2743 2744
	struct qeth_qdio_out_q *queue;
	unsigned int i;

2745 2746 2747 2748 2749 2750 2751 2752 2753 2754 2755 2756 2757 2758 2759 2760 2761
	parms->pcit_magic[0] = 'P';
	parms->pcit_magic[1] = 'C';
	parms->pcit_magic[2] = 'I';
	parms->pcit_magic[3] = 'T';
	ASCEBC(parms->pcit_magic, sizeof(parms->pcit_magic));
	parms->pcit_a = QETH_PCI_THRESHOLD_A(card);
	parms->pcit_b = QETH_PCI_THRESHOLD_B(card);
	parms->pcit_c = QETH_PCI_TIMER_VALUE(card);

	parms->blkt_magic[0] = 'B';
	parms->blkt_magic[1] = 'L';
	parms->blkt_magic[2] = 'K';
	parms->blkt_magic[3] = 'T';
	ASCEBC(parms->blkt_magic, sizeof(parms->blkt_magic));
	parms->blkt_total = card->info.blkt.time_total;
	parms->blkt_inter_packet = card->info.blkt.inter_packet;
	parms->blkt_inter_packet_jumbo = card->info.blkt.inter_packet_jumbo;
2762 2763 2764 2765 2766 2767 2768 2769 2770 2771 2772 2773 2774 2775 2776

	/* Prio-queueing implicitly uses the default priorities: */
	if (qeth_uses_tx_prio_queueing(card) || card->qdio.no_out_queues == 1)
		return;

	parms->pque_magic[0] = 'P';
	parms->pque_magic[1] = 'Q';
	parms->pque_magic[2] = 'U';
	parms->pque_magic[3] = 'E';
	ASCEBC(parms->pque_magic, sizeof(parms->pque_magic));
	parms->pque_order = QETH_QIB_PQUE_ORDER_RR;
	parms->pque_units = QETH_QIB_PQUE_UNITS_SBAL;

	qeth_for_each_output_queue(card, queue, i)
		parms->pque_priority[i] = queue->priority;
F
Frank Blaschka 已提交
2777 2778 2779 2780
}

static int qeth_qdio_activate(struct qeth_card *card)
{
2781
	QETH_CARD_TEXT(card, 3, "qdioact");
J
Jan Glauber 已提交
2782
	return qdio_activate(CARD_DDEV(card));
F
Frank Blaschka 已提交
2783 2784 2785 2786 2787 2788
}

static int qeth_dm_act(struct qeth_card *card)
{
	struct qeth_cmd_buffer *iob;

2789
	QETH_CARD_TEXT(card, 2, "dmact");
F
Frank Blaschka 已提交
2790

2791
	iob = qeth_mpc_alloc_cmd(card, DM_ACT, DM_ACT_SIZE);
2792 2793
	if (!iob)
		return -ENOMEM;
F
Frank Blaschka 已提交
2794 2795 2796 2797 2798

	memcpy(QETH_DM_ACT_DEST_ADDR(iob->data),
	       &card->token.cm_connection_r, QETH_MPC_TOKEN_LENGTH);
	memcpy(QETH_DM_ACT_CONNECTION_TOKEN(iob->data),
	       &card->token.ulp_connection_r, QETH_MPC_TOKEN_LENGTH);
2799
	return qeth_send_control_data(card, iob, NULL, NULL);
F
Frank Blaschka 已提交
2800 2801 2802 2803 2804 2805
}

static int qeth_mpc_initialize(struct qeth_card *card)
{
	int rc;

2806
	QETH_CARD_TEXT(card, 2, "mpcinit");
F
Frank Blaschka 已提交
2807 2808 2809

	rc = qeth_issue_next_read(card);
	if (rc) {
2810
		QETH_CARD_TEXT_(card, 2, "1err%d", rc);
F
Frank Blaschka 已提交
2811 2812 2813 2814
		return rc;
	}
	rc = qeth_cm_enable(card);
	if (rc) {
2815
		QETH_CARD_TEXT_(card, 2, "2err%d", rc);
2816
		return rc;
F
Frank Blaschka 已提交
2817 2818 2819
	}
	rc = qeth_cm_setup(card);
	if (rc) {
2820
		QETH_CARD_TEXT_(card, 2, "3err%d", rc);
2821
		return rc;
F
Frank Blaschka 已提交
2822 2823 2824
	}
	rc = qeth_ulp_enable(card);
	if (rc) {
2825
		QETH_CARD_TEXT_(card, 2, "4err%d", rc);
2826
		return rc;
F
Frank Blaschka 已提交
2827 2828 2829
	}
	rc = qeth_ulp_setup(card);
	if (rc) {
2830
		QETH_CARD_TEXT_(card, 2, "5err%d", rc);
2831
		return rc;
F
Frank Blaschka 已提交
2832
	}
2833
	rc = qeth_alloc_qdio_queues(card);
F
Frank Blaschka 已提交
2834
	if (rc) {
2835
		QETH_CARD_TEXT_(card, 2, "5err%d", rc);
2836
		return rc;
F
Frank Blaschka 已提交
2837 2838 2839
	}
	rc = qeth_qdio_establish(card);
	if (rc) {
2840
		QETH_CARD_TEXT_(card, 2, "6err%d", rc);
2841
		qeth_free_qdio_queues(card);
2842
		return rc;
F
Frank Blaschka 已提交
2843 2844 2845
	}
	rc = qeth_qdio_activate(card);
	if (rc) {
2846
		QETH_CARD_TEXT_(card, 2, "7err%d", rc);
2847
		return rc;
F
Frank Blaschka 已提交
2848 2849 2850
	}
	rc = qeth_dm_act(card);
	if (rc) {
2851
		QETH_CARD_TEXT_(card, 2, "8err%d", rc);
2852
		return rc;
F
Frank Blaschka 已提交
2853 2854 2855 2856 2857
	}

	return 0;
}

2858
static void qeth_print_status_message(struct qeth_card *card)
F
Frank Blaschka 已提交
2859 2860
{
	switch (card->info.type) {
2861 2862 2863
	case QETH_CARD_TYPE_OSD:
	case QETH_CARD_TYPE_OSM:
	case QETH_CARD_TYPE_OSX:
F
Frank Blaschka 已提交
2864 2865 2866 2867 2868 2869 2870 2871 2872 2873
		/* VM will use a non-zero first character
		 * to indicate a HiperSockets like reporting
		 * of the level OSA sets the first character to zero
		 * */
		if (!card->info.mcl_level[0]) {
			sprintf(card->info.mcl_level, "%02x%02x",
				card->info.mcl_level[2],
				card->info.mcl_level[3]);
			break;
		}
2874
		fallthrough;
F
Frank Blaschka 已提交
2875
	case QETH_CARD_TYPE_IQD:
2876
		if (IS_VM_NIC(card) || (card->info.mcl_level[0] & 0x80)) {
F
Frank Blaschka 已提交
2877 2878 2879 2880 2881 2882 2883 2884 2885 2886 2887 2888 2889 2890
			card->info.mcl_level[0] = (char) _ebcasc[(__u8)
				card->info.mcl_level[0]];
			card->info.mcl_level[1] = (char) _ebcasc[(__u8)
				card->info.mcl_level[1]];
			card->info.mcl_level[2] = (char) _ebcasc[(__u8)
				card->info.mcl_level[2]];
			card->info.mcl_level[3] = (char) _ebcasc[(__u8)
				card->info.mcl_level[3]];
			card->info.mcl_level[QETH_MCL_LENGTH] = 0;
		}
		break;
	default:
		memset(&card->info.mcl_level[0], 0, QETH_MCL_LENGTH + 1);
	}
2891 2892 2893 2894 2895 2896 2897
	dev_info(&card->gdev->dev,
		 "Device is a%s card%s%s%s\nwith link type %s.\n",
		 qeth_get_cardname(card),
		 (card->info.mcl_level[0]) ? " (level: " : "",
		 (card->info.mcl_level[0]) ? card->info.mcl_level : "",
		 (card->info.mcl_level[0]) ? ")" : "",
		 qeth_get_cardname_short(card));
F
Frank Blaschka 已提交
2898 2899 2900 2901 2902 2903
}

static void qeth_initialize_working_pool_list(struct qeth_card *card)
{
	struct qeth_buffer_pool_entry *entry;

C
Carsten Otte 已提交
2904
	QETH_CARD_TEXT(card, 5, "inwrklst");
F
Frank Blaschka 已提交
2905 2906 2907 2908 2909 2910 2911

	list_for_each_entry(entry,
			    &card->qdio.init_pool.entry_list, init_list) {
		qeth_put_buffer_pool_entry(card, entry);
	}
}

J
Julian Wiedmann 已提交
2912 2913
static struct qeth_buffer_pool_entry *qeth_find_free_buffer_pool_entry(
					struct qeth_card *card)
F
Frank Blaschka 已提交
2914 2915 2916 2917 2918 2919 2920
{
	struct qeth_buffer_pool_entry *entry;
	int i, free;

	if (list_empty(&card->qdio.in_buf_pool.entry_list))
		return NULL;

2921
	list_for_each_entry(entry, &card->qdio.in_buf_pool.entry_list, list) {
F
Frank Blaschka 已提交
2922 2923
		free = 1;
		for (i = 0; i < QETH_MAX_BUFFER_ELEMENTS(card); ++i) {
2924
			if (page_count(entry->elements[i]) > 1) {
F
Frank Blaschka 已提交
2925 2926 2927 2928 2929 2930 2931 2932 2933 2934 2935
				free = 0;
				break;
			}
		}
		if (free) {
			list_del_init(&entry->list);
			return entry;
		}
	}

	/* no free buffer in pool so take first one and swap pages */
2936 2937
	entry = list_first_entry(&card->qdio.in_buf_pool.entry_list,
				 struct qeth_buffer_pool_entry, list);
F
Frank Blaschka 已提交
2938
	for (i = 0; i < QETH_MAX_BUFFER_ELEMENTS(card); ++i) {
2939
		if (page_count(entry->elements[i]) > 1) {
2940
			struct page *page = dev_alloc_page();
2941 2942

			if (!page)
F
Frank Blaschka 已提交
2943
				return NULL;
2944 2945 2946 2947

			__free_page(entry->elements[i]);
			entry->elements[i] = page;
			QETH_CARD_STAT_INC(card, rx_sg_alloc_page);
F
Frank Blaschka 已提交
2948 2949 2950 2951 2952 2953 2954 2955 2956
		}
	}
	list_del_init(&entry->list);
	return entry;
}

static int qeth_init_input_buffer(struct qeth_card *card,
		struct qeth_qdio_buffer *buf)
{
2957
	struct qeth_buffer_pool_entry *pool_entry = buf->pool_entry;
F
Frank Blaschka 已提交
2958 2959
	int i;

2960
	if ((card->options.cq == QETH_CQ_ENABLED) && (!buf->rx_skb)) {
2961
		buf->rx_skb = netdev_alloc_skb(card->dev,
2962 2963
					       ETH_HLEN +
					       sizeof(struct ipv6hdr));
2964
		if (!buf->rx_skb)
2965
			return -ENOMEM;
2966 2967
	}

2968 2969 2970 2971 2972 2973 2974
	if (!pool_entry) {
		pool_entry = qeth_find_free_buffer_pool_entry(card);
		if (!pool_entry)
			return -ENOBUFS;

		buf->pool_entry = pool_entry;
	}
F
Frank Blaschka 已提交
2975 2976 2977 2978 2979 2980 2981 2982 2983

	/*
	 * since the buffer is accessed only from the input_tasklet
	 * there shouldn't be a need to synchronize; also, since we use
	 * the QETH_IN_BUF_REQUEUE_THRESHOLD we should never run  out off
	 * buffers
	 */
	for (i = 0; i < QETH_MAX_BUFFER_ELEMENTS(card); ++i) {
		buf->buffer->element[i].length = PAGE_SIZE;
2984
		buf->buffer->element[i].addr =
2985
			page_to_phys(pool_entry->elements[i]);
F
Frank Blaschka 已提交
2986
		if (i == QETH_MAX_BUFFER_ELEMENTS(card) - 1)
2987
			buf->buffer->element[i].eflags = SBAL_EFLAGS_LAST_ENTRY;
F
Frank Blaschka 已提交
2988
		else
2989 2990
			buf->buffer->element[i].eflags = 0;
		buf->buffer->element[i].sflags = 0;
F
Frank Blaschka 已提交
2991 2992 2993 2994
	}
	return 0;
}

J
Julian Wiedmann 已提交
2995 2996 2997 2998 2999 3000 3001 3002 3003 3004 3005 3006
static unsigned int qeth_tx_select_bulk_max(struct qeth_card *card,
					    struct qeth_qdio_out_q *queue)
{
	if (!IS_IQD(card) ||
	    qeth_iqd_is_mcast_queue(card, queue) ||
	    card->options.cq == QETH_CQ_ENABLED ||
	    qdio_get_ssqd_desc(CARD_DDEV(card), &card->ssqd))
		return 1;

	return card->ssqd.mmwc ? card->ssqd.mmwc : 1;
}

3007
static int qeth_init_qdio_queues(struct qeth_card *card)
F
Frank Blaschka 已提交
3008
{
3009
	unsigned int rx_bufs = card->qdio.in_buf_pool.buf_count;
3010
	unsigned int i;
F
Frank Blaschka 已提交
3011 3012
	int rc;

3013
	QETH_CARD_TEXT(card, 2, "initqdqs");
F
Frank Blaschka 已提交
3014 3015

	/* inbound queue */
3016 3017
	qdio_reset_buffers(card->qdio.in_q->qdio_bufs, QDIO_MAX_BUFFERS_PER_Q);
	memset(&card->rx, 0, sizeof(struct qeth_rx));
3018

F
Frank Blaschka 已提交
3019 3020
	qeth_initialize_working_pool_list(card);
	/*give only as many buffers to hardware as we have buffer pool entries*/
3021
	for (i = 0; i < rx_bufs; i++) {
3022 3023 3024 3025 3026
		rc = qeth_init_input_buffer(card, &card->qdio.in_q->bufs[i]);
		if (rc)
			return rc;
	}

3027 3028
	card->qdio.in_q->next_buf_to_init = QDIO_BUFNR(rx_bufs);
	rc = do_QDIO(CARD_DDEV(card), QDIO_FLAG_SYNC_INPUT, 0, 0, rx_bufs);
F
Frank Blaschka 已提交
3029
	if (rc) {
3030
		QETH_CARD_TEXT_(card, 2, "1err%d", rc);
F
Frank Blaschka 已提交
3031 3032
		return rc;
	}
3033 3034 3035 3036 3037 3038 3039

	/* completion */
	rc = qeth_cq_init(card);
	if (rc) {
		return rc;
	}

F
Frank Blaschka 已提交
3040 3041
	/* outbound queue */
	for (i = 0; i < card->qdio.no_out_queues; ++i) {
3042 3043 3044 3045 3046 3047
		struct qeth_qdio_out_q *queue = card->qdio.out_qs[i];

		qdio_reset_buffers(queue->qdio_bufs, QDIO_MAX_BUFFERS_PER_Q);
		queue->max_elements = QETH_MAX_BUFFER_ELEMENTS(card);
		queue->next_buf_to_fill = 0;
		queue->do_pack = 0;
3048
		queue->prev_hdr = NULL;
3049
		queue->coalesced_frames = 0;
3050
		queue->bulk_start = 0;
J
Julian Wiedmann 已提交
3051 3052
		queue->bulk_count = 0;
		queue->bulk_max = qeth_tx_select_bulk_max(card, queue);
3053 3054
		atomic_set(&queue->used_buffers, 0);
		atomic_set(&queue->set_pci_flags_count, 0);
3055
		netdev_tx_reset_queue(netdev_get_tx_queue(card->dev, i));
F
Frank Blaschka 已提交
3056 3057 3058 3059
	}
	return 0;
}

3060
static void qeth_ipa_finalize_cmd(struct qeth_card *card,
3061
				  struct qeth_cmd_buffer *iob)
3062
{
3063
	qeth_mpc_finalize_cmd(card, iob);
3064 3065

	/* override with IPA-specific values: */
3066
	__ipa_cmd(iob)->hdr.seqno = card->seqno.ipa++;
3067 3068
}

3069
void qeth_prepare_ipa_cmd(struct qeth_card *card, struct qeth_cmd_buffer *iob,
3070 3071 3072
			  u16 cmd_length,
			  bool (*match)(struct qeth_cmd_buffer *iob,
					struct qeth_cmd_buffer *reply))
3073 3074
{
	u8 prot_type = qeth_mpc_select_prot_type(card);
3075
	u16 total_length = iob->length;
3076

3077 3078
	qeth_setup_ccw(__ccw_from_cmd(iob), CCW_CMD_WRITE, 0, total_length,
		       iob->data);
3079
	iob->finalize = qeth_ipa_finalize_cmd;
3080
	iob->match = match;
3081

3082
	memcpy(iob->data, IPA_PDU_HEADER, IPA_PDU_HEADER_SIZE);
3083
	memcpy(QETH_IPA_PDU_LEN_TOTAL(iob->data), &total_length, 2);
3084
	memcpy(QETH_IPA_CMD_PROT_TYPE(iob->data), &prot_type, 1);
3085 3086
	memcpy(QETH_IPA_PDU_LEN_PDU1(iob->data), &cmd_length, 2);
	memcpy(QETH_IPA_PDU_LEN_PDU2(iob->data), &cmd_length, 2);
3087 3088
	memcpy(QETH_IPA_CMD_DEST_ADDR(iob->data),
	       &card->token.ulp_connection_r, QETH_MPC_TOKEN_LENGTH);
3089
	memcpy(QETH_IPA_PDU_LEN_PDU3(iob->data), &cmd_length, 2);
3090 3091 3092
}
EXPORT_SYMBOL_GPL(qeth_prepare_ipa_cmd);

3093 3094 3095 3096 3097 3098 3099 3100
static bool qeth_ipa_match_reply(struct qeth_cmd_buffer *iob,
				 struct qeth_cmd_buffer *reply)
{
	struct qeth_ipa_cmd *ipa_reply = __ipa_reply(reply);

	return ipa_reply && (__ipa_cmd(iob)->hdr.seqno == ipa_reply->hdr.seqno);
}

3101 3102 3103 3104 3105 3106
struct qeth_cmd_buffer *qeth_ipa_alloc_cmd(struct qeth_card *card,
					   enum qeth_ipa_cmds cmd_code,
					   enum qeth_prot_versions prot,
					   unsigned int data_length)
{
	struct qeth_cmd_buffer *iob;
3107
	struct qeth_ipacmd_hdr *hdr;
3108 3109 3110 3111 3112 3113 3114

	data_length += offsetof(struct qeth_ipa_cmd, data);
	iob = qeth_alloc_cmd(&card->write, IPA_PDU_HEADER_SIZE + data_length, 1,
			     QETH_IPA_TIMEOUT);
	if (!iob)
		return NULL;

3115
	qeth_prepare_ipa_cmd(card, iob, data_length, qeth_ipa_match_reply);
3116 3117 3118 3119 3120

	hdr = &__ipa_cmd(iob)->hdr;
	hdr->command = cmd_code;
	hdr->initiator = IPA_CMD_INITIATOR_HOST;
	/* hdr->seqno is set by qeth_send_control_data() */
3121
	hdr->adapter_type = QETH_LINK_TYPE_FAST_ETH;
3122 3123 3124 3125
	hdr->rel_adapter_no = (u8) card->dev->dev_port;
	hdr->prim_version_no = IS_LAYER2(card) ? 2 : 1;
	hdr->param_count = 1;
	hdr->prot_version = prot;
3126 3127 3128 3129
	return iob;
}
EXPORT_SYMBOL_GPL(qeth_ipa_alloc_cmd);

3130 3131 3132 3133 3134 3135 3136 3137
static int qeth_send_ipa_cmd_cb(struct qeth_card *card,
				struct qeth_reply *reply, unsigned long data)
{
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;

	return (cmd->hdr.return_code) ? -EIO : 0;
}

E
Eugene Crosser 已提交
3138 3139 3140 3141 3142 3143
/**
 * qeth_send_ipa_cmd() - send an IPA command
 *
 * See qeth_send_control_data() for explanation of the arguments.
 */

F
Frank Blaschka 已提交
3144 3145 3146 3147 3148 3149 3150
int qeth_send_ipa_cmd(struct qeth_card *card, struct qeth_cmd_buffer *iob,
		int (*reply_cb)(struct qeth_card *, struct qeth_reply*,
			unsigned long),
		void *reply_param)
{
	int rc;

C
Carsten Otte 已提交
3151
	QETH_CARD_TEXT(card, 4, "sendipa");
3152

3153
	if (card->read_or_write_problem) {
3154
		qeth_put_cmd(iob);
3155 3156 3157
		return -EIO;
	}

3158 3159
	if (reply_cb == NULL)
		reply_cb = qeth_send_ipa_cmd_cb;
3160
	rc = qeth_send_control_data(card, iob, reply_cb, reply_param);
3161 3162 3163 3164
	if (rc == -ETIME) {
		qeth_clear_ipacmd_list(card);
		qeth_schedule_recovery(card);
	}
F
Frank Blaschka 已提交
3165 3166 3167 3168
	return rc;
}
EXPORT_SYMBOL_GPL(qeth_send_ipa_cmd);

3169 3170 3171 3172 3173 3174 3175 3176 3177 3178 3179
static int qeth_send_startlan_cb(struct qeth_card *card,
				 struct qeth_reply *reply, unsigned long data)
{
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;

	if (cmd->hdr.return_code == IPA_RC_LAN_OFFLINE)
		return -ENETDOWN;

	return (cmd->hdr.return_code) ? -EIO : 0;
}

3180
static int qeth_send_startlan(struct qeth_card *card)
F
Frank Blaschka 已提交
3181
{
3182
	struct qeth_cmd_buffer *iob;
F
Frank Blaschka 已提交
3183

3184
	QETH_CARD_TEXT(card, 2, "strtlan");
F
Frank Blaschka 已提交
3185

3186
	iob = qeth_ipa_alloc_cmd(card, IPA_CMD_STARTLAN, QETH_PROT_NONE, 0);
3187 3188
	if (!iob)
		return -ENOMEM;
3189
	return qeth_send_ipa_cmd(card, iob, qeth_send_startlan_cb, NULL);
F
Frank Blaschka 已提交
3190 3191
}

3192
static int qeth_setadpparms_inspect_rc(struct qeth_ipa_cmd *cmd)
F
Frank Blaschka 已提交
3193
{
3194
	if (!cmd->hdr.return_code)
F
Frank Blaschka 已提交
3195 3196
		cmd->hdr.return_code =
			cmd->data.setadapterparms.hdr.return_code;
3197
	return cmd->hdr.return_code;
F
Frank Blaschka 已提交
3198 3199 3200 3201 3202
}

static int qeth_query_setadapterparms_cb(struct qeth_card *card,
		struct qeth_reply *reply, unsigned long data)
{
3203
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
3204
	struct qeth_query_cmds_supp *query_cmd;
F
Frank Blaschka 已提交
3205

C
Carsten Otte 已提交
3206
	QETH_CARD_TEXT(card, 3, "quyadpcb");
3207
	if (qeth_setadpparms_inspect_rc(cmd))
3208
		return -EIO;
F
Frank Blaschka 已提交
3209

3210 3211 3212 3213 3214 3215
	query_cmd = &cmd->data.setadapterparms.data.query_cmds_supp;
	if (query_cmd->lan_type & 0x7f) {
		if (!qeth_is_supported_link_type(card, query_cmd->lan_type))
			return -EPROTONOSUPPORT;

		card->info.link_type = query_cmd->lan_type;
3216
		QETH_CARD_TEXT_(card, 2, "lnk %d", card->info.link_type);
3217
	}
3218 3219

	card->options.adp.supported = query_cmd->supported_cmds;
3220
	return 0;
F
Frank Blaschka 已提交
3221 3222
}

S
Stefan Raspl 已提交
3223
static struct qeth_cmd_buffer *qeth_get_adapter_cmd(struct qeth_card *card,
3224 3225
						    enum qeth_ipa_setadp_cmd adp_cmd,
						    unsigned int data_length)
F
Frank Blaschka 已提交
3226
{
3227
	struct qeth_ipacmd_setadpparms_hdr *hdr;
F
Frank Blaschka 已提交
3228 3229
	struct qeth_cmd_buffer *iob;

3230 3231 3232 3233 3234 3235
	iob = qeth_ipa_alloc_cmd(card, IPA_CMD_SETADAPTERPARMS, QETH_PROT_IPV4,
				 data_length +
				 offsetof(struct qeth_ipacmd_setadpparms,
					  data));
	if (!iob)
		return NULL;
F
Frank Blaschka 已提交
3236

3237 3238 3239 3240 3241
	hdr = &__ipa_cmd(iob)->data.setadapterparms.hdr;
	hdr->cmdlength = sizeof(*hdr) + data_length;
	hdr->command_code = adp_cmd;
	hdr->used_total = 1;
	hdr->seq_no = 1;
F
Frank Blaschka 已提交
3242 3243 3244
	return iob;
}

3245
static int qeth_query_setadapterparms(struct qeth_card *card)
F
Frank Blaschka 已提交
3246 3247 3248 3249
{
	int rc;
	struct qeth_cmd_buffer *iob;

C
Carsten Otte 已提交
3250
	QETH_CARD_TEXT(card, 3, "queryadp");
F
Frank Blaschka 已提交
3251
	iob = qeth_get_adapter_cmd(card, IPA_SETADP_QUERY_COMMANDS_SUPPORTED,
3252
				   SETADP_DATA_SIZEOF(query_cmds_supp));
3253 3254
	if (!iob)
		return -ENOMEM;
F
Frank Blaschka 已提交
3255 3256 3257 3258
	rc = qeth_send_ipa_cmd(card, iob, qeth_query_setadapterparms_cb, NULL);
	return rc;
}

3259 3260 3261 3262 3263
static int qeth_query_ipassists_cb(struct qeth_card *card,
		struct qeth_reply *reply, unsigned long data)
{
	struct qeth_ipa_cmd *cmd;

3264
	QETH_CARD_TEXT(card, 2, "qipasscb");
3265 3266

	cmd = (struct qeth_ipa_cmd *) data;
3267 3268

	switch (cmd->hdr.return_code) {
3269 3270
	case IPA_RC_SUCCESS:
		break;
3271 3272
	case IPA_RC_NOTSUPP:
	case IPA_RC_L2_UNSUPPORTED_CMD:
3273
		QETH_CARD_TEXT(card, 2, "ipaunsup");
3274 3275
		card->options.ipa4.supported |= IPA_SETADAPTERPARMS;
		card->options.ipa6.supported |= IPA_SETADAPTERPARMS;
3276
		return -EOPNOTSUPP;
3277
	default:
3278 3279 3280
		QETH_DBF_MESSAGE(1, "IPA_CMD_QIPASSIST on device %x: Unhandled rc=%#x\n",
				 CARD_DEVID(card), cmd->hdr.return_code);
		return -EIO;
3281 3282
	}

3283 3284 3285 3286 3287
	if (cmd->hdr.prot_version == QETH_PROT_IPV4)
		card->options.ipa4 = cmd->hdr.assists;
	else if (cmd->hdr.prot_version == QETH_PROT_IPV6)
		card->options.ipa6 = cmd->hdr.assists;
	else
3288 3289
		QETH_DBF_MESSAGE(1, "IPA_CMD_QIPASSIST on device %x: Flawed LIC detected\n",
				 CARD_DEVID(card));
3290 3291 3292
	return 0;
}

3293 3294
static int qeth_query_ipassists(struct qeth_card *card,
				enum qeth_prot_versions prot)
3295 3296 3297 3298
{
	int rc;
	struct qeth_cmd_buffer *iob;

3299
	QETH_CARD_TEXT_(card, 2, "qipassi%i", prot);
3300
	iob = qeth_ipa_alloc_cmd(card, IPA_CMD_QIPASSIST, prot, 0);
3301 3302
	if (!iob)
		return -ENOMEM;
3303 3304 3305 3306
	rc = qeth_send_ipa_cmd(card, iob, qeth_query_ipassists_cb, NULL);
	return rc;
}

3307 3308 3309
static int qeth_query_switch_attributes_cb(struct qeth_card *card,
				struct qeth_reply *reply, unsigned long data)
{
3310
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
3311
	struct qeth_query_switch_attributes *attrs;
3312
	struct qeth_switch_info *sw_info;
3313 3314

	QETH_CARD_TEXT(card, 2, "qswiatcb");
3315
	if (qeth_setadpparms_inspect_rc(cmd))
3316
		return -EIO;
3317

3318 3319 3320 3321 3322 3323
	sw_info = (struct qeth_switch_info *)reply->param;
	attrs = &cmd->data.setadapterparms.data.query_switch_attributes;
	sw_info->capabilities = attrs->capabilities;
	sw_info->settings = attrs->settings;
	QETH_CARD_TEXT_(card, 2, "%04x%04x", sw_info->capabilities,
			sw_info->settings);
3324 3325 3326 3327 3328 3329 3330 3331 3332 3333 3334 3335 3336
	return 0;
}

int qeth_query_switch_attributes(struct qeth_card *card,
				 struct qeth_switch_info *sw_info)
{
	struct qeth_cmd_buffer *iob;

	QETH_CARD_TEXT(card, 2, "qswiattr");
	if (!qeth_adp_supported(card, IPA_SETADP_QUERY_SWITCH_ATTRIBUTES))
		return -EOPNOTSUPP;
	if (!netif_carrier_ok(card->dev))
		return -ENOMEDIUM;
3337
	iob = qeth_get_adapter_cmd(card, IPA_SETADP_QUERY_SWITCH_ATTRIBUTES, 0);
3338 3339
	if (!iob)
		return -ENOMEM;
3340 3341 3342 3343
	return qeth_send_ipa_cmd(card, iob,
				qeth_query_switch_attributes_cb, sw_info);
}

3344 3345 3346 3347 3348 3349 3350 3351 3352 3353 3354 3355 3356 3357 3358 3359 3360 3361 3362
struct qeth_cmd_buffer *qeth_get_diag_cmd(struct qeth_card *card,
					  enum qeth_diags_cmds sub_cmd,
					  unsigned int data_length)
{
	struct qeth_ipacmd_diagass *cmd;
	struct qeth_cmd_buffer *iob;

	iob = qeth_ipa_alloc_cmd(card, IPA_CMD_SET_DIAG_ASS, QETH_PROT_NONE,
				 DIAG_HDR_LEN + data_length);
	if (!iob)
		return NULL;

	cmd = &__ipa_cmd(iob)->data.diagass;
	cmd->subcmd_len = DIAG_SUB_HDR_LEN + data_length;
	cmd->subcmd = sub_cmd;
	return iob;
}
EXPORT_SYMBOL_GPL(qeth_get_diag_cmd);

3363 3364 3365
static int qeth_query_setdiagass_cb(struct qeth_card *card,
		struct qeth_reply *reply, unsigned long data)
{
3366 3367
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
	u16 rc = cmd->hdr.return_code;
3368

3369
	if (rc) {
3370
		QETH_CARD_TEXT_(card, 2, "diagq:%x", rc);
3371 3372 3373 3374
		return -EIO;
	}

	card->info.diagass_support = cmd->data.diagass.ext;
3375 3376 3377 3378 3379 3380 3381
	return 0;
}

static int qeth_query_setdiagass(struct qeth_card *card)
{
	struct qeth_cmd_buffer *iob;

3382
	QETH_CARD_TEXT(card, 2, "qdiagass");
3383
	iob = qeth_get_diag_cmd(card, QETH_DIAGS_CMD_QUERY, 0);
3384 3385
	if (!iob)
		return -ENOMEM;
3386 3387 3388 3389 3390 3391 3392 3393 3394
	return qeth_send_ipa_cmd(card, iob, qeth_query_setdiagass_cb, NULL);
}

static void qeth_get_trap_id(struct qeth_card *card, struct qeth_trap_id *tid)
{
	unsigned long info = get_zeroed_page(GFP_KERNEL);
	struct sysinfo_2_2_2 *info222 = (struct sysinfo_2_2_2 *)info;
	struct sysinfo_3_2_2 *info322 = (struct sysinfo_3_2_2 *)info;
	struct ccw_dev_id ccwid;
3395
	int level;
3396 3397 3398 3399 3400 3401 3402

	tid->chpid = card->info.chpid;
	ccw_device_get_id(CARD_RDEV(card), &ccwid);
	tid->ssid = ccwid.ssid;
	tid->devno = ccwid.devno;
	if (!info)
		return;
3403 3404
	level = stsi(NULL, 0, 0, 0);
	if ((level >= 2) && (stsi(info222, 2, 2, 2) == 0))
3405
		tid->lparnr = info222->lpar_number;
3406
	if ((level >= 3) && (stsi(info322, 3, 2, 2) == 0)) {
3407 3408 3409 3410 3411 3412 3413 3414 3415
		EBCASC(info322->vm[0].name, sizeof(info322->vm[0].name));
		memcpy(tid->vmname, info322->vm[0].name, sizeof(tid->vmname));
	}
	free_page(info);
}

static int qeth_hw_trap_cb(struct qeth_card *card,
		struct qeth_reply *reply, unsigned long data)
{
3416 3417
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
	u16 rc = cmd->hdr.return_code;
3418

3419
	if (rc) {
3420
		QETH_CARD_TEXT_(card, 2, "trapc:%x", rc);
3421 3422
		return -EIO;
	}
3423 3424 3425 3426 3427 3428 3429 3430
	return 0;
}

int qeth_hw_trap(struct qeth_card *card, enum qeth_diags_trap_action action)
{
	struct qeth_cmd_buffer *iob;
	struct qeth_ipa_cmd *cmd;

3431
	QETH_CARD_TEXT(card, 2, "diagtrap");
3432
	iob = qeth_get_diag_cmd(card, QETH_DIAGS_CMD_TRAP, 64);
3433 3434
	if (!iob)
		return -ENOMEM;
3435
	cmd = __ipa_cmd(iob);
3436 3437 3438 3439 3440 3441 3442 3443 3444 3445 3446 3447 3448 3449 3450 3451 3452 3453 3454
	cmd->data.diagass.type = 1;
	cmd->data.diagass.action = action;
	switch (action) {
	case QETH_DIAGS_TRAP_ARM:
		cmd->data.diagass.options = 0x0003;
		cmd->data.diagass.ext = 0x00010000 +
			sizeof(struct qeth_trap_id);
		qeth_get_trap_id(card,
			(struct qeth_trap_id *)cmd->data.diagass.cdata);
		break;
	case QETH_DIAGS_TRAP_DISARM:
		cmd->data.diagass.options = 0x0001;
		break;
	case QETH_DIAGS_TRAP_CAPTURE:
		break;
	}
	return qeth_send_ipa_cmd(card, iob, qeth_hw_trap_cb, NULL);
}

3455 3456 3457 3458
static int qeth_check_qdio_errors(struct qeth_card *card,
				  struct qdio_buffer *buf,
				  unsigned int qdio_error,
				  const char *dbftext)
F
Frank Blaschka 已提交
3459
{
J
Jan Glauber 已提交
3460
	if (qdio_error) {
C
Carsten Otte 已提交
3461
		QETH_CARD_TEXT(card, 2, dbftext);
C
Carsten Otte 已提交
3462
		QETH_CARD_TEXT_(card, 2, " F15=%02X",
3463
			       buf->element[15].sflags);
C
Carsten Otte 已提交
3464
		QETH_CARD_TEXT_(card, 2, " F14=%02X",
3465
			       buf->element[14].sflags);
C
Carsten Otte 已提交
3466
		QETH_CARD_TEXT_(card, 2, " qerr=%X", qdio_error);
3467
		if ((buf->element[15].sflags) == 0x12) {
3468
			QETH_CARD_STAT_INC(card, rx_fifo_errors);
3469 3470 3471
			return 0;
		} else
			return 1;
F
Frank Blaschka 已提交
3472 3473 3474 3475
	}
	return 0;
}

3476 3477
static unsigned int qeth_rx_refill_queue(struct qeth_card *card,
					 unsigned int count)
F
Frank Blaschka 已提交
3478 3479
{
	struct qeth_qdio_q *queue = card->qdio.in_q;
3480
	struct list_head *lh;
F
Frank Blaschka 已提交
3481 3482 3483 3484 3485 3486 3487 3488 3489
	int i;
	int rc;
	int newcount = 0;

	/* only requeue at a certain threshold to avoid SIGAs */
	if (count >= QETH_IN_BUF_REQUEUE_THRESHOLD(card)) {
		for (i = queue->next_buf_to_init;
		     i < queue->next_buf_to_init + count; ++i) {
			if (qeth_init_input_buffer(card,
J
Julian Wiedmann 已提交
3490
				&queue->bufs[QDIO_BUFNR(i)])) {
F
Frank Blaschka 已提交
3491 3492 3493 3494 3495 3496 3497 3498 3499 3500 3501 3502 3503 3504 3505
				break;
			} else {
				newcount++;
			}
		}

		if (newcount < count) {
			/* we are in memory shortage so we switch back to
			   traditional skb allocation and drop packages */
			atomic_set(&card->force_alloc_skb, 3);
			count = newcount;
		} else {
			atomic_add_unless(&card->force_alloc_skb, -1, 0);
		}

3506 3507 3508 3509 3510 3511 3512 3513 3514 3515
		if (!count) {
			i = 0;
			list_for_each(lh, &card->qdio.in_buf_pool.entry_list)
				i++;
			if (i == card->qdio.in_buf_pool.buf_count) {
				QETH_CARD_TEXT(card, 2, "qsarbw");
				schedule_delayed_work(
					&card->buffer_reclaim_work,
					QETH_RECLAIM_WORK_TIME);
			}
3516
			return 0;
3517 3518
		}

J
Jan Glauber 已提交
3519 3520
		rc = do_QDIO(CARD_DDEV(card), QDIO_FLAG_SYNC_INPUT, 0,
			     queue->next_buf_to_init, count);
F
Frank Blaschka 已提交
3521
		if (rc) {
C
Carsten Otte 已提交
3522
			QETH_CARD_TEXT(card, 2, "qinberr");
F
Frank Blaschka 已提交
3523
		}
J
Julian Wiedmann 已提交
3524 3525
		queue->next_buf_to_init = QDIO_BUFNR(queue->next_buf_to_init +
						     count);
3526
		return count;
F
Frank Blaschka 已提交
3527
	}
3528 3529

	return 0;
F
Frank Blaschka 已提交
3530
}
3531 3532 3533

static void qeth_buffer_reclaim_work(struct work_struct *work)
{
3534 3535 3536
	struct qeth_card *card = container_of(to_delayed_work(work),
					      struct qeth_card,
					      buffer_reclaim_work);
3537

3538 3539 3540 3541
	local_bh_disable();
	napi_schedule(&card->napi);
	/* kick-start the NAPI softirq: */
	local_bh_enable();
3542
}
F
Frank Blaschka 已提交
3543

3544
static void qeth_handle_send_error(struct qeth_card *card,
J
Jan Glauber 已提交
3545
		struct qeth_qdio_out_buffer *buffer, unsigned int qdio_err)
F
Frank Blaschka 已提交
3546
{
3547
	int sbalf15 = buffer->buffer->element[15].sflags;
F
Frank Blaschka 已提交
3548

C
Carsten Otte 已提交
3549
	QETH_CARD_TEXT(card, 6, "hdsnderr");
3550
	qeth_check_qdio_errors(card, buffer->buffer, qdio_err, "qouterr");
3551 3552

	if (!qdio_err)
3553
		return;
3554 3555

	if ((sbalf15 >= 15) && (sbalf15 <= 31))
3556
		return;
3557

C
Carsten Otte 已提交
3558 3559
	QETH_CARD_TEXT(card, 1, "lnkfail");
	QETH_CARD_TEXT_(card, 1, "%04x %02x",
3560
		       (u16)qdio_err, (u8)sbalf15);
F
Frank Blaschka 已提交
3561 3562
}

3563 3564 3565 3566 3567 3568 3569 3570 3571 3572 3573 3574 3575 3576 3577 3578
/**
 * qeth_prep_flush_pack_buffer - Prepares flushing of a packing buffer.
 * @queue: queue to check for packing buffer
 *
 * Returns number of buffers that were prepared for flush.
 */
static int qeth_prep_flush_pack_buffer(struct qeth_qdio_out_q *queue)
{
	struct qeth_qdio_out_buffer *buffer;

	buffer = queue->bufs[queue->next_buf_to_fill];
	if ((atomic_read(&buffer->state) == QETH_QDIO_BUF_EMPTY) &&
	    (buffer->next_element_to_fill > 0)) {
		/* it's a packing buffer */
		atomic_set(&buffer->state, QETH_QDIO_BUF_PRIMED);
		queue->next_buf_to_fill =
J
Julian Wiedmann 已提交
3579
			QDIO_BUFNR(queue->next_buf_to_fill + 1);
3580 3581 3582 3583 3584
		return 1;
	}
	return 0;
}

F
Frank Blaschka 已提交
3585 3586 3587 3588 3589 3590 3591 3592 3593 3594
/*
 * Switched to packing state if the number of used buffers on a queue
 * reaches a certain limit.
 */
static void qeth_switch_to_packing_if_needed(struct qeth_qdio_out_q *queue)
{
	if (!queue->do_pack) {
		if (atomic_read(&queue->used_buffers)
		    >= QETH_HIGH_WATERMARK_PACK){
			/* switch non-PACKING -> PACKING */
C
Carsten Otte 已提交
3595
			QETH_CARD_TEXT(queue->card, 6, "np->pack");
3596
			QETH_TXQ_STAT_INC(queue, packing_mode_switch);
F
Frank Blaschka 已提交
3597 3598 3599 3600 3601 3602 3603 3604 3605 3606 3607 3608 3609 3610 3611 3612 3613
			queue->do_pack = 1;
		}
	}
}

/*
 * Switches from packing to non-packing mode. If there is a packing
 * buffer on the queue this buffer will be prepared to be flushed.
 * In that case 1 is returned to inform the caller. If no buffer
 * has to be flushed, zero is returned.
 */
static int qeth_switch_to_nonpacking_if_needed(struct qeth_qdio_out_q *queue)
{
	if (queue->do_pack) {
		if (atomic_read(&queue->used_buffers)
		    <= QETH_LOW_WATERMARK_PACK) {
			/* switch PACKING -> non-PACKING */
C
Carsten Otte 已提交
3614
			QETH_CARD_TEXT(queue->card, 6, "pack->np");
3615
			QETH_TXQ_STAT_INC(queue, packing_mode_switch);
F
Frank Blaschka 已提交
3616
			queue->do_pack = 0;
3617
			return qeth_prep_flush_pack_buffer(queue);
F
Frank Blaschka 已提交
3618 3619 3620 3621 3622
		}
	}
	return 0;
}

J
Jan Glauber 已提交
3623 3624
static void qeth_flush_buffers(struct qeth_qdio_out_q *queue, int index,
			       int count)
F
Frank Blaschka 已提交
3625
{
3626 3627
	struct qeth_qdio_out_buffer *buf = queue->bufs[index];
	unsigned int qdio_flags = QDIO_FLAG_SYNC_OUTPUT;
3628
	struct qeth_card *card = queue->card;
F
Frank Blaschka 已提交
3629 3630 3631 3632
	int rc;
	int i;

	for (i = index; i < index + count; ++i) {
J
Julian Wiedmann 已提交
3633
		unsigned int bidx = QDIO_BUFNR(i);
3634
		struct sk_buff *skb;
J
Julian Wiedmann 已提交
3635

3636
		buf = queue->bufs[bidx];
3637 3638
		buf->buffer->element[buf->next_element_to_fill - 1].eflags |=
				SBAL_EFLAGS_LAST_ENTRY;
3639
		queue->coalesced_frames += buf->frames;
F
Frank Blaschka 已提交
3640

3641 3642 3643
		if (queue->bufstates)
			queue->bufstates[bidx].user = buf;

3644 3645 3646 3647
		if (IS_IQD(card)) {
			skb_queue_walk(&buf->skb_list, skb)
				skb_tx_timestamp(skb);
		}
3648
	}
F
Frank Blaschka 已提交
3649

3650
	if (!IS_IQD(card)) {
F
Frank Blaschka 已提交
3651 3652 3653 3654 3655 3656 3657 3658
		if (!queue->do_pack) {
			if ((atomic_read(&queue->used_buffers) >=
				(QETH_HIGH_WATERMARK_PACK -
				 QETH_WATERMARK_PACK_FUZZ)) &&
			    !atomic_read(&queue->set_pci_flags_count)) {
				/* it's likely that we'll go to packing
				 * mode soon */
				atomic_inc(&queue->set_pci_flags_count);
3659
				buf->buffer->element[0].sflags |= SBAL_SFLAGS0_PCI_REQ;
F
Frank Blaschka 已提交
3660 3661 3662 3663 3664 3665 3666 3667 3668 3669 3670 3671
			}
		} else {
			if (!atomic_read(&queue->set_pci_flags_count)) {
				/*
				 * there's no outstanding PCI any more, so we
				 * have to request a PCI to be sure the the PCI
				 * will wake at some time in the future then we
				 * can flush packed buffers that might still be
				 * hanging around, which can happen if no
				 * further send was requested by the stack
				 */
				atomic_inc(&queue->set_pci_flags_count);
3672
				buf->buffer->element[0].sflags |= SBAL_SFLAGS0_PCI_REQ;
F
Frank Blaschka 已提交
3673 3674
			}
		}
3675 3676 3677

		if (atomic_read(&queue->set_pci_flags_count))
			qdio_flags |= QDIO_FLAG_PCI_OUT;
F
Frank Blaschka 已提交
3678 3679
	}

3680
	QETH_TXQ_STAT_INC(queue, doorbell);
F
Frank Blaschka 已提交
3681
	rc = do_QDIO(CARD_DDEV(queue->card), qdio_flags,
J
Jan Glauber 已提交
3682
		     queue->queue_no, index, count);
3683

3684 3685 3686 3687 3688 3689 3690 3691 3692 3693 3694 3695 3696 3697 3698 3699 3700
	switch (rc) {
	case 0:
	case -ENOBUFS:
		/* ignore temporary SIGA errors without busy condition */

		/* Fake the TX completion interrupt: */
		if (IS_IQD(card)) {
			unsigned int frames = READ_ONCE(queue->max_coalesced_frames);
			unsigned int usecs = READ_ONCE(queue->coalesce_usecs);

			if (frames && queue->coalesced_frames >= frames) {
				napi_schedule(&queue->napi);
				queue->coalesced_frames = 0;
				QETH_TXQ_STAT_INC(queue, coal_frames);
			} else if (usecs) {
				qeth_tx_arm_timer(queue, usecs);
			}
3701
		}
3702

3703 3704
		break;
	default:
C
Carsten Otte 已提交
3705
		QETH_CARD_TEXT(queue->card, 2, "flushbuf");
3706 3707 3708
		QETH_CARD_TEXT_(queue->card, 2, " q%d", queue->queue_no);
		QETH_CARD_TEXT_(queue->card, 2, " idx%d", index);
		QETH_CARD_TEXT_(queue->card, 2, " c%d", count);
C
Carsten Otte 已提交
3709
		QETH_CARD_TEXT_(queue->card, 2, " err%d", rc);
3710

F
Frank Blaschka 已提交
3711 3712 3713 3714 3715 3716
		/* this must not happen under normal circumstances. if it
		 * happens something is really wrong -> recover */
		qeth_schedule_recovery(queue->card);
	}
}

3717 3718
static void qeth_flush_queue(struct qeth_qdio_out_q *queue)
{
J
Julian Wiedmann 已提交
3719
	qeth_flush_buffers(queue, queue->bulk_start, queue->bulk_count);
3720

J
Julian Wiedmann 已提交
3721
	queue->bulk_start = QDIO_BUFNR(queue->bulk_start + queue->bulk_count);
3722
	queue->prev_hdr = NULL;
J
Julian Wiedmann 已提交
3723
	queue->bulk_count = 0;
3724 3725
}

F
Frank Blaschka 已提交
3726 3727 3728 3729 3730 3731 3732 3733
static void qeth_check_outbound_queue(struct qeth_qdio_out_q *queue)
{
	/*
	 * check if weed have to switch to non-packing mode or if
	 * we have to get a pci flag out on the queue
	 */
	if ((atomic_read(&queue->used_buffers) <= QETH_LOW_WATERMARK_PACK) ||
	    !atomic_read(&queue->set_pci_flags_count)) {
3734 3735 3736 3737 3738 3739 3740 3741 3742 3743 3744 3745 3746 3747
		unsigned int index, flush_cnt;
		bool q_was_packing;

		spin_lock(&queue->lock);

		index = queue->next_buf_to_fill;
		q_was_packing = queue->do_pack;

		flush_cnt = qeth_switch_to_nonpacking_if_needed(queue);
		if (!flush_cnt && !atomic_read(&queue->set_pci_flags_count))
			flush_cnt = qeth_prep_flush_pack_buffer(queue);

		if (flush_cnt) {
			qeth_flush_buffers(queue, index, flush_cnt);
3748 3749
			if (q_was_packing)
				QETH_TXQ_STAT_ADD(queue, bufs_pack, flush_cnt);
F
Frank Blaschka 已提交
3750
		}
3751 3752

		spin_unlock(&queue->lock);
F
Frank Blaschka 已提交
3753 3754 3755
	}
}

3756
static void qeth_qdio_poll(struct ccw_device *cdev, unsigned long card_ptr)
3757 3758 3759
{
	struct qeth_card *card = (struct qeth_card *)card_ptr;

3760
	napi_schedule_irqoff(&card->napi);
3761 3762
}

3763 3764 3765 3766 3767 3768 3769 3770 3771 3772 3773 3774 3775
int qeth_configure_cq(struct qeth_card *card, enum qeth_cq cq)
{
	int rc;

	if (card->options.cq ==  QETH_CQ_NOTAVAILABLE) {
		rc = -1;
		goto out;
	} else {
		if (card->options.cq == cq) {
			rc = 0;
			goto out;
		}

3776
		qeth_free_qdio_queues(card);
3777 3778 3779 3780 3781 3782 3783 3784 3785
		card->options.cq = cq;
		rc = 0;
	}
out:
	return rc;

}
EXPORT_SYMBOL_GPL(qeth_configure_cq);

3786 3787 3788 3789
static void qeth_qdio_cq_handler(struct qeth_card *card, unsigned int qdio_err,
				 unsigned int queue, int first_element,
				 int count)
{
3790 3791 3792 3793 3794 3795 3796 3797 3798
	struct qeth_qdio_q *cq = card->qdio.c_q;
	int i;
	int rc;

	QETH_CARD_TEXT_(card, 5, "qcqhe%d", first_element);
	QETH_CARD_TEXT_(card, 5, "qcqhc%d", count);
	QETH_CARD_TEXT_(card, 5, "qcqherr%d", qdio_err);

	if (qdio_err) {
3799
		netif_tx_stop_all_queues(card->dev);
3800
		qeth_schedule_recovery(card);
3801
		return;
3802 3803 3804
	}

	for (i = first_element; i < first_element + count; ++i) {
J
Julian Wiedmann 已提交
3805
		struct qdio_buffer *buffer = cq->qdio_bufs[QDIO_BUFNR(i)];
3806
		int e = 0;
3807

3808 3809
		while ((e < QDIO_MAX_ELEMENTS_PER_BUFFER) &&
		       buffer->element[e].addr) {
3810
			unsigned long phys_aob_addr = buffer->element[e].addr;
3811 3812 3813 3814

			qeth_qdio_handle_aob(card, phys_aob_addr);
			++e;
		}
3815
		qeth_scrub_qdio_buffer(buffer, QDIO_MAX_ELEMENTS_PER_BUFFER);
3816 3817 3818 3819 3820 3821 3822 3823 3824
	}
	rc = do_QDIO(CARD_DDEV(card), QDIO_FLAG_SYNC_INPUT, queue,
		    card->qdio.c_q->next_buf_to_init,
		    count);
	if (rc) {
		dev_warn(&card->gdev->dev,
			"QDIO reported an error, rc=%i\n", rc);
		QETH_CARD_TEXT(card, 2, "qcqherr");
	}
J
Julian Wiedmann 已提交
3825 3826

	cq->next_buf_to_init = QDIO_BUFNR(cq->next_buf_to_init + count);
3827 3828
}

3829 3830 3831 3832
static void qeth_qdio_input_handler(struct ccw_device *ccwdev,
				    unsigned int qdio_err, int queue,
				    int first_elem, int count,
				    unsigned long card_ptr)
3833 3834 3835
{
	struct qeth_card *card = (struct qeth_card *)card_ptr;

3836 3837 3838
	QETH_CARD_TEXT_(card, 2, "qihq%d", queue);
	QETH_CARD_TEXT_(card, 2, "qiec%d", qdio_err);

3839
	if (qdio_err)
3840 3841 3842
		qeth_schedule_recovery(card);
}

3843 3844 3845 3846
static void qeth_qdio_output_handler(struct ccw_device *ccwdev,
				     unsigned int qdio_error, int __queue,
				     int first_element, int count,
				     unsigned long card_ptr)
F
Frank Blaschka 已提交
3847 3848 3849
{
	struct qeth_card *card        = (struct qeth_card *) card_ptr;
	struct qeth_qdio_out_q *queue = card->qdio.out_qs[__queue];
3850
	struct net_device *dev = card->dev;
3851
	struct netdev_queue *txq;
F
Frank Blaschka 已提交
3852 3853
	int i;

C
Carsten Otte 已提交
3854
	QETH_CARD_TEXT(card, 6, "qdouhdl");
3855
	if (qdio_error & QDIO_ERROR_FATAL) {
C
Carsten Otte 已提交
3856
		QETH_CARD_TEXT(card, 2, "achkcond");
3857
		netif_tx_stop_all_queues(dev);
J
Jan Glauber 已提交
3858 3859
		qeth_schedule_recovery(card);
		return;
F
Frank Blaschka 已提交
3860
	}
3861

F
Frank Blaschka 已提交
3862
	for (i = first_element; i < (first_element + count); ++i) {
J
Julian Wiedmann 已提交
3863 3864 3865 3866
		struct qeth_qdio_out_buffer *buf = queue->bufs[QDIO_BUFNR(i)];

		qeth_handle_send_error(card, buf, qdio_error);
		qeth_clear_output_buffer(queue, buf, qdio_error, 0);
F
Frank Blaschka 已提交
3867
	}
3868

F
Frank Blaschka 已提交
3869
	atomic_sub(count, &queue->used_buffers);
3870
	qeth_check_outbound_queue(queue);
F
Frank Blaschka 已提交
3871

3872 3873 3874 3875 3876 3877 3878
	txq = netdev_get_tx_queue(dev, __queue);
	/* xmit may have observed the full-condition, but not yet stopped the
	 * txq. In which case the code below won't trigger. So before returning,
	 * xmit will re-check the txq's fill level and wake it up if needed.
	 */
	if (netif_tx_queue_stopped(txq) && !qeth_out_queue_is_full(queue))
		netif_tx_wake_queue(txq);
F
Frank Blaschka 已提交
3879 3880
}

3881 3882 3883
/**
 * Note: Function assumes that we have 4 outbound queues.
 */
3884
int qeth_get_priority_queue(struct qeth_card *card, struct sk_buff *skb)
F
Frank Blaschka 已提交
3885
{
J
Julian Wiedmann 已提交
3886
	struct vlan_ethhdr *veth = vlan_eth_hdr(skb);
3887 3888 3889 3890 3891
	u8 tos;

	switch (card->qdio.do_prio_queueing) {
	case QETH_PRIO_Q_ING_TOS:
	case QETH_PRIO_Q_ING_PREC:
3892 3893
		switch (vlan_get_protocol(skb)) {
		case htons(ETH_P_IP):
3894 3895
			tos = ipv4_get_dsfield(ip_hdr(skb));
			break;
3896
		case htons(ETH_P_IPV6):
3897 3898 3899 3900
			tos = ipv6_get_dsfield(ipv6_hdr(skb));
			break;
		default:
			return card->qdio.default_out_queue;
F
Frank Blaschka 已提交
3901
		}
3902
		if (card->qdio.do_prio_queueing == QETH_PRIO_Q_ING_PREC)
J
Julian Wiedmann 已提交
3903
			return ~tos >> 6 & 3;
3904
		if (tos & IPTOS_MINCOST)
J
Julian Wiedmann 已提交
3905
			return 3;
3906 3907 3908 3909 3910 3911
		if (tos & IPTOS_RELIABILITY)
			return 2;
		if (tos & IPTOS_THROUGHPUT)
			return 1;
		if (tos & IPTOS_LOWDELAY)
			return 0;
3912 3913 3914 3915
		break;
	case QETH_PRIO_Q_ING_SKB:
		if (skb->priority > 5)
			return 0;
J
Julian Wiedmann 已提交
3916
		return ~skb->priority >> 1 & 3;
3917
	case QETH_PRIO_Q_ING_VLAN:
J
Julian Wiedmann 已提交
3918 3919 3920
		if (veth->h_vlan_proto == htons(ETH_P_8021Q))
			return ~ntohs(veth->h_vlan_TCI) >>
			       (VLAN_PRIO_SHIFT + 1) & 3;
3921
		break;
3922 3923
	case QETH_PRIO_Q_ING_FIXED:
		return card->qdio.default_out_queue;
F
Frank Blaschka 已提交
3924
	default:
3925
		break;
F
Frank Blaschka 已提交
3926
	}
3927
	return card->qdio.default_out_queue;
F
Frank Blaschka 已提交
3928 3929 3930
}
EXPORT_SYMBOL_GPL(qeth_get_priority_queue);

3931 3932 3933 3934 3935 3936 3937
/**
 * qeth_get_elements_for_frags() -	find number of SBALEs for skb frags.
 * @skb:				SKB address
 *
 * Returns the number of pages, and thus QDIO buffer elements, needed to cover
 * fragmented part of the SKB. Returns zero for linear SKB.
 */
3938
static int qeth_get_elements_for_frags(struct sk_buff *skb)
3939
{
3940
	int cnt, elements = 0;
3941 3942

	for (cnt = 0; cnt < skb_shinfo(skb)->nr_frags; cnt++) {
3943
		skb_frag_t *frag = &skb_shinfo(skb)->frags[cnt];
3944 3945 3946 3947

		elements += qeth_get_elements_for_range(
			(addr_t)skb_frag_address(frag),
			(addr_t)skb_frag_address(frag) + skb_frag_size(frag));
3948 3949 3950 3951
	}
	return elements;
}

3952 3953 3954 3955 3956 3957 3958 3959 3960 3961
/**
 * qeth_count_elements() -	Counts the number of QDIO buffer elements needed
 *				to transmit an skb.
 * @skb:			the skb to operate on.
 * @data_offset:		skip this part of the skb's linear data
 *
 * Returns the number of pages, and thus QDIO buffer elements, needed to map the
 * skb's data (both its linear part and paged fragments).
 */
unsigned int qeth_count_elements(struct sk_buff *skb, unsigned int data_offset)
3962 3963 3964 3965 3966 3967 3968 3969 3970
{
	unsigned int elements = qeth_get_elements_for_frags(skb);
	addr_t end = (addr_t)skb->data + skb_headlen(skb);
	addr_t start = (addr_t)skb->data + data_offset;

	if (start != end)
		elements += qeth_get_elements_for_range(start, end);
	return elements;
}
3971
EXPORT_SYMBOL_GPL(qeth_count_elements);
F
Frank Blaschka 已提交
3972

3973 3974
#define QETH_HDR_CACHE_OBJ_SIZE		(sizeof(struct qeth_hdr_tso) + \
					 MAX_TCP_HEADER)
3975

3976
/**
3977 3978
 * qeth_add_hw_header() - add a HW header to an skb.
 * @skb: skb that the HW header should be added to.
3979 3980
 * @hdr: double pointer to a qeth_hdr. When returning with >= 0,
 *	 it contains a valid pointer to a qeth_hdr.
3981 3982 3983
 * @hdr_len: length of the HW header.
 * @proto_len: length of protocol headers that need to be in same page as the
 *	       HW header.
3984 3985 3986 3987
 *
 * Returns the pushed length. If the header can't be pushed on
 * (eg. because it would cross a page boundary), it is allocated from
 * the cache instead and 0 is returned.
3988
 * The number of needed buffer elements is returned in @elements.
3989 3990
 * Error to create the hdr is indicated by returning with < 0.
 */
3991 3992 3993 3994
static int qeth_add_hw_header(struct qeth_qdio_out_q *queue,
			      struct sk_buff *skb, struct qeth_hdr **hdr,
			      unsigned int hdr_len, unsigned int proto_len,
			      unsigned int *elements)
3995
{
3996
	gfp_t gfp = GFP_ATOMIC | (skb_pfmemalloc(skb) ? __GFP_MEMALLOC : 0);
3997
	const unsigned int contiguous = proto_len ? proto_len : 1;
3998
	const unsigned int max_elements = queue->max_elements;
3999 4000 4001 4002 4003 4004
	unsigned int __elements;
	addr_t start, end;
	bool push_ok;
	int rc;

check_layout:
4005
	start = (addr_t)skb->data - hdr_len;
4006 4007
	end = (addr_t)skb->data;

4008
	if (qeth_get_elements_for_range(start, end + contiguous) == 1) {
4009 4010
		/* Push HW header into same page as first protocol header. */
		push_ok = true;
4011 4012 4013 4014 4015
		/* ... but TSO always needs a separate element for headers: */
		if (skb_is_gso(skb))
			__elements = 1 + qeth_count_elements(skb, proto_len);
		else
			__elements = qeth_count_elements(skb, 0);
J
Julian Wiedmann 已提交
4016 4017
	} else if (!proto_len && PAGE_ALIGNED(skb->data)) {
		/* Push HW header into preceding page, flush with skb->data. */
4018
		push_ok = true;
4019
		__elements = 1 + qeth_count_elements(skb, 0);
4020 4021 4022 4023
	} else {
		/* Use header cache, copy protocol headers up. */
		push_ok = false;
		__elements = 1 + qeth_count_elements(skb, proto_len);
4024 4025 4026 4027 4028 4029 4030 4031 4032 4033 4034 4035
	}

	/* Compress skb to fit into one IO buffer: */
	if (__elements > max_elements) {
		if (!skb_is_nonlinear(skb)) {
			/* Drop it, no easy way of shrinking it further. */
			QETH_DBF_MESSAGE(2, "Dropped an oversized skb (Max Elements=%u / Actual=%u / Length=%u).\n",
					 max_elements, __elements, skb->len);
			return -E2BIG;
		}

		rc = skb_linearize(skb);
4036 4037
		if (rc) {
			QETH_TXQ_STAT_INC(queue, skbs_linearized_fail);
4038
			return rc;
4039
		}
4040

4041
		QETH_TXQ_STAT_INC(queue, skbs_linearized);
4042 4043 4044 4045 4046 4047 4048
		/* Linearization changed the layout, re-evaluate: */
		goto check_layout;
	}

	*elements = __elements;
	/* Add the header: */
	if (push_ok) {
4049 4050
		*hdr = skb_push(skb, hdr_len);
		return hdr_len;
4051
	}
4052 4053

	/* Fall back to cache element with known-good alignment: */
4054 4055
	if (hdr_len + proto_len > QETH_HDR_CACHE_OBJ_SIZE)
		return -E2BIG;
4056
	*hdr = kmem_cache_alloc(qeth_core_header_cache, gfp);
4057 4058
	if (!*hdr)
		return -ENOMEM;
4059 4060
	/* Copy protocol headers behind HW header: */
	skb_copy_from_linear_data(skb, ((char *)*hdr) + hdr_len, proto_len);
4061 4062 4063
	return 0;
}

4064 4065 4066 4067
static bool qeth_iqd_may_bulk(struct qeth_qdio_out_q *queue,
			      struct sk_buff *curr_skb,
			      struct qeth_hdr *curr_hdr)
{
J
Julian Wiedmann 已提交
4068
	struct qeth_qdio_out_buffer *buffer = queue->bufs[queue->bulk_start];
4069 4070 4071 4072 4073 4074 4075 4076 4077 4078 4079 4080 4081 4082 4083 4084 4085 4086
	struct qeth_hdr *prev_hdr = queue->prev_hdr;

	if (!prev_hdr)
		return true;

	/* All packets must have the same target: */
	if (curr_hdr->hdr.l2.id == QETH_HEADER_TYPE_LAYER2) {
		struct sk_buff *prev_skb = skb_peek(&buffer->skb_list);

		return ether_addr_equal(eth_hdr(prev_skb)->h_dest,
					eth_hdr(curr_skb)->h_dest) &&
		       qeth_l2_same_vlan(&prev_hdr->hdr.l2, &curr_hdr->hdr.l2);
	}

	return qeth_l3_same_next_hop(&prev_hdr->hdr.l3, &curr_hdr->hdr.l3) &&
	       qeth_l3_iqd_same_vlan(&prev_hdr->hdr.l3, &curr_hdr->hdr.l3);
}

4087 4088 4089 4090 4091 4092 4093 4094 4095 4096 4097 4098
/**
 * qeth_fill_buffer() - map skb into an output buffer
 * @buf:	buffer to transport the skb
 * @skb:	skb to map into the buffer
 * @hdr:	qeth_hdr for this skb. Either at skb->data, or allocated
 *		from qeth_core_header_cache.
 * @offset:	when mapping the skb, start at skb->data + offset
 * @hd_len:	if > 0, build a dedicated header element of this size
 */
static unsigned int qeth_fill_buffer(struct qeth_qdio_out_buffer *buf,
				     struct sk_buff *skb, struct qeth_hdr *hdr,
				     unsigned int offset, unsigned int hd_len)
F
Frank Blaschka 已提交
4099
{
4100 4101
	struct qdio_buffer *buffer = buf->buffer;
	int element = buf->next_element_to_fill;
4102 4103
	int length = skb_headlen(skb) - offset;
	char *data = skb->data + offset;
J
Julian Wiedmann 已提交
4104
	unsigned int elem_length, cnt;
4105 4106 4107 4108 4109 4110 4111 4112 4113 4114 4115
	bool is_first_elem = true;

	__skb_queue_tail(&buf->skb_list, skb);

	/* build dedicated element for HW Header */
	if (hd_len) {
		is_first_elem = false;

		buffer->element[element].addr = virt_to_phys(hdr);
		buffer->element[element].length = hd_len;
		buffer->element[element].eflags = SBAL_EFLAGS_FIRST_FRAG;
4116 4117 4118 4119 4120 4121 4122 4123 4124 4125

		/* HW header is allocated from cache: */
		if ((void *)hdr != skb->data)
			buf->is_header[element] = 1;
		/* HW header was pushed and is contiguous with linear part: */
		else if (length > 0 && !PAGE_ALIGNED(data) &&
			 (data == (char *)hdr + hd_len))
			buffer->element[element].eflags |=
				SBAL_EFLAGS_CONTIGUOUS;

4126 4127
		element++;
	}
F
Frank Blaschka 已提交
4128

4129
	/* map linear part into buffer element(s) */
F
Frank Blaschka 已提交
4130
	while (length > 0) {
J
Julian Wiedmann 已提交
4131 4132
		elem_length = min_t(unsigned int, length,
				    PAGE_SIZE - offset_in_page(data));
F
Frank Blaschka 已提交
4133

4134
		buffer->element[element].addr = virt_to_phys(data);
J
Julian Wiedmann 已提交
4135 4136
		buffer->element[element].length = elem_length;
		length -= elem_length;
4137 4138
		if (is_first_elem) {
			is_first_elem = false;
4139 4140
			if (length || skb_is_nonlinear(skb))
				/* skb needs additional elements */
4141
				buffer->element[element].eflags =
4142
					SBAL_EFLAGS_FIRST_FRAG;
F
Frank Blaschka 已提交
4143
			else
4144 4145 4146 4147
				buffer->element[element].eflags = 0;
		} else {
			buffer->element[element].eflags =
				SBAL_EFLAGS_MIDDLE_FRAG;
F
Frank Blaschka 已提交
4148
		}
J
Julian Wiedmann 已提交
4149 4150

		data += elem_length;
F
Frank Blaschka 已提交
4151 4152
		element++;
	}
4153

4154
	/* map page frags into buffer element(s) */
4155
	for (cnt = 0; cnt < skb_shinfo(skb)->nr_frags; cnt++) {
4156 4157 4158 4159
		skb_frag_t *frag = &skb_shinfo(skb)->frags[cnt];

		data = skb_frag_address(frag);
		length = skb_frag_size(frag);
4160
		while (length > 0) {
J
Julian Wiedmann 已提交
4161 4162
			elem_length = min_t(unsigned int, length,
					    PAGE_SIZE - offset_in_page(data));
4163

4164
			buffer->element[element].addr = virt_to_phys(data);
J
Julian Wiedmann 已提交
4165
			buffer->element[element].length = elem_length;
4166 4167
			buffer->element[element].eflags =
				SBAL_EFLAGS_MIDDLE_FRAG;
J
Julian Wiedmann 已提交
4168 4169 4170

			length -= elem_length;
			data += elem_length;
4171 4172
			element++;
		}
4173 4174
	}

4175 4176
	if (buffer->element[element - 1].eflags)
		buffer->element[element - 1].eflags = SBAL_EFLAGS_LAST_FRAG;
4177
	buf->next_element_to_fill = element;
4178
	return element;
F
Frank Blaschka 已提交
4179 4180
}

4181 4182 4183 4184
static int __qeth_xmit(struct qeth_card *card, struct qeth_qdio_out_q *queue,
		       struct sk_buff *skb, unsigned int elements,
		       struct qeth_hdr *hdr, unsigned int offset,
		       unsigned int hd_len)
F
Frank Blaschka 已提交
4185
{
4186
	unsigned int bytes = qdisc_pkt_len(skb);
J
Julian Wiedmann 已提交
4187
	struct qeth_qdio_out_buffer *buffer;
4188
	unsigned int next_element;
4189 4190
	struct netdev_queue *txq;
	bool stopped = false;
4191 4192
	bool flush;

J
Julian Wiedmann 已提交
4193
	buffer = queue->bufs[QDIO_BUFNR(queue->bulk_start + queue->bulk_count)];
4194
	txq = netdev_get_tx_queue(card->dev, skb_get_queue_mapping(skb));
F
Frank Blaschka 已提交
4195

4196 4197
	/* Just a sanity check, the wake/stop logic should ensure that we always
	 * get a free buffer.
F
Frank Blaschka 已提交
4198 4199
	 */
	if (atomic_read(&buffer->state) != QETH_QDIO_BUF_EMPTY)
4200
		return -EBUSY;
4201

J
Julian Wiedmann 已提交
4202 4203 4204 4205 4206 4207 4208 4209 4210 4211 4212 4213 4214 4215 4216 4217 4218
	flush = !qeth_iqd_may_bulk(queue, skb, hdr);

	if (flush ||
	    (buffer->next_element_to_fill + elements > queue->max_elements)) {
		if (buffer->next_element_to_fill > 0) {
			atomic_set(&buffer->state, QETH_QDIO_BUF_PRIMED);
			queue->bulk_count++;
		}

		if (queue->bulk_count >= queue->bulk_max)
			flush = true;

		if (flush)
			qeth_flush_queue(queue);

		buffer = queue->bufs[QDIO_BUFNR(queue->bulk_start +
						queue->bulk_count)];
4219

4220 4221 4222 4223 4224 4225 4226
		/* Sanity-check again: */
		if (atomic_read(&buffer->state) != QETH_QDIO_BUF_EMPTY)
			return -EBUSY;
	}

	if (buffer->next_element_to_fill == 0 &&
	    atomic_inc_return(&queue->used_buffers) >= QDIO_MAX_BUFFERS_PER_Q) {
4227 4228 4229 4230 4231 4232 4233 4234
		/* If a TX completion happens right _here_ and misses to wake
		 * the txq, then our re-check below will catch the race.
		 */
		QETH_TXQ_STAT_INC(queue, stopped);
		netif_tx_stop_queue(txq);
		stopped = true;
	}

4235
	next_element = qeth_fill_buffer(buffer, skb, hdr, offset, hd_len);
4236
	buffer->bytes += bytes;
4237
	buffer->frames += skb_is_gso(skb) ? skb_shinfo(skb)->gso_segs : 1;
4238
	queue->prev_hdr = hdr;
4239

4240 4241 4242 4243 4244
	flush = __netdev_tx_sent_queue(txq, bytes,
				       !stopped && netdev_xmit_more());

	if (flush || next_element >= queue->max_elements) {
		atomic_set(&buffer->state, QETH_QDIO_BUF_PRIMED);
J
Julian Wiedmann 已提交
4245 4246 4247 4248 4249 4250 4251
		queue->bulk_count++;

		if (queue->bulk_count >= queue->bulk_max)
			flush = true;

		if (flush)
			qeth_flush_queue(queue);
4252
	}
4253 4254 4255

	if (stopped && !qeth_out_queue_is_full(queue))
		netif_tx_start_queue(txq);
F
Frank Blaschka 已提交
4256 4257 4258 4259
	return 0;
}

int qeth_do_send_packet(struct qeth_card *card, struct qeth_qdio_out_q *queue,
4260
			struct sk_buff *skb, struct qeth_hdr *hdr,
4261 4262
			unsigned int offset, unsigned int hd_len,
			int elements_needed)
F
Frank Blaschka 已提交
4263
{
4264
	unsigned int start_index = queue->next_buf_to_fill;
F
Frank Blaschka 已提交
4265
	struct qeth_qdio_out_buffer *buffer;
4266
	unsigned int next_element;
4267 4268
	struct netdev_queue *txq;
	bool stopped = false;
F
Frank Blaschka 已提交
4269 4270 4271 4272
	int flush_count = 0;
	int do_pack = 0;
	int rc = 0;

4273
	buffer = queue->bufs[queue->next_buf_to_fill];
4274 4275 4276

	/* Just a sanity check, the wake/stop logic should ensure that we always
	 * get a free buffer.
F
Frank Blaschka 已提交
4277
	 */
4278
	if (atomic_read(&buffer->state) != QETH_QDIO_BUF_EMPTY)
F
Frank Blaschka 已提交
4279
		return -EBUSY;
4280 4281 4282

	txq = netdev_get_tx_queue(card->dev, skb_get_queue_mapping(skb));

F
Frank Blaschka 已提交
4283 4284 4285 4286
	/* check if we need to switch packing state of this queue */
	qeth_switch_to_packing_if_needed(queue);
	if (queue->do_pack) {
		do_pack = 1;
F
Frank Blaschka 已提交
4287
		/* does packet fit in current buffer? */
4288 4289
		if (buffer->next_element_to_fill + elements_needed >
		    queue->max_elements) {
F
Frank Blaschka 已提交
4290 4291 4292 4293
			/* ... no -> set state PRIMED */
			atomic_set(&buffer->state, QETH_QDIO_BUF_PRIMED);
			flush_count++;
			queue->next_buf_to_fill =
J
Julian Wiedmann 已提交
4294
				QDIO_BUFNR(queue->next_buf_to_fill + 1);
4295
			buffer = queue->bufs[queue->next_buf_to_fill];
4296 4297

			/* We stepped forward, so sanity-check again: */
F
Frank Blaschka 已提交
4298 4299 4300
			if (atomic_read(&buffer->state) !=
			    QETH_QDIO_BUF_EMPTY) {
				qeth_flush_buffers(queue, start_index,
J
Jan Glauber 已提交
4301
							   flush_count);
4302 4303
				rc = -EBUSY;
				goto out;
F
Frank Blaschka 已提交
4304 4305 4306
			}
		}
	}
4307

4308 4309 4310 4311 4312 4313 4314 4315 4316 4317
	if (buffer->next_element_to_fill == 0 &&
	    atomic_inc_return(&queue->used_buffers) >= QDIO_MAX_BUFFERS_PER_Q) {
		/* If a TX completion happens right _here_ and misses to wake
		 * the txq, then our re-check below will catch the race.
		 */
		QETH_TXQ_STAT_INC(queue, stopped);
		netif_tx_stop_queue(txq);
		stopped = true;
	}

4318
	next_element = qeth_fill_buffer(buffer, skb, hdr, offset, hd_len);
4319 4320
	buffer->bytes += qdisc_pkt_len(skb);
	buffer->frames += skb_is_gso(skb) ? skb_shinfo(skb)->gso_segs : 1;
4321 4322 4323 4324 4325 4326

	if (queue->do_pack)
		QETH_TXQ_STAT_INC(queue, skbs_pack);
	if (!queue->do_pack || stopped || next_element >= queue->max_elements) {
		flush_count++;
		atomic_set(&buffer->state, QETH_QDIO_BUF_PRIMED);
J
Julian Wiedmann 已提交
4327 4328
		queue->next_buf_to_fill =
				QDIO_BUFNR(queue->next_buf_to_fill + 1);
4329 4330
	}

F
Frank Blaschka 已提交
4331
	if (flush_count)
J
Jan Glauber 已提交
4332
		qeth_flush_buffers(queue, start_index, flush_count);
4333

4334
out:
4335 4336
	if (do_pack)
		QETH_TXQ_STAT_ADD(queue, bufs_pack, flush_count);
F
Frank Blaschka 已提交
4337

4338 4339
	if (stopped && !qeth_out_queue_is_full(queue))
		netif_tx_start_queue(txq);
F
Frank Blaschka 已提交
4340 4341 4342 4343
	return rc;
}
EXPORT_SYMBOL_GPL(qeth_do_send_packet);

J
Julian Wiedmann 已提交
4344 4345 4346
static void qeth_fill_tso_ext(struct qeth_hdr_tso *hdr,
			      unsigned int payload_len, struct sk_buff *skb,
			      unsigned int proto_len)
4347 4348 4349 4350 4351 4352 4353 4354 4355 4356 4357 4358 4359
{
	struct qeth_hdr_ext_tso *ext = &hdr->ext;

	ext->hdr_tot_len = sizeof(*ext);
	ext->imb_hdr_no = 1;
	ext->hdr_type = 1;
	ext->hdr_version = 1;
	ext->hdr_len = 28;
	ext->payload_len = payload_len;
	ext->mss = skb_shinfo(skb)->gso_size;
	ext->dg_hdr_len = proto_len;
}

4360
int qeth_xmit(struct qeth_card *card, struct sk_buff *skb,
4361
	      struct qeth_qdio_out_q *queue, __be16 proto,
4362 4363
	      void (*fill_header)(struct qeth_qdio_out_q *queue,
				  struct qeth_hdr *hdr, struct sk_buff *skb,
4364
				  __be16 proto, unsigned int data_len))
4365
{
4366
	unsigned int proto_len, hw_hdr_len;
4367
	unsigned int frame_len = skb->len;
4368
	bool is_tso = skb_is_gso(skb);
4369 4370 4371 4372 4373 4374
	unsigned int data_offset = 0;
	struct qeth_hdr *hdr = NULL;
	unsigned int hd_len = 0;
	unsigned int elements;
	int push_len, rc;

4375 4376 4377 4378 4379
	if (is_tso) {
		hw_hdr_len = sizeof(struct qeth_hdr_tso);
		proto_len = skb_transport_offset(skb) + tcp_hdrlen(skb);
	} else {
		hw_hdr_len = sizeof(struct qeth_hdr);
J
Julian Wiedmann 已提交
4380
		proto_len = (IS_IQD(card) && IS_LAYER2(card)) ? ETH_HLEN : 0;
4381 4382
	}

4383 4384 4385 4386
	rc = skb_cow_head(skb, hw_hdr_len);
	if (rc)
		return rc;

4387
	push_len = qeth_add_hw_header(queue, skb, &hdr, hw_hdr_len, proto_len,
4388 4389 4390
				      &elements);
	if (push_len < 0)
		return push_len;
4391
	if (is_tso || !push_len) {
4392 4393
		/* HW header needs its own buffer element. */
		hd_len = hw_hdr_len + proto_len;
4394
		data_offset = push_len + proto_len;
4395
	}
4396
	memset(hdr, 0, hw_hdr_len);
4397
	fill_header(queue, hdr, skb, proto, frame_len);
4398 4399 4400
	if (is_tso)
		qeth_fill_tso_ext((struct qeth_hdr_tso *) hdr,
				  frame_len - proto_len, skb, proto_len);
4401 4402

	if (IS_IQD(card)) {
4403 4404
		rc = __qeth_xmit(card, queue, skb, elements, hdr, data_offset,
				 hd_len);
4405 4406 4407
	} else {
		/* TODO: drop skb_orphan() once TX completion is fast enough */
		skb_orphan(skb);
4408
		spin_lock(&queue->lock);
4409 4410
		rc = qeth_do_send_packet(card, queue, skb, hdr, data_offset,
					 hd_len, elements);
4411
		spin_unlock(&queue->lock);
4412 4413
	}

4414 4415 4416
	if (rc && !push_len)
		kmem_cache_free(qeth_core_header_cache, hdr);

4417 4418 4419 4420
	return rc;
}
EXPORT_SYMBOL_GPL(qeth_xmit);

F
Frank Blaschka 已提交
4421 4422 4423
static int qeth_setadp_promisc_mode_cb(struct qeth_card *card,
		struct qeth_reply *reply, unsigned long data)
{
4424
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
F
Frank Blaschka 已提交
4425 4426
	struct qeth_ipacmd_setadpparms *setparms;

C
Carsten Otte 已提交
4427
	QETH_CARD_TEXT(card, 4, "prmadpcb");
F
Frank Blaschka 已提交
4428 4429

	setparms = &(cmd->data.setadapterparms);
4430
	if (qeth_setadpparms_inspect_rc(cmd)) {
4431
		QETH_CARD_TEXT_(card, 4, "prmrc%x", cmd->hdr.return_code);
F
Frank Blaschka 已提交
4432 4433 4434
		setparms->data.mode = SET_PROMISC_MODE_OFF;
	}
	card->info.promisc_mode = setparms->data.mode;
4435
	return (cmd->hdr.return_code) ? -EIO : 0;
F
Frank Blaschka 已提交
4436 4437
}

4438
void qeth_setadp_promisc_mode(struct qeth_card *card, bool enable)
F
Frank Blaschka 已提交
4439
{
4440 4441
	enum qeth_ipa_promisc_modes mode = enable ? SET_PROMISC_MODE_ON :
						    SET_PROMISC_MODE_OFF;
F
Frank Blaschka 已提交
4442 4443 4444
	struct qeth_cmd_buffer *iob;
	struct qeth_ipa_cmd *cmd;

C
Carsten Otte 已提交
4445 4446
	QETH_CARD_TEXT(card, 4, "setprom");
	QETH_CARD_TEXT_(card, 4, "mode:%x", mode);
F
Frank Blaschka 已提交
4447 4448

	iob = qeth_get_adapter_cmd(card, IPA_SETADP_SET_PROMISC_MODE,
4449
				   SETADP_DATA_SIZEOF(mode));
4450 4451
	if (!iob)
		return;
4452
	cmd = __ipa_cmd(iob);
F
Frank Blaschka 已提交
4453 4454 4455 4456 4457 4458 4459 4460
	cmd->data.setadapterparms.data.mode = mode;
	qeth_send_ipa_cmd(card, iob, qeth_setadp_promisc_mode_cb, NULL);
}
EXPORT_SYMBOL_GPL(qeth_setadp_promisc_mode);

static int qeth_setadpparms_change_macaddr_cb(struct qeth_card *card,
		struct qeth_reply *reply, unsigned long data)
{
4461
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
4462
	struct qeth_ipacmd_setadpparms *adp_cmd;
F
Frank Blaschka 已提交
4463

C
Carsten Otte 已提交
4464
	QETH_CARD_TEXT(card, 4, "chgmaccb");
4465
	if (qeth_setadpparms_inspect_rc(cmd))
4466
		return -EIO;
F
Frank Blaschka 已提交
4467

4468
	adp_cmd = &cmd->data.setadapterparms;
4469 4470 4471
	if (!is_valid_ether_addr(adp_cmd->data.change_addr.addr))
		return -EADDRNOTAVAIL;

4472 4473
	if (IS_LAYER2(card) && IS_OSD(card) && !IS_VM_NIC(card) &&
	    !(adp_cmd->hdr.flags & QETH_SETADP_FLAGS_VIRTUAL_MAC))
4474
		return -EADDRNOTAVAIL;
4475 4476

	ether_addr_copy(card->dev->dev_addr, adp_cmd->data.change_addr.addr);
F
Frank Blaschka 已提交
4477 4478 4479 4480 4481 4482 4483 4484 4485
	return 0;
}

int qeth_setadpparms_change_macaddr(struct qeth_card *card)
{
	int rc;
	struct qeth_cmd_buffer *iob;
	struct qeth_ipa_cmd *cmd;

C
Carsten Otte 已提交
4486
	QETH_CARD_TEXT(card, 4, "chgmac");
F
Frank Blaschka 已提交
4487 4488

	iob = qeth_get_adapter_cmd(card, IPA_SETADP_ALTER_MAC_ADDRESS,
4489
				   SETADP_DATA_SIZEOF(change_addr));
4490 4491
	if (!iob)
		return -ENOMEM;
4492
	cmd = __ipa_cmd(iob);
F
Frank Blaschka 已提交
4493
	cmd->data.setadapterparms.data.change_addr.cmd = CHANGE_ADDR_READ_MAC;
4494 4495 4496
	cmd->data.setadapterparms.data.change_addr.addr_size = ETH_ALEN;
	ether_addr_copy(cmd->data.setadapterparms.data.change_addr.addr,
			card->dev->dev_addr);
F
Frank Blaschka 已提交
4497 4498 4499 4500 4501 4502
	rc = qeth_send_ipa_cmd(card, iob, qeth_setadpparms_change_macaddr_cb,
			       NULL);
	return rc;
}
EXPORT_SYMBOL_GPL(qeth_setadpparms_change_macaddr);

E
Einar Lueck 已提交
4503 4504 4505
static int qeth_setadpparms_set_access_ctrl_cb(struct qeth_card *card,
		struct qeth_reply *reply, unsigned long data)
{
4506
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
E
Einar Lueck 已提交
4507 4508
	struct qeth_set_access_ctrl *access_ctrl_req;

C
Carsten Otte 已提交
4509
	QETH_CARD_TEXT(card, 4, "setaccb");
E
Einar Lueck 已提交
4510 4511

	access_ctrl_req = &cmd->data.setadapterparms.data.set_access_ctrl;
4512 4513
	QETH_CARD_TEXT_(card, 2, "rc=%d",
			cmd->data.setadapterparms.hdr.return_code);
S
Stefan Raspl 已提交
4514 4515
	if (cmd->data.setadapterparms.hdr.return_code !=
						SET_ACCESS_CTRL_RC_SUCCESS)
4516 4517 4518
		QETH_DBF_MESSAGE(3, "ERR:SET_ACCESS_CTRL(%#x) on device %x: %#x\n",
				 access_ctrl_req->subcmd_code, CARD_DEVID(card),
				 cmd->data.setadapterparms.hdr.return_code);
4519
	switch (qeth_setadpparms_inspect_rc(cmd)) {
E
Einar Lueck 已提交
4520
	case SET_ACCESS_CTRL_RC_SUCCESS:
4521
		if (access_ctrl_req->subcmd_code == ISOLATION_MODE_NONE)
E
Einar Lueck 已提交
4522 4523
			dev_info(&card->gdev->dev,
			    "QDIO data connection isolation is deactivated\n");
4524
		else
E
Einar Lueck 已提交
4525 4526
			dev_info(&card->gdev->dev,
			    "QDIO data connection isolation is activated\n");
4527
		return 0;
S
Stefan Raspl 已提交
4528
	case SET_ACCESS_CTRL_RC_ALREADY_NOT_ISOLATED:
4529 4530
		QETH_DBF_MESSAGE(2, "QDIO data connection isolation on device %x already deactivated\n",
				 CARD_DEVID(card));
4531
		return 0;
S
Stefan Raspl 已提交
4532
	case SET_ACCESS_CTRL_RC_ALREADY_ISOLATED:
4533 4534
		QETH_DBF_MESSAGE(2, "QDIO data connection isolation on device %x already activated\n",
				 CARD_DEVID(card));
4535
		return 0;
E
Einar Lueck 已提交
4536 4537 4538
	case SET_ACCESS_CTRL_RC_NOT_SUPPORTED:
		dev_err(&card->gdev->dev, "Adapter does not "
			"support QDIO data connection isolation\n");
4539
		return -EOPNOTSUPP;
E
Einar Lueck 已提交
4540 4541 4542 4543
	case SET_ACCESS_CTRL_RC_NONE_SHARED_ADAPTER:
		dev_err(&card->gdev->dev,
			"Adapter is dedicated. "
			"QDIO data connection isolation not supported\n");
4544
		return -EOPNOTSUPP;
E
Einar Lueck 已提交
4545 4546 4547
	case SET_ACCESS_CTRL_RC_ACTIVE_CHECKSUM_OFF:
		dev_err(&card->gdev->dev,
			"TSO does not permit QDIO data connection isolation\n");
4548
		return -EPERM;
S
Stefan Raspl 已提交
4549 4550 4551
	case SET_ACCESS_CTRL_RC_REFLREL_UNSUPPORTED:
		dev_err(&card->gdev->dev, "The adjacent switch port does not "
			"support reflective relay mode\n");
4552
		return -EOPNOTSUPP;
S
Stefan Raspl 已提交
4553 4554 4555
	case SET_ACCESS_CTRL_RC_REFLREL_FAILED:
		dev_err(&card->gdev->dev, "The reflective relay mode cannot be "
					"enabled at the adjacent switch port");
4556
		return -EREMOTEIO;
S
Stefan Raspl 已提交
4557 4558 4559
	case SET_ACCESS_CTRL_RC_REFLREL_DEACT_FAILED:
		dev_warn(&card->gdev->dev, "Turning off reflective relay mode "
					"at the adjacent switch failed\n");
4560 4561
		/* benign error while disabling ISOLATION_MODE_FWD */
		return 0;
E
Einar Lueck 已提交
4562
	default:
4563
		return -EIO;
E
Einar Lueck 已提交
4564 4565 4566
	}
}

4567 4568
int qeth_setadpparms_set_access_ctrl(struct qeth_card *card,
				     enum qeth_ipa_isolation_modes mode)
E
Einar Lueck 已提交
4569 4570 4571 4572 4573 4574
{
	int rc;
	struct qeth_cmd_buffer *iob;
	struct qeth_ipa_cmd *cmd;
	struct qeth_set_access_ctrl *access_ctrl_req;

C
Carsten Otte 已提交
4575
	QETH_CARD_TEXT(card, 4, "setacctl");
E
Einar Lueck 已提交
4576

4577 4578 4579 4580 4581 4582
	if (!qeth_adp_supported(card, IPA_SETADP_SET_ACCESS_CONTROL)) {
		dev_err(&card->gdev->dev,
			"Adapter does not support QDIO data connection isolation\n");
		return -EOPNOTSUPP;
	}

E
Einar Lueck 已提交
4583
	iob = qeth_get_adapter_cmd(card, IPA_SETADP_SET_ACCESS_CONTROL,
4584
				   SETADP_DATA_SIZEOF(set_access_ctrl));
4585 4586
	if (!iob)
		return -ENOMEM;
4587
	cmd = __ipa_cmd(iob);
E
Einar Lueck 已提交
4588
	access_ctrl_req = &cmd->data.setadapterparms.data.set_access_ctrl;
4589
	access_ctrl_req->subcmd_code = mode;
E
Einar Lueck 已提交
4590 4591

	rc = qeth_send_ipa_cmd(card, iob, qeth_setadpparms_set_access_ctrl_cb,
4592
			       NULL);
4593
	if (rc) {
4594
		QETH_CARD_TEXT_(card, 2, "rc=%d", rc);
4595 4596
		QETH_DBF_MESSAGE(3, "IPA(SET_ACCESS_CTRL(%d) on device %x: sent failed\n",
				 rc, CARD_DEVID(card));
E
Einar Lueck 已提交
4597
	}
4598

E
Einar Lueck 已提交
4599 4600 4601
	return rc;
}

4602
void qeth_tx_timeout(struct net_device *dev, unsigned int txqueue)
F
Frank Blaschka 已提交
4603 4604 4605
{
	struct qeth_card *card;

4606
	card = dev->ml_priv;
C
Carsten Otte 已提交
4607
	QETH_CARD_TEXT(card, 4, "txtimeo");
F
Frank Blaschka 已提交
4608 4609 4610 4611
	qeth_schedule_recovery(card);
}
EXPORT_SYMBOL_GPL(qeth_tx_timeout);

4612
static int qeth_mdio_read(struct net_device *dev, int phy_id, int regnum)
F
Frank Blaschka 已提交
4613
{
4614
	struct qeth_card *card = dev->ml_priv;
F
Frank Blaschka 已提交
4615 4616 4617 4618 4619 4620 4621
	int rc = 0;

	switch (regnum) {
	case MII_BMCR: /* Basic mode control register */
		rc = BMCR_FULLDPLX;
		if ((card->info.link_type != QETH_LINK_TYPE_GBIT_ETH) &&
		    (card->info.link_type != QETH_LINK_TYPE_OSN) &&
4622 4623
		    (card->info.link_type != QETH_LINK_TYPE_10GBIT_ETH) &&
		    (card->info.link_type != QETH_LINK_TYPE_25GBIT_ETH))
F
Frank Blaschka 已提交
4624 4625 4626 4627 4628 4629 4630 4631 4632 4633 4634 4635 4636 4637 4638 4639 4640 4641 4642 4643 4644 4645 4646 4647 4648 4649 4650 4651 4652 4653 4654
			rc |= BMCR_SPEED100;
		break;
	case MII_BMSR: /* Basic mode status register */
		rc = BMSR_ERCAP | BMSR_ANEGCOMPLETE | BMSR_LSTATUS |
		     BMSR_10HALF | BMSR_10FULL | BMSR_100HALF | BMSR_100FULL |
		     BMSR_100BASE4;
		break;
	case MII_PHYSID1: /* PHYS ID 1 */
		rc = (dev->dev_addr[0] << 16) | (dev->dev_addr[1] << 8) |
		     dev->dev_addr[2];
		rc = (rc >> 5) & 0xFFFF;
		break;
	case MII_PHYSID2: /* PHYS ID 2 */
		rc = (dev->dev_addr[2] << 10) & 0xFFFF;
		break;
	case MII_ADVERTISE: /* Advertisement control reg */
		rc = ADVERTISE_ALL;
		break;
	case MII_LPA: /* Link partner ability reg */
		rc = LPA_10HALF | LPA_10FULL | LPA_100HALF | LPA_100FULL |
		     LPA_100BASE4 | LPA_LPACK;
		break;
	case MII_EXPANSION: /* Expansion register */
		break;
	case MII_DCOUNTER: /* disconnect counter */
		break;
	case MII_FCSCOUNTER: /* false carrier counter */
		break;
	case MII_NWAYTEST: /* N-way auto-neg test register */
		break;
	case MII_RERRCOUNTER: /* rx error counter */
4655 4656 4657
		rc = card->stats.rx_length_errors +
		     card->stats.rx_frame_errors +
		     card->stats.rx_fifo_errors;
F
Frank Blaschka 已提交
4658 4659 4660 4661 4662 4663 4664 4665 4666 4667 4668 4669 4670 4671 4672 4673 4674 4675 4676 4677 4678 4679
		break;
	case MII_SREVISION: /* silicon revision */
		break;
	case MII_RESV1: /* reserved 1 */
		break;
	case MII_LBRERROR: /* loopback, rx, bypass error */
		break;
	case MII_PHYADDR: /* physical address */
		break;
	case MII_RESV2: /* reserved 2 */
		break;
	case MII_TPISTATUS: /* TPI status for 10mbps */
		break;
	case MII_NCONFIG: /* network interface config */
		break;
	default:
		break;
	}
	return rc;
}

static int qeth_snmp_command_cb(struct qeth_card *card,
4680
				struct qeth_reply *reply, unsigned long data)
F
Frank Blaschka 已提交
4681
{
4682 4683 4684 4685
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
	struct qeth_arp_query_info *qinfo = reply->param;
	struct qeth_ipacmd_setadpparms *adp_cmd;
	unsigned int data_len;
4686
	void *snmp_data;
F
Frank Blaschka 已提交
4687

C
Carsten Otte 已提交
4688
	QETH_CARD_TEXT(card, 3, "snpcmdcb");
F
Frank Blaschka 已提交
4689 4690

	if (cmd->hdr.return_code) {
4691
		QETH_CARD_TEXT_(card, 4, "scer1%x", cmd->hdr.return_code);
4692
		return -EIO;
F
Frank Blaschka 已提交
4693 4694 4695 4696
	}
	if (cmd->data.setadapterparms.hdr.return_code) {
		cmd->hdr.return_code =
			cmd->data.setadapterparms.hdr.return_code;
4697
		QETH_CARD_TEXT_(card, 4, "scer2%x", cmd->hdr.return_code);
4698
		return -EIO;
F
Frank Blaschka 已提交
4699
	}
4700 4701 4702 4703 4704

	adp_cmd = &cmd->data.setadapterparms;
	data_len = adp_cmd->hdr.cmdlength - sizeof(adp_cmd->hdr);
	if (adp_cmd->hdr.seq_no == 1) {
		snmp_data = &adp_cmd->data.snmp;
4705
	} else {
4706 4707
		snmp_data = &adp_cmd->data.snmp.request;
		data_len -= offsetof(struct qeth_snmp_cmd, request);
4708
	}
F
Frank Blaschka 已提交
4709 4710 4711

	/* check if there is enough room in userspace */
	if ((qinfo->udata_len - qinfo->udata_offset) < data_len) {
4712 4713
		QETH_CARD_TEXT_(card, 4, "scer3%i", -ENOSPC);
		return -ENOSPC;
F
Frank Blaschka 已提交
4714
	}
C
Carsten Otte 已提交
4715
	QETH_CARD_TEXT_(card, 4, "snore%i",
4716
			cmd->data.setadapterparms.hdr.used_total);
C
Carsten Otte 已提交
4717
	QETH_CARD_TEXT_(card, 4, "sseqn%i",
4718
			cmd->data.setadapterparms.hdr.seq_no);
F
Frank Blaschka 已提交
4719
	/*copy entries to user buffer*/
4720
	memcpy(qinfo->udata + qinfo->udata_offset, snmp_data, data_len);
F
Frank Blaschka 已提交
4721
	qinfo->udata_offset += data_len;
4722

F
Frank Blaschka 已提交
4723 4724 4725 4726 4727 4728
	if (cmd->data.setadapterparms.hdr.seq_no <
	    cmd->data.setadapterparms.hdr.used_total)
		return 1;
	return 0;
}

4729
static int qeth_snmp_command(struct qeth_card *card, char __user *udata)
F
Frank Blaschka 已提交
4730
{
4731
	struct qeth_snmp_ureq __user *ureq;
F
Frank Blaschka 已提交
4732
	struct qeth_cmd_buffer *iob;
4733
	unsigned int req_len;
F
Frank Blaschka 已提交
4734 4735 4736
	struct qeth_arp_query_info qinfo = {0, };
	int rc = 0;

C
Carsten Otte 已提交
4737
	QETH_CARD_TEXT(card, 3, "snmpcmd");
F
Frank Blaschka 已提交
4738

4739
	if (IS_VM_NIC(card))
F
Frank Blaschka 已提交
4740 4741 4742
		return -EOPNOTSUPP;

	if ((!qeth_adp_supported(card, IPA_SETADP_SET_SNMP_CONTROL)) &&
4743
	    IS_LAYER3(card))
F
Frank Blaschka 已提交
4744
		return -EOPNOTSUPP;
4745

4746 4747 4748 4749 4750
	ureq = (struct qeth_snmp_ureq __user *) udata;
	if (get_user(qinfo.udata_len, &ureq->hdr.data_len) ||
	    get_user(req_len, &ureq->hdr.req_len))
		return -EFAULT;

4751 4752 4753 4754
	/* Sanitize user input, to avoid overflows in iob size calculation: */
	if (req_len > QETH_BUFSIZE)
		return -EINVAL;

4755 4756 4757 4758 4759 4760 4761
	iob = qeth_get_adapter_cmd(card, IPA_SETADP_SET_SNMP_CONTROL, req_len);
	if (!iob)
		return -ENOMEM;

	if (copy_from_user(&__ipa_cmd(iob)->data.setadapterparms.data.snmp,
			   &ureq->cmd, req_len)) {
		qeth_put_cmd(iob);
F
Frank Blaschka 已提交
4762
		return -EFAULT;
4763 4764
	}

F
Frank Blaschka 已提交
4765 4766
	qinfo.udata = kzalloc(qinfo.udata_len, GFP_KERNEL);
	if (!qinfo.udata) {
4767
		qeth_put_cmd(iob);
F
Frank Blaschka 已提交
4768 4769 4770 4771
		return -ENOMEM;
	}
	qinfo.udata_offset = sizeof(struct qeth_snmp_ureq_hdr);

4772
	rc = qeth_send_ipa_cmd(card, iob, qeth_snmp_command_cb, &qinfo);
F
Frank Blaschka 已提交
4773
	if (rc)
4774 4775
		QETH_DBF_MESSAGE(2, "SNMP command failed on device %x: (%#x)\n",
				 CARD_DEVID(card), rc);
F
Frank Blaschka 已提交
4776 4777 4778 4779
	else {
		if (copy_to_user(udata, qinfo.udata, qinfo.udata_len))
			rc = -EFAULT;
	}
4780

F
Frank Blaschka 已提交
4781 4782 4783 4784
	kfree(qinfo.udata);
	return rc;
}

4785
static int qeth_setadpparms_query_oat_cb(struct qeth_card *card,
J
Julian Wiedmann 已提交
4786 4787
					 struct qeth_reply *reply,
					 unsigned long data)
4788
{
4789
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *)data;
J
Julian Wiedmann 已提交
4790
	struct qeth_qoat_priv *priv = reply->param;
4791 4792 4793
	int resdatalen;

	QETH_CARD_TEXT(card, 3, "qoatcb");
4794
	if (qeth_setadpparms_inspect_rc(cmd))
4795
		return -EIO;
4796 4797 4798

	resdatalen = cmd->data.setadapterparms.hdr.cmdlength;

4799 4800
	if (resdatalen > (priv->buffer_len - priv->response_len))
		return -ENOSPC;
4801

4802 4803
	memcpy(priv->buffer + priv->response_len,
	       &cmd->data.setadapterparms.hdr, resdatalen);
4804 4805 4806 4807 4808 4809 4810 4811
	priv->response_len += resdatalen;

	if (cmd->data.setadapterparms.hdr.seq_no <
	    cmd->data.setadapterparms.hdr.used_total)
		return 1;
	return 0;
}

4812
static int qeth_query_oat_command(struct qeth_card *card, char __user *udata)
4813 4814 4815 4816 4817 4818 4819 4820 4821 4822 4823
{
	int rc = 0;
	struct qeth_cmd_buffer *iob;
	struct qeth_ipa_cmd *cmd;
	struct qeth_query_oat *oat_req;
	struct qeth_query_oat_data oat_data;
	struct qeth_qoat_priv priv;
	void __user *tmp;

	QETH_CARD_TEXT(card, 3, "qoatcmd");

J
Julian Wiedmann 已提交
4824 4825
	if (!qeth_adp_supported(card, IPA_SETADP_QUERY_OAT))
		return -EOPNOTSUPP;
4826

J
Julian Wiedmann 已提交
4827 4828
	if (copy_from_user(&oat_data, udata, sizeof(oat_data)))
		return -EFAULT;
4829 4830 4831

	priv.buffer_len = oat_data.buffer_len;
	priv.response_len = 0;
4832
	priv.buffer = vzalloc(oat_data.buffer_len);
J
Julian Wiedmann 已提交
4833 4834
	if (!priv.buffer)
		return -ENOMEM;
4835 4836

	iob = qeth_get_adapter_cmd(card, IPA_SETADP_QUERY_OAT,
4837
				   SETADP_DATA_SIZEOF(query_oat));
4838 4839 4840 4841
	if (!iob) {
		rc = -ENOMEM;
		goto out_free;
	}
4842
	cmd = __ipa_cmd(iob);
4843 4844 4845
	oat_req = &cmd->data.setadapterparms.data.query_oat;
	oat_req->subcmd_code = oat_data.command;

J
Julian Wiedmann 已提交
4846
	rc = qeth_send_ipa_cmd(card, iob, qeth_setadpparms_query_oat_cb, &priv);
4847
	if (!rc) {
4848 4849
		tmp = is_compat_task() ? compat_ptr(oat_data.ptr) :
					 u64_to_user_ptr(oat_data.ptr);
4850 4851
		oat_data.response_len = priv.response_len;

J
Julian Wiedmann 已提交
4852 4853
		if (copy_to_user(tmp, priv.buffer, priv.response_len) ||
		    copy_to_user(udata, &oat_data, sizeof(oat_data)))
4854
			rc = -EFAULT;
4855
	}
4856 4857

out_free:
4858
	vfree(priv.buffer);
4859 4860 4861
	return rc;
}

4862 4863
static int qeth_query_card_info_cb(struct qeth_card *card,
				   struct qeth_reply *reply, unsigned long data)
E
Eugene Crosser 已提交
4864
{
4865
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *)data;
4866
	struct qeth_link_info *link_info = reply->param;
E
Eugene Crosser 已提交
4867 4868 4869
	struct qeth_query_card_info *card_info;

	QETH_CARD_TEXT(card, 2, "qcrdincb");
4870
	if (qeth_setadpparms_inspect_rc(cmd))
4871
		return -EIO;
E
Eugene Crosser 已提交
4872

4873
	card_info = &cmd->data.setadapterparms.data.card_info;
4874 4875 4876 4877 4878 4879 4880 4881 4882 4883 4884 4885 4886 4887 4888 4889 4890 4891 4892 4893 4894 4895 4896 4897 4898 4899 4900 4901 4902 4903 4904 4905 4906 4907 4908 4909 4910 4911 4912 4913 4914 4915 4916 4917 4918 4919 4920 4921 4922 4923 4924 4925 4926 4927 4928 4929
	netdev_dbg(card->dev,
		   "card info: card_type=0x%02x, port_mode=0x%04x, port_speed=0x%08x\n",
		   card_info->card_type, card_info->port_mode,
		   card_info->port_speed);

	switch (card_info->port_mode) {
	case CARD_INFO_PORTM_FULLDUPLEX:
		link_info->duplex = DUPLEX_FULL;
		break;
	case CARD_INFO_PORTM_HALFDUPLEX:
		link_info->duplex = DUPLEX_HALF;
		break;
	default:
		link_info->duplex = DUPLEX_UNKNOWN;
	}

	switch (card_info->card_type) {
	case CARD_INFO_TYPE_1G_COPPER_A:
	case CARD_INFO_TYPE_1G_COPPER_B:
		link_info->speed = SPEED_1000;
		link_info->port = PORT_TP;
		break;
	case CARD_INFO_TYPE_1G_FIBRE_A:
	case CARD_INFO_TYPE_1G_FIBRE_B:
		link_info->speed = SPEED_1000;
		link_info->port = PORT_FIBRE;
		break;
	case CARD_INFO_TYPE_10G_FIBRE_A:
	case CARD_INFO_TYPE_10G_FIBRE_B:
		link_info->speed = SPEED_10000;
		link_info->port = PORT_FIBRE;
		break;
	default:
		switch (card_info->port_speed) {
		case CARD_INFO_PORTS_10M:
			link_info->speed = SPEED_10;
			break;
		case CARD_INFO_PORTS_100M:
			link_info->speed = SPEED_100;
			break;
		case CARD_INFO_PORTS_1G:
			link_info->speed = SPEED_1000;
			break;
		case CARD_INFO_PORTS_10G:
			link_info->speed = SPEED_10000;
			break;
		case CARD_INFO_PORTS_25G:
			link_info->speed = SPEED_25000;
			break;
		default:
			link_info->speed = SPEED_UNKNOWN;
		}

		link_info->port = PORT_OTHER;
	}

E
Eugene Crosser 已提交
4930 4931 4932
	return 0;
}

4933
int qeth_query_card_info(struct qeth_card *card,
4934
			 struct qeth_link_info *link_info)
E
Eugene Crosser 已提交
4935 4936 4937 4938 4939 4940
{
	struct qeth_cmd_buffer *iob;

	QETH_CARD_TEXT(card, 2, "qcrdinfo");
	if (!qeth_adp_supported(card, IPA_SETADP_QUERY_CARD_INFO))
		return -EOPNOTSUPP;
4941
	iob = qeth_get_adapter_cmd(card, IPA_SETADP_QUERY_CARD_INFO, 0);
4942 4943
	if (!iob)
		return -ENOMEM;
4944 4945

	return qeth_send_ipa_cmd(card, iob, qeth_query_card_info_cb, link_info);
E
Eugene Crosser 已提交
4946 4947
}

4948 4949 4950 4951 4952 4953 4954 4955 4956 4957 4958 4959 4960 4961 4962 4963 4964 4965 4966 4967 4968 4969 4970 4971 4972 4973 4974 4975 4976 4977 4978 4979 4980 4981 4982 4983 4984 4985 4986 4987 4988 4989 4990 4991 4992 4993 4994 4995 4996 4997 4998 4999 5000 5001 5002 5003 5004 5005 5006 5007 5008 5009 5010 5011 5012 5013 5014
static int qeth_init_link_info_oat_cb(struct qeth_card *card,
				      struct qeth_reply *reply_priv,
				      unsigned long data)
{
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *)data;
	struct qeth_link_info *link_info = reply_priv->param;
	struct qeth_query_oat_physical_if *phys_if;
	struct qeth_query_oat_reply *reply;

	if (qeth_setadpparms_inspect_rc(cmd))
		return -EIO;

	/* Multi-part reply is unexpected, don't bother: */
	if (cmd->data.setadapterparms.hdr.used_total > 1)
		return -EINVAL;

	/* Expect the reply to start with phys_if data: */
	reply = &cmd->data.setadapterparms.data.query_oat.reply[0];
	if (reply->type != QETH_QOAT_REPLY_TYPE_PHYS_IF ||
	    reply->length < sizeof(*reply))
		return -EINVAL;

	phys_if = &reply->phys_if;

	switch (phys_if->speed_duplex) {
	case QETH_QOAT_PHYS_SPEED_10M_HALF:
		link_info->speed = SPEED_10;
		link_info->duplex = DUPLEX_HALF;
		break;
	case QETH_QOAT_PHYS_SPEED_10M_FULL:
		link_info->speed = SPEED_10;
		link_info->duplex = DUPLEX_FULL;
		break;
	case QETH_QOAT_PHYS_SPEED_100M_HALF:
		link_info->speed = SPEED_100;
		link_info->duplex = DUPLEX_HALF;
		break;
	case QETH_QOAT_PHYS_SPEED_100M_FULL:
		link_info->speed = SPEED_100;
		link_info->duplex = DUPLEX_FULL;
		break;
	case QETH_QOAT_PHYS_SPEED_1000M_HALF:
		link_info->speed = SPEED_1000;
		link_info->duplex = DUPLEX_HALF;
		break;
	case QETH_QOAT_PHYS_SPEED_1000M_FULL:
		link_info->speed = SPEED_1000;
		link_info->duplex = DUPLEX_FULL;
		break;
	case QETH_QOAT_PHYS_SPEED_10G_FULL:
		link_info->speed = SPEED_10000;
		link_info->duplex = DUPLEX_FULL;
		break;
	case QETH_QOAT_PHYS_SPEED_25G_FULL:
		link_info->speed = SPEED_25000;
		link_info->duplex = DUPLEX_FULL;
		break;
	case QETH_QOAT_PHYS_SPEED_UNKNOWN:
	default:
		link_info->speed = SPEED_UNKNOWN;
		link_info->duplex = DUPLEX_UNKNOWN;
		break;
	}

	switch (phys_if->media_type) {
	case QETH_QOAT_PHYS_MEDIA_COPPER:
		link_info->port = PORT_TP;
5015
		link_info->link_mode = QETH_LINK_MODE_UNKNOWN;
5016 5017
		break;
	case QETH_QOAT_PHYS_MEDIA_FIBRE_SHORT:
5018 5019 5020
		link_info->port = PORT_FIBRE;
		link_info->link_mode = QETH_LINK_MODE_FIBRE_SHORT;
		break;
5021 5022
	case QETH_QOAT_PHYS_MEDIA_FIBRE_LONG:
		link_info->port = PORT_FIBRE;
5023
		link_info->link_mode = QETH_LINK_MODE_FIBRE_LONG;
5024 5025 5026
		break;
	default:
		link_info->port = PORT_OTHER;
5027
		link_info->link_mode = QETH_LINK_MODE_UNKNOWN;
5028 5029 5030 5031 5032 5033
		break;
	}

	return 0;
}

5034 5035 5036 5037 5038 5039 5040
static void qeth_init_link_info(struct qeth_card *card)
{
	card->info.link_info.duplex = DUPLEX_FULL;

	if (IS_IQD(card) || IS_VM_NIC(card)) {
		card->info.link_info.speed = SPEED_10000;
		card->info.link_info.port = PORT_FIBRE;
5041
		card->info.link_info.link_mode = QETH_LINK_MODE_FIBRE_SHORT;
5042 5043 5044 5045 5046 5047 5048 5049 5050 5051 5052 5053 5054 5055 5056 5057 5058 5059 5060 5061 5062 5063 5064 5065 5066 5067
	} else {
		switch (card->info.link_type) {
		case QETH_LINK_TYPE_FAST_ETH:
		case QETH_LINK_TYPE_LANE_ETH100:
			card->info.link_info.speed = SPEED_100;
			card->info.link_info.port = PORT_TP;
			break;
		case QETH_LINK_TYPE_GBIT_ETH:
		case QETH_LINK_TYPE_LANE_ETH1000:
			card->info.link_info.speed = SPEED_1000;
			card->info.link_info.port = PORT_FIBRE;
			break;
		case QETH_LINK_TYPE_10GBIT_ETH:
			card->info.link_info.speed = SPEED_10000;
			card->info.link_info.port = PORT_FIBRE;
			break;
		case QETH_LINK_TYPE_25GBIT_ETH:
			card->info.link_info.speed = SPEED_25000;
			card->info.link_info.port = PORT_FIBRE;
			break;
		default:
			dev_info(&card->gdev->dev, "Unknown link type %x\n",
				 card->info.link_type);
			card->info.link_info.speed = SPEED_UNKNOWN;
			card->info.link_info.port = PORT_OTHER;
		}
5068 5069

		card->info.link_info.link_mode = QETH_LINK_MODE_UNKNOWN;
5070
	}
5071 5072 5073 5074 5075 5076 5077 5078 5079 5080 5081 5082 5083 5084 5085 5086 5087 5088 5089 5090 5091 5092 5093 5094

	/* Get more accurate data via QUERY OAT: */
	if (qeth_adp_supported(card, IPA_SETADP_QUERY_OAT)) {
		struct qeth_link_info link_info;
		struct qeth_cmd_buffer *iob;

		iob = qeth_get_adapter_cmd(card, IPA_SETADP_QUERY_OAT,
					   SETADP_DATA_SIZEOF(query_oat));
		if (iob) {
			struct qeth_ipa_cmd *cmd = __ipa_cmd(iob);
			struct qeth_query_oat *oat_req;

			oat_req = &cmd->data.setadapterparms.data.query_oat;
			oat_req->subcmd_code = QETH_QOAT_SCOPE_INTERFACE;

			if (!qeth_send_ipa_cmd(card, iob,
					       qeth_init_link_info_oat_cb,
					       &link_info)) {
				if (link_info.speed != SPEED_UNKNOWN)
					card->info.link_info.speed = link_info.speed;
				if (link_info.duplex != DUPLEX_UNKNOWN)
					card->info.link_info.duplex = link_info.duplex;
				if (link_info.port != PORT_OTHER)
					card->info.link_info.port = link_info.port;
5095 5096
				if (link_info.link_mode != QETH_LINK_MODE_UNKNOWN)
					card->info.link_info.link_mode = link_info.link_mode;
5097 5098 5099
			}
		}
	}
5100 5101
}

5102 5103 5104 5105 5106 5107 5108 5109 5110 5111 5112 5113 5114 5115
/**
 * qeth_vm_request_mac() - Request a hypervisor-managed MAC address
 * @card: pointer to a qeth_card
 *
 * Returns
 *	0, if a MAC address has been set for the card's netdevice
 *	a return code, for various error conditions
 */
int qeth_vm_request_mac(struct qeth_card *card)
{
	struct diag26c_mac_resp *response;
	struct diag26c_mac_req *request;
	int rc;

5116
	QETH_CARD_TEXT(card, 2, "vmreqmac");
5117 5118 5119 5120 5121 5122 5123 5124 5125 5126 5127

	request = kzalloc(sizeof(*request), GFP_KERNEL | GFP_DMA);
	response = kzalloc(sizeof(*response), GFP_KERNEL | GFP_DMA);
	if (!request || !response) {
		rc = -ENOMEM;
		goto out;
	}

	request->resp_buf_len = sizeof(*response);
	request->resp_version = DIAG26C_VERSION2;
	request->op_code = DIAG26C_GET_MAC;
5128
	request->devno = card->info.ddev_devno;
5129

5130
	QETH_DBF_HEX(CTRL, 2, request, sizeof(*request));
5131
	rc = diag26c(request, response, DIAG26C_MAC_SERVICES);
5132
	QETH_DBF_HEX(CTRL, 2, request, sizeof(*request));
5133 5134
	if (rc)
		goto out;
5135
	QETH_DBF_HEX(CTRL, 2, response, sizeof(*response));
5136 5137 5138 5139

	if (request->resp_buf_len < sizeof(*response) ||
	    response->version != request->resp_version) {
		rc = -EIO;
5140 5141 5142
		QETH_CARD_TEXT(card, 2, "badresp");
		QETH_CARD_HEX(card, 2, &request->resp_buf_len,
			      sizeof(request->resp_buf_len));
5143 5144
	} else if (!is_valid_ether_addr(response->mac)) {
		rc = -EINVAL;
5145 5146
		QETH_CARD_TEXT(card, 2, "badmac");
		QETH_CARD_HEX(card, 2, response->mac, ETH_ALEN);
5147 5148 5149 5150 5151 5152 5153 5154 5155 5156 5157
	} else {
		ether_addr_copy(card->dev->dev_addr, response->mac);
	}

out:
	kfree(response);
	kfree(request);
	return rc;
}
EXPORT_SYMBOL_GPL(qeth_vm_request_mac);

5158 5159
static void qeth_determine_capabilities(struct qeth_card *card)
{
5160 5161
	struct qeth_channel *channel = &card->data;
	struct ccw_device *ddev = channel->ccwdev;
5162 5163 5164
	int rc;
	int ddev_offline = 0;

5165
	QETH_CARD_TEXT(card, 2, "detcapab");
5166 5167
	if (!ddev->online) {
		ddev_offline = 1;
5168
		rc = qeth_start_channel(channel);
5169
		if (rc) {
5170
			QETH_CARD_TEXT_(card, 2, "3err%d", rc);
5171 5172 5173 5174
			goto out;
		}
	}

5175
	rc = qeth_read_conf_data(card);
5176
	if (rc) {
5177 5178
		QETH_DBF_MESSAGE(2, "qeth_read_conf_data on device %x returned %i\n",
				 CARD_DEVID(card), rc);
5179
		QETH_CARD_TEXT_(card, 2, "5err%d", rc);
5180 5181 5182 5183 5184
		goto out_offline;
	}

	rc = qdio_get_ssqd_desc(ddev, &card->ssqd);
	if (rc)
5185
		QETH_CARD_TEXT_(card, 2, "6err%d", rc);
5186

5187 5188 5189 5190 5191
	QETH_CARD_TEXT_(card, 2, "qfmt%d", card->ssqd.qfmt);
	QETH_CARD_TEXT_(card, 2, "ac1:%02x", card->ssqd.qdioac1);
	QETH_CARD_TEXT_(card, 2, "ac2:%04x", card->ssqd.qdioac2);
	QETH_CARD_TEXT_(card, 2, "ac3:%04x", card->ssqd.qdioac3);
	QETH_CARD_TEXT_(card, 2, "icnt%d", card->ssqd.icnt);
5192 5193 5194 5195 5196 5197 5198 5199 5200
	if (!((card->ssqd.qfmt != QDIO_IQDIO_QFMT) ||
	    ((card->ssqd.qdioac1 & CHSC_AC1_INITIATE_INPUTQ) == 0) ||
	    ((card->ssqd.qdioac3 & CHSC_AC3_FORMAT2_CQ_AVAILABLE) == 0))) {
		dev_info(&card->gdev->dev,
			"Completion Queueing supported\n");
	} else {
		card->options.cq = QETH_CQ_NOTAVAILABLE;
	}

5201 5202
out_offline:
	if (ddev_offline == 1)
5203
		qeth_stop_channel(channel);
5204 5205 5206 5207
out:
	return;
}

5208 5209 5210 5211 5212 5213 5214 5215 5216 5217 5218 5219 5220 5221 5222 5223 5224 5225 5226 5227 5228 5229 5230 5231 5232 5233 5234
static void qeth_read_ccw_conf_data(struct qeth_card *card)
{
	struct qeth_card_info *info = &card->info;
	struct ccw_device *cdev = CARD_DDEV(card);
	struct ccw_dev_id dev_id;

	QETH_CARD_TEXT(card, 2, "ccwconfd");
	ccw_device_get_id(cdev, &dev_id);

	info->ddev_devno = dev_id.devno;
	info->ids_valid = !ccw_device_get_cssid(cdev, &info->cssid) &&
			  !ccw_device_get_iid(cdev, &info->iid) &&
			  !ccw_device_get_chid(cdev, 0, &info->chid);
	info->ssid = dev_id.ssid;

	dev_info(&card->gdev->dev, "CHID: %x CHPID: %x\n",
		 info->chid, info->chpid);

	QETH_CARD_TEXT_(card, 3, "devn%x", info->ddev_devno);
	QETH_CARD_TEXT_(card, 3, "cssid:%x", info->cssid);
	QETH_CARD_TEXT_(card, 3, "iid:%x", info->iid);
	QETH_CARD_TEXT_(card, 3, "ssid:%x", info->ssid);
	QETH_CARD_TEXT_(card, 3, "chpid:%x", info->chpid);
	QETH_CARD_TEXT_(card, 3, "chid:%x", info->chid);
	QETH_CARD_TEXT_(card, 3, "idval%x", info->ids_valid);
}

F
Frank Blaschka 已提交
5235 5236
static int qeth_qdio_establish(struct qeth_card *card)
{
5237 5238
	struct qdio_buffer **out_sbal_ptrs[QETH_MAX_OUT_QUEUES];
	struct qdio_buffer **in_sbal_ptrs[QETH_MAX_IN_QUEUES];
5239
	struct qeth_qib_parms *qib_parms = NULL;
F
Frank Blaschka 已提交
5240
	struct qdio_initialize init_data;
5241
	unsigned int i;
F
Frank Blaschka 已提交
5242 5243
	int rc = 0;

5244
	QETH_CARD_TEXT(card, 2, "qdioest");
F
Frank Blaschka 已提交
5245

5246 5247 5248 5249
	if (!IS_IQD(card) && !IS_VM_NIC(card)) {
		qib_parms = kzalloc(sizeof_field(struct qib, parm), GFP_KERNEL);
		if (!qib_parms)
			return -ENOMEM;
F
Frank Blaschka 已提交
5250

5251 5252
		qeth_fill_qib_parms(card, qib_parms);
	}
F
Frank Blaschka 已提交
5253

5254 5255 5256
	in_sbal_ptrs[0] = card->qdio.in_q->qdio_bufs;
	if (card->options.cq == QETH_CQ_ENABLED)
		in_sbal_ptrs[1] = card->qdio.c_q->qdio_bufs;
5257

5258 5259
	for (i = 0; i < card->qdio.no_out_queues; i++)
		out_sbal_ptrs[i] = card->qdio.out_qs[i]->qdio_bufs;
F
Frank Blaschka 已提交
5260 5261

	memset(&init_data, 0, sizeof(struct qdio_initialize));
5262 5263
	init_data.q_format		 = IS_IQD(card) ? QDIO_IQDIO_QFMT :
							  QDIO_QETH_QFMT;
F
Frank Blaschka 已提交
5264
	init_data.qib_param_field_format = 0;
5265
	init_data.qib_param_field	 = (void *)qib_parms;
5266
	init_data.no_input_qs            = card->qdio.no_in_queues;
F
Frank Blaschka 已提交
5267
	init_data.no_output_qs           = card->qdio.no_out_queues;
5268 5269
	init_data.input_handler		 = qeth_qdio_input_handler;
	init_data.output_handler	 = qeth_qdio_output_handler;
5270
	init_data.irq_poll		 = qeth_qdio_poll;
F
Frank Blaschka 已提交
5271
	init_data.int_parm               = (unsigned long) card;
5272 5273
	init_data.input_sbal_addr_array  = in_sbal_ptrs;
	init_data.output_sbal_addr_array = out_sbal_ptrs;
5274
	init_data.output_sbal_state_array = card->qdio.out_bufstates;
5275
	init_data.scan_threshold	 = IS_IQD(card) ? 0 : 32;
F
Frank Blaschka 已提交
5276 5277 5278

	if (atomic_cmpxchg(&card->qdio.state, QETH_QDIO_ALLOCATED,
		QETH_QDIO_ESTABLISHED) == QETH_QDIO_ALLOCATED) {
5279 5280
		rc = qdio_allocate(CARD_DDEV(card), init_data.no_input_qs,
				   init_data.no_output_qs);
J
Jan Glauber 已提交
5281 5282 5283 5284
		if (rc) {
			atomic_set(&card->qdio.state, QETH_QDIO_ALLOCATED);
			goto out;
		}
5285
		rc = qdio_establish(CARD_DDEV(card), &init_data);
J
Jan Glauber 已提交
5286
		if (rc) {
F
Frank Blaschka 已提交
5287
			atomic_set(&card->qdio.state, QETH_QDIO_ALLOCATED);
J
Jan Glauber 已提交
5288 5289
			qdio_free(CARD_DDEV(card));
		}
F
Frank Blaschka 已提交
5290
	}
5291 5292 5293 5294 5295 5296 5297 5298 5299 5300 5301

	switch (card->options.cq) {
	case QETH_CQ_ENABLED:
		dev_info(&card->gdev->dev, "Completion Queue support enabled");
		break;
	case QETH_CQ_DISABLED:
		dev_info(&card->gdev->dev, "Completion Queue support disabled");
		break;
	default:
		break;
	}
5302

J
Jan Glauber 已提交
5303
out:
5304
	kfree(qib_parms);
F
Frank Blaschka 已提交
5305 5306 5307 5308 5309
	return rc;
}

static void qeth_core_free_card(struct qeth_card *card)
{
5310
	QETH_CARD_TEXT(card, 2, "freecrd");
5311 5312 5313

	unregister_service_level(&card->qeth_service_level);
	debugfs_remove_recursive(card->debugfs);
5314
	qeth_put_cmd(card->read_cmd);
5315
	destroy_workqueue(card->event_wq);
5316
	dev_set_drvdata(&card->gdev->dev, NULL);
F
Frank Blaschka 已提交
5317 5318 5319
	kfree(card);
}

5320
static void qeth_trace_features(struct qeth_card *card)
5321 5322
{
	QETH_CARD_TEXT(card, 2, "features");
5323 5324 5325 5326 5327
	QETH_CARD_HEX(card, 2, &card->options.ipa4, sizeof(card->options.ipa4));
	QETH_CARD_HEX(card, 2, &card->options.ipa6, sizeof(card->options.ipa6));
	QETH_CARD_HEX(card, 2, &card->options.adp, sizeof(card->options.adp));
	QETH_CARD_HEX(card, 2, &card->info.diagass_support,
		      sizeof(card->info.diagass_support));
5328 5329
}

F
Frank Blaschka 已提交
5330
static struct ccw_device_id qeth_ids[] = {
5331 5332 5333 5334
	{CCW_DEVICE_DEVTYPE(0x1731, 0x01, 0x1732, 0x01),
					.driver_info = QETH_CARD_TYPE_OSD},
	{CCW_DEVICE_DEVTYPE(0x1731, 0x05, 0x1732, 0x05),
					.driver_info = QETH_CARD_TYPE_IQD},
5335
#ifdef CONFIG_QETH_OSN
5336 5337
	{CCW_DEVICE_DEVTYPE(0x1731, 0x06, 0x1732, 0x06),
					.driver_info = QETH_CARD_TYPE_OSN},
5338
#endif
5339 5340
	{CCW_DEVICE_DEVTYPE(0x1731, 0x02, 0x1732, 0x03),
					.driver_info = QETH_CARD_TYPE_OSM},
5341
#ifdef CONFIG_QETH_OSX
5342 5343
	{CCW_DEVICE_DEVTYPE(0x1731, 0x02, 0x1732, 0x02),
					.driver_info = QETH_CARD_TYPE_OSX},
5344
#endif
F
Frank Blaschka 已提交
5345 5346 5347 5348 5349
	{},
};
MODULE_DEVICE_TABLE(ccw, qeth_ids);

static struct ccw_driver qeth_ccw_driver = {
5350
	.driver = {
S
Sebastian Ott 已提交
5351
		.owner = THIS_MODULE,
5352 5353
		.name = "qeth",
	},
F
Frank Blaschka 已提交
5354 5355 5356 5357 5358
	.ids = qeth_ids,
	.probe = ccwgroup_probe_ccwdev,
	.remove = ccwgroup_remove_ccwdev,
};

5359
static int qeth_hardsetup_card(struct qeth_card *card, bool *carrier_ok)
F
Frank Blaschka 已提交
5360
{
5361
	int retries = 3;
F
Frank Blaschka 已提交
5362 5363
	int rc;

5364
	QETH_CARD_TEXT(card, 2, "hrdsetup");
F
Frank Blaschka 已提交
5365
	atomic_set(&card->force_alloc_skb, 0);
5366 5367 5368
	rc = qeth_update_from_chp_desc(card);
	if (rc)
		return rc;
F
Frank Blaschka 已提交
5369
retry:
5370
	if (retries < 3)
5371 5372
		QETH_DBF_MESSAGE(2, "Retrying to do IDX activates on device %x.\n",
				 CARD_DEVID(card));
5373
	rc = qeth_qdio_clear_card(card, !IS_IQD(card));
5374 5375 5376
	qeth_stop_channel(&card->data);
	qeth_stop_channel(&card->write);
	qeth_stop_channel(&card->read);
5377
	qdio_free(CARD_DDEV(card));
5378 5379

	rc = qeth_start_channel(&card->read);
5380 5381
	if (rc)
		goto retriable;
5382
	rc = qeth_start_channel(&card->write);
5383 5384
	if (rc)
		goto retriable;
5385
	rc = qeth_start_channel(&card->data);
5386 5387 5388
	if (rc)
		goto retriable;
retriable:
F
Frank Blaschka 已提交
5389
	if (rc == -ERESTARTSYS) {
5390
		QETH_CARD_TEXT(card, 2, "break1");
F
Frank Blaschka 已提交
5391 5392
		return rc;
	} else if (rc) {
5393
		QETH_CARD_TEXT_(card, 2, "1err%d", rc);
5394
		if (--retries < 0)
F
Frank Blaschka 已提交
5395 5396 5397 5398
			goto out;
		else
			goto retry;
	}
5399

5400
	qeth_determine_capabilities(card);
5401
	qeth_read_ccw_conf_data(card);
5402
	qeth_idx_init(card);
5403 5404 5405

	rc = qeth_idx_activate_read_channel(card);
	if (rc == -EINTR) {
5406
		QETH_CARD_TEXT(card, 2, "break2");
F
Frank Blaschka 已提交
5407 5408
		return rc;
	} else if (rc) {
5409
		QETH_CARD_TEXT_(card, 2, "3err%d", rc);
F
Frank Blaschka 已提交
5410 5411 5412 5413 5414
		if (--retries < 0)
			goto out;
		else
			goto retry;
	}
5415 5416 5417

	rc = qeth_idx_activate_write_channel(card);
	if (rc == -EINTR) {
5418
		QETH_CARD_TEXT(card, 2, "break3");
F
Frank Blaschka 已提交
5419 5420
		return rc;
	} else if (rc) {
5421
		QETH_CARD_TEXT_(card, 2, "4err%d", rc);
F
Frank Blaschka 已提交
5422 5423 5424 5425 5426
		if (--retries < 0)
			goto out;
		else
			goto retry;
	}
5427
	card->read_or_write_problem = 0;
F
Frank Blaschka 已提交
5428 5429
	rc = qeth_mpc_initialize(card);
	if (rc) {
5430
		QETH_CARD_TEXT_(card, 2, "5err%d", rc);
F
Frank Blaschka 已提交
5431 5432
		goto out;
	}
5433

5434 5435
	rc = qeth_send_startlan(card);
	if (rc) {
5436
		QETH_CARD_TEXT_(card, 2, "6err%d", rc);
5437 5438
		if (rc == -ENETDOWN) {
			dev_warn(&card->gdev->dev, "The LAN is offline\n");
J
Julian Wiedmann 已提交
5439
			*carrier_ok = false;
5440 5441 5442
		} else {
			goto out;
		}
5443
	} else {
J
Julian Wiedmann 已提交
5444 5445 5446
		*carrier_ok = true;
	}

5447 5448 5449
	card->options.ipa4.supported = 0;
	card->options.ipa6.supported = 0;
	card->options.adp.supported = 0;
5450
	card->options.sbp.supported_funcs = 0;
5451
	card->info.diagass_support = 0;
5452 5453 5454
	rc = qeth_query_ipassists(card, QETH_PROT_IPV4);
	if (rc == -ENOMEM)
		goto out;
5455 5456 5457 5458 5459
	if (qeth_is_supported(card, IPA_IPV6)) {
		rc = qeth_query_ipassists(card, QETH_PROT_IPV6);
		if (rc == -ENOMEM)
			goto out;
	}
5460 5461 5462
	if (qeth_is_supported(card, IPA_SETADAPTERPARMS)) {
		rc = qeth_query_setadapterparms(card);
		if (rc < 0) {
5463
			QETH_CARD_TEXT_(card, 2, "7err%d", rc);
5464 5465 5466 5467 5468
			goto out;
		}
	}
	if (qeth_adp_supported(card, IPA_SETADP_SET_DIAG_ASSIST)) {
		rc = qeth_query_setdiagass(card);
5469
		if (rc)
5470
			QETH_CARD_TEXT_(card, 2, "8err%d", rc);
5471
	}
5472

5473 5474
	qeth_trace_features(card);

5475 5476 5477 5478
	if (!qeth_is_diagass_supported(card, QETH_DIAGS_CMD_TRAP) ||
	    (card->info.hwtrap && qeth_hw_trap(card, QETH_DIAGS_TRAP_ARM)))
		card->info.hwtrap = 0;

5479
	if (card->options.isolation != ISOLATION_MODE_NONE) {
5480 5481
		rc = qeth_setadpparms_set_access_ctrl(card,
						      card->options.isolation);
5482 5483 5484
		if (rc)
			goto out;
	}
5485

5486 5487
	qeth_init_link_info(card);

5488 5489 5490 5491 5492 5493
	rc = qeth_init_qdio_queues(card);
	if (rc) {
		QETH_CARD_TEXT_(card, 2, "9err%d", rc);
		goto out;
	}

F
Frank Blaschka 已提交
5494 5495
	return 0;
out:
5496 5497
	dev_warn(&card->gdev->dev, "The qeth device driver failed to recover "
		"an error on the device\n");
5498 5499
	QETH_DBF_MESSAGE(2, "Initialization for device %x failed in hardsetup! rc=%d\n",
			 CARD_DEVID(card), rc);
F
Frank Blaschka 已提交
5500 5501 5502
	return rc;
}

5503 5504
static int qeth_set_online(struct qeth_card *card,
			   const struct qeth_discipline *disc)
5505
{
5506
	bool carrier_ok;
5507 5508 5509 5510 5511
	int rc;

	mutex_lock(&card->conf_mutex);
	QETH_CARD_TEXT(card, 2, "setonlin");

5512 5513 5514 5515 5516 5517 5518 5519 5520
	rc = qeth_hardsetup_card(card, &carrier_ok);
	if (rc) {
		QETH_CARD_TEXT_(card, 2, "2err%04x", rc);
		rc = -ENODEV;
		goto err_hardsetup;
	}

	qeth_print_status_message(card);

5521
	if (card->dev->reg_state != NETREG_REGISTERED)
5522 5523 5524
		/* no need for locking / error handling at this early stage: */
		qeth_set_real_num_tx_queues(card, qeth_tx_actual_queues(card));

5525
	rc = disc->set_online(card, carrier_ok);
5526 5527 5528 5529 5530
	if (rc)
		goto err_online;

	/* let user_space know that device is online */
	kobject_uevent(&card->gdev->dev.kobj, KOBJ_CHANGE);
5531 5532

	mutex_unlock(&card->conf_mutex);
5533
	return 0;
5534

5535 5536
err_online:
err_hardsetup:
5537 5538 5539 5540
	qeth_qdio_clear_card(card, 0);
	qeth_clear_working_pool_list(card);
	qeth_flush_local_addrs(card);

5541 5542 5543 5544 5545 5546
	qeth_stop_channel(&card->data);
	qeth_stop_channel(&card->write);
	qeth_stop_channel(&card->read);
	qdio_free(CARD_DDEV(card));

	mutex_unlock(&card->conf_mutex);
5547 5548 5549
	return rc;
}

5550 5551
int qeth_set_offline(struct qeth_card *card, const struct qeth_discipline *disc,
		     bool resetting)
5552 5553 5554 5555 5556 5557 5558 5559 5560 5561 5562
{
	int rc, rc2, rc3;

	mutex_lock(&card->conf_mutex);
	QETH_CARD_TEXT(card, 3, "setoffl");

	if ((!resetting && card->info.hwtrap) || card->info.hwtrap == 2) {
		qeth_hw_trap(card, QETH_DIAGS_TRAP_DISARM);
		card->info.hwtrap = 1;
	}

5563 5564 5565
	/* cancel any stalled cmd that might block the rtnl: */
	qeth_clear_ipacmd_list(card);

5566 5567 5568 5569 5570 5571 5572
	rtnl_lock();
	card->info.open_when_online = card->dev->flags & IFF_UP;
	dev_close(card->dev);
	netif_device_detach(card->dev);
	netif_carrier_off(card->dev);
	rtnl_unlock();

5573 5574
	cancel_work_sync(&card->rx_mode_work);

5575
	disc->set_offline(card);
5576

5577 5578 5579 5580 5581 5582
	qeth_qdio_clear_card(card, 0);
	qeth_drain_output_queues(card);
	qeth_clear_working_pool_list(card);
	qeth_flush_local_addrs(card);
	card->info.promisc_mode = 0;

5583 5584 5585 5586 5587 5588 5589 5590 5591 5592 5593 5594 5595 5596 5597 5598 5599 5600 5601
	rc  = qeth_stop_channel(&card->data);
	rc2 = qeth_stop_channel(&card->write);
	rc3 = qeth_stop_channel(&card->read);
	if (!rc)
		rc = (rc2) ? rc2 : rc3;
	if (rc)
		QETH_CARD_TEXT_(card, 2, "1err%d", rc);
	qdio_free(CARD_DDEV(card));

	/* let user_space know that device is offline */
	kobject_uevent(&card->gdev->dev.kobj, KOBJ_CHANGE);

	mutex_unlock(&card->conf_mutex);
	return 0;
}
EXPORT_SYMBOL_GPL(qeth_set_offline);

static int qeth_do_reset(void *data)
{
5602
	const struct qeth_discipline *disc;
5603 5604 5605
	struct qeth_card *card = data;
	int rc;

5606 5607 5608
	/* Lock-free, other users will block until we are done. */
	disc = card->discipline;

5609 5610 5611 5612 5613 5614 5615
	QETH_CARD_TEXT(card, 2, "recover1");
	if (!qeth_do_run_thread(card, QETH_RECOVER_THREAD))
		return 0;
	QETH_CARD_TEXT(card, 2, "recover2");
	dev_warn(&card->gdev->dev,
		 "A recovery process has been started for the device\n");

5616 5617
	qeth_set_offline(card, disc, true);
	rc = qeth_set_online(card, disc);
5618 5619 5620 5621 5622 5623 5624 5625 5626 5627 5628 5629 5630
	if (!rc) {
		dev_info(&card->gdev->dev,
			 "Device successfully recovered!\n");
	} else {
		ccwgroup_set_offline(card->gdev);
		dev_warn(&card->gdev->dev,
			 "The qeth device driver failed to recover an error on the device\n");
	}
	qeth_clear_thread_start_bit(card, QETH_RECOVER_THREAD);
	qeth_clear_thread_running_bit(card, QETH_RECOVER_THREAD);
	return 0;
}

J
Julian Wiedmann 已提交
5631 5632 5633 5634 5635 5636 5637 5638 5639 5640 5641 5642 5643 5644 5645 5646 5647 5648 5649 5650 5651 5652 5653 5654 5655 5656 5657 5658 5659 5660 5661 5662 5663 5664 5665 5666 5667 5668 5669 5670 5671 5672 5673 5674 5675 5676 5677 5678 5679 5680 5681 5682 5683 5684 5685 5686 5687 5688 5689 5690
#if IS_ENABLED(CONFIG_QETH_L3)
static void qeth_l3_rebuild_skb(struct qeth_card *card, struct sk_buff *skb,
				struct qeth_hdr *hdr)
{
	struct af_iucv_trans_hdr *iucv = (struct af_iucv_trans_hdr *) skb->data;
	struct qeth_hdr_layer3 *l3_hdr = &hdr->hdr.l3;
	struct net_device *dev = skb->dev;

	if (IS_IQD(card) && iucv->magic == ETH_P_AF_IUCV) {
		dev_hard_header(skb, dev, ETH_P_AF_IUCV, dev->dev_addr,
				"FAKELL", skb->len);
		return;
	}

	if (!(l3_hdr->flags & QETH_HDR_PASSTHRU)) {
		u16 prot = (l3_hdr->flags & QETH_HDR_IPV6) ? ETH_P_IPV6 :
							     ETH_P_IP;
		unsigned char tg_addr[ETH_ALEN];

		skb_reset_network_header(skb);
		switch (l3_hdr->flags & QETH_HDR_CAST_MASK) {
		case QETH_CAST_MULTICAST:
			if (prot == ETH_P_IP)
				ip_eth_mc_map(ip_hdr(skb)->daddr, tg_addr);
			else
				ipv6_eth_mc_map(&ipv6_hdr(skb)->daddr, tg_addr);
			QETH_CARD_STAT_INC(card, rx_multicast);
			break;
		case QETH_CAST_BROADCAST:
			ether_addr_copy(tg_addr, dev->broadcast);
			QETH_CARD_STAT_INC(card, rx_multicast);
			break;
		default:
			if (card->options.sniffer)
				skb->pkt_type = PACKET_OTHERHOST;
			ether_addr_copy(tg_addr, dev->dev_addr);
		}

		if (l3_hdr->ext_flags & QETH_HDR_EXT_SRC_MAC_ADDR)
			dev_hard_header(skb, dev, prot, tg_addr,
					&l3_hdr->next_hop.rx.src_mac, skb->len);
		else
			dev_hard_header(skb, dev, prot, tg_addr, "FAKELL",
					skb->len);
	}

	/* copy VLAN tag from hdr into skb */
	if (!card->options.sniffer &&
	    (l3_hdr->ext_flags & (QETH_HDR_EXT_VLAN_FRAME |
				  QETH_HDR_EXT_INCLUDE_VLAN_TAG))) {
		u16 tag = (l3_hdr->ext_flags & QETH_HDR_EXT_VLAN_FRAME) ?
				l3_hdr->vlan_id :
				l3_hdr->next_hop.rx.vlan_id;

		__vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), tag);
	}
}
#endif

static void qeth_receive_skb(struct qeth_card *card, struct sk_buff *skb,
5691
			     struct qeth_hdr *hdr, bool uses_frags)
J
Julian Wiedmann 已提交
5692
{
5693
	struct napi_struct *napi = &card->napi;
J
Julian Wiedmann 已提交
5694 5695 5696 5697 5698 5699 5700 5701 5702 5703 5704 5705 5706 5707 5708 5709 5710 5711 5712 5713 5714 5715
	bool is_cso;

	switch (hdr->hdr.l2.id) {
	case QETH_HEADER_TYPE_OSN:
		skb_push(skb, sizeof(*hdr));
		skb_copy_to_linear_data(skb, hdr, sizeof(*hdr));
		QETH_CARD_STAT_ADD(card, rx_bytes, skb->len);
		QETH_CARD_STAT_INC(card, rx_packets);

		card->osn_info.data_cb(skb);
		return;
#if IS_ENABLED(CONFIG_QETH_L3)
	case QETH_HEADER_TYPE_LAYER3:
		qeth_l3_rebuild_skb(card, skb, hdr);
		is_cso = hdr->hdr.l3.ext_flags & QETH_HDR_EXT_CSUM_TRANSP_REQ;
		break;
#endif
	case QETH_HEADER_TYPE_LAYER2:
		is_cso = hdr->hdr.l2.flags[1] & QETH_HDR_EXT_CSUM_TRANSP_REQ;
		break;
	default:
		/* never happens */
5716 5717 5718 5719
		if (uses_frags)
			napi_free_frags(napi);
		else
			dev_kfree_skb_any(skb);
J
Julian Wiedmann 已提交
5720 5721 5722 5723 5724 5725 5726 5727 5728 5729 5730 5731 5732 5733 5734 5735 5736 5737
		return;
	}

	if (is_cso && (card->dev->features & NETIF_F_RXCSUM)) {
		skb->ip_summed = CHECKSUM_UNNECESSARY;
		QETH_CARD_STAT_INC(card, rx_skb_csum);
	} else {
		skb->ip_summed = CHECKSUM_NONE;
	}

	QETH_CARD_STAT_ADD(card, rx_bytes, skb->len);
	QETH_CARD_STAT_INC(card, rx_packets);
	if (skb_is_nonlinear(skb)) {
		QETH_CARD_STAT_INC(card, rx_sg_skbs);
		QETH_CARD_STAT_ADD(card, rx_sg_frags,
				   skb_shinfo(skb)->nr_frags);
	}

5738 5739 5740 5741 5742 5743
	if (uses_frags) {
		napi_gro_frags(napi);
	} else {
		skb->protocol = eth_type_trans(skb, skb->dev);
		napi_gro_receive(napi, skb);
	}
J
Julian Wiedmann 已提交
5744 5745
}

5746
static void qeth_create_skb_frag(struct sk_buff *skb, char *data, int data_len)
F
Frank Blaschka 已提交
5747
{
5748
	struct page *page = virt_to_page(data);
5749
	unsigned int next_frag;
5750

5751
	next_frag = skb_shinfo(skb)->nr_frags;
5752
	get_page(page);
5753 5754
	skb_add_rx_frag(skb, next_frag, page, offset_in_page(data), data_len,
			data_len);
F
Frank Blaschka 已提交
5755 5756
}

5757 5758 5759 5760 5761
static inline int qeth_is_last_sbale(struct qdio_buffer_element *sbale)
{
	return (sbale->eflags & SBAL_EFLAGS_LAST_ENTRY);
}

J
Julian Wiedmann 已提交
5762
static int qeth_extract_skb(struct qeth_card *card,
5763
			    struct qeth_qdio_buffer *qethbuffer, u8 *element_no,
J
Julian Wiedmann 已提交
5764
			    int *__offset)
F
Frank Blaschka 已提交
5765
{
5766
	struct qeth_priv *priv = netdev_priv(card->dev);
5767
	struct qdio_buffer *buffer = qethbuffer->buffer;
5768
	struct napi_struct *napi = &card->napi;
5769
	struct qdio_buffer_element *element;
5770
	unsigned int linear_len = 0;
5771
	bool uses_frags = false;
F
Frank Blaschka 已提交
5772
	int offset = *__offset;
5773
	bool use_rx_sg = false;
5774
	unsigned int headroom;
J
Julian Wiedmann 已提交
5775
	struct qeth_hdr *hdr;
5776
	struct sk_buff *skb;
5777
	int skb_len = 0;
F
Frank Blaschka 已提交
5778

5779 5780
	element = &buffer->element[*element_no];

5781
next_packet:
F
Frank Blaschka 已提交
5782
	/* qeth_hdr must not cross element boundaries */
5783
	while (element->length < offset + sizeof(struct qeth_hdr)) {
F
Frank Blaschka 已提交
5784
		if (qeth_is_last_sbale(element))
J
Julian Wiedmann 已提交
5785
			return -ENODATA;
F
Frank Blaschka 已提交
5786 5787 5788 5789
		element++;
		offset = 0;
	}

5790
	hdr = phys_to_virt(element->addr) + offset;
J
Julian Wiedmann 已提交
5791
	offset += sizeof(*hdr);
5792 5793
	skb = NULL;

J
Julian Wiedmann 已提交
5794
	switch (hdr->hdr.l2.id) {
5795
	case QETH_HEADER_TYPE_LAYER2:
J
Julian Wiedmann 已提交
5796
		skb_len = hdr->hdr.l2.pkt_length;
5797
		linear_len = ETH_HLEN;
5798
		headroom = 0;
5799 5800
		break;
	case QETH_HEADER_TYPE_LAYER3:
J
Julian Wiedmann 已提交
5801
		skb_len = hdr->hdr.l3.length;
5802 5803 5804 5805 5806
		if (!IS_LAYER3(card)) {
			QETH_CARD_STAT_INC(card, rx_dropped_notsupp);
			goto walk_packet;
		}

J
Julian Wiedmann 已提交
5807
		if (hdr->hdr.l3.flags & QETH_HDR_PASSTHRU) {
5808 5809 5810 5811 5812
			linear_len = ETH_HLEN;
			headroom = 0;
			break;
		}

J
Julian Wiedmann 已提交
5813
		if (hdr->hdr.l3.flags & QETH_HDR_IPV6)
5814 5815 5816
			linear_len = sizeof(struct ipv6hdr);
		else
			linear_len = sizeof(struct iphdr);
5817
		headroom = ETH_HLEN;
5818 5819
		break;
	case QETH_HEADER_TYPE_OSN:
J
Julian Wiedmann 已提交
5820
		skb_len = hdr->hdr.osn.pdu_length;
5821 5822 5823 5824 5825
		if (!IS_OSN(card)) {
			QETH_CARD_STAT_INC(card, rx_dropped_notsupp);
			goto walk_packet;
		}

5826
		linear_len = skb_len;
5827 5828 5829
		headroom = sizeof(struct qeth_hdr);
		break;
	default:
J
Julian Wiedmann 已提交
5830
		if (hdr->hdr.l2.id & QETH_HEADER_MASK_INVAL)
5831 5832 5833 5834
			QETH_CARD_STAT_INC(card, rx_frame_errors);
		else
			QETH_CARD_STAT_INC(card, rx_dropped_notsupp);

5835
		/* Can't determine packet length, drop the whole buffer. */
J
Julian Wiedmann 已提交
5836
		return -EPROTONOSUPPORT;
F
Frank Blaschka 已提交
5837 5838
	}

5839 5840 5841 5842
	if (skb_len < linear_len) {
		QETH_CARD_STAT_INC(card, rx_dropped_runt);
		goto walk_packet;
	}
F
Frank Blaschka 已提交
5843

5844
	use_rx_sg = (card->options.cq == QETH_CQ_ENABLED) ||
5845
		    (skb_len > READ_ONCE(priv->rx_copybreak) &&
5846 5847
		     !atomic_read(&card->force_alloc_skb) &&
		     !IS_OSN(card));
5848

5849
	if (use_rx_sg) {
5850
		/* QETH_CQ_ENABLED only: */
5851 5852
		if (qethbuffer->rx_skb &&
		    skb_tailroom(qethbuffer->rx_skb) >= linear_len + headroom) {
5853 5854 5855 5856 5857 5858 5859 5860 5861 5862 5863 5864 5865 5866 5867 5868 5869 5870 5871 5872 5873
			skb = qethbuffer->rx_skb;
			qethbuffer->rx_skb = NULL;
			goto use_skb;
		}

		skb = napi_get_frags(napi);
		if (!skb) {
			/* -ENOMEM, no point in falling back further. */
			QETH_CARD_STAT_INC(card, rx_dropped_nomem);
			goto walk_packet;
		}

		if (skb_tailroom(skb) >= linear_len + headroom) {
			uses_frags = true;
			goto use_skb;
		}

		netdev_info_once(card->dev,
				 "Insufficient linear space in NAPI frags skb, need %u but have %u\n",
				 linear_len + headroom, skb_tailroom(skb));
		/* Shouldn't happen. Don't optimize, fall back to linear skb. */
F
Frank Blaschka 已提交
5874
	}
5875

5876 5877 5878
	linear_len = skb_len;
	skb = napi_alloc_skb(napi, linear_len + headroom);
	if (!skb) {
5879
		QETH_CARD_STAT_INC(card, rx_dropped_nomem);
5880 5881
		goto walk_packet;
	}
F
Frank Blaschka 已提交
5882

5883 5884 5885
use_skb:
	if (headroom)
		skb_reserve(skb, headroom);
5886
walk_packet:
F
Frank Blaschka 已提交
5887
	while (skb_len) {
5888
		int data_len = min(skb_len, (int)(element->length - offset));
5889
		char *data = phys_to_virt(element->addr) + offset;
5890 5891 5892

		skb_len -= data_len;
		offset += data_len;
5893

5894
		/* Extract data from current element: */
5895
		if (skb && data_len) {
5896 5897 5898 5899 5900 5901 5902 5903 5904 5905 5906 5907 5908 5909
			if (linear_len) {
				unsigned int copy_len;

				copy_len = min_t(unsigned int, linear_len,
						 data_len);

				skb_put_data(skb, data, copy_len);
				linear_len -= copy_len;
				data_len -= copy_len;
				data += copy_len;
			}

			if (data_len)
				qeth_create_skb_frag(skb, data, data_len);
F
Frank Blaschka 已提交
5910
		}
5911 5912

		/* Step forward to next element: */
F
Frank Blaschka 已提交
5913 5914
		if (skb_len) {
			if (qeth_is_last_sbale(element)) {
C
Carsten Otte 已提交
5915
				QETH_CARD_TEXT(card, 4, "unexeob");
C
Carsten Otte 已提交
5916
				QETH_CARD_HEX(card, 2, buffer, sizeof(void *));
5917
				if (skb) {
5918 5919 5920 5921
					if (uses_frags)
						napi_free_frags(napi);
					else
						dev_kfree_skb_any(skb);
5922 5923 5924
					QETH_CARD_STAT_INC(card,
							   rx_length_errors);
				}
J
Julian Wiedmann 已提交
5925
				return -EMSGSIZE;
F
Frank Blaschka 已提交
5926 5927 5928 5929 5930
			}
			element++;
			offset = 0;
		}
	}
5931 5932 5933 5934 5935

	/* This packet was skipped, go get another one: */
	if (!skb)
		goto next_packet;

5936
	*element_no = element - &buffer->element[0];
F
Frank Blaschka 已提交
5937
	*__offset = offset;
J
Julian Wiedmann 已提交
5938

5939
	qeth_receive_skb(card, skb, hdr, uses_frags);
J
Julian Wiedmann 已提交
5940 5941 5942
	return 0;
}

5943 5944
static unsigned int qeth_extract_skbs(struct qeth_card *card, int budget,
				      struct qeth_qdio_buffer *buf, bool *done)
J
Julian Wiedmann 已提交
5945
{
5946
	unsigned int work_done = 0;
J
Julian Wiedmann 已提交
5947 5948

	while (budget) {
5949
		if (qeth_extract_skb(card, buf, &card->rx.buf_element,
J
Julian Wiedmann 已提交
5950 5951 5952 5953 5954 5955 5956
				     &card->rx.e_offset)) {
			*done = true;
			break;
		}

		work_done++;
		budget--;
F
Frank Blaschka 已提交
5957
	}
J
Julian Wiedmann 已提交
5958 5959

	return work_done;
F
Frank Blaschka 已提交
5960 5961
}

5962
static unsigned int qeth_rx_poll(struct qeth_card *card, int budget)
5963
{
5964
	struct qeth_rx *ctx = &card->rx;
5965
	unsigned int work_done = 0;
5966

5967
	while (budget > 0) {
5968 5969 5970 5971
		struct qeth_qdio_buffer *buffer;
		unsigned int skbs_done = 0;
		bool done = false;

5972
		/* Fetch completed RX buffers: */
5973 5974 5975 5976 5977 5978 5979 5980 5981 5982 5983
		if (!card->rx.b_count) {
			card->rx.qdio_err = 0;
			card->rx.b_count = qdio_get_next_buffers(
				card->data.ccwdev, 0, &card->rx.b_index,
				&card->rx.qdio_err);
			if (card->rx.b_count <= 0) {
				card->rx.b_count = 0;
				break;
			}
		}

5984
		/* Process one completed RX buffer: */
5985 5986 5987 5988 5989 5990 5991 5992 5993 5994 5995 5996 5997 5998 5999
		buffer = &card->qdio.in_q->bufs[card->rx.b_index];
		if (!(card->rx.qdio_err &&
		      qeth_check_qdio_errors(card, buffer->buffer,
					     card->rx.qdio_err, "qinerr")))
			skbs_done = qeth_extract_skbs(card, budget, buffer,
						      &done);
		else
			done = true;

		work_done += skbs_done;
		budget -= skbs_done;

		if (done) {
			QETH_CARD_STAT_INC(card, rx_bufs);
			qeth_put_buffer_pool_entry(card, buffer->pool_entry);
6000
			buffer->pool_entry = NULL;
6001
			card->rx.b_count--;
6002 6003 6004
			ctx->bufs_refill++;
			ctx->bufs_refill -= qeth_rx_refill_queue(card,
								 ctx->bufs_refill);
6005 6006 6007 6008 6009

			/* Step forward to next buffer: */
			card->rx.b_index = QDIO_BUFNR(card->rx.b_index + 1);
			card->rx.buf_element = 0;
			card->rx.e_offset = 0;
6010 6011 6012
		}
	}

6013 6014 6015
	return work_done;
}

6016 6017 6018 6019 6020 6021 6022 6023 6024 6025 6026 6027 6028 6029 6030 6031 6032 6033
static void qeth_cq_poll(struct qeth_card *card)
{
	unsigned int work_done = 0;

	while (work_done < QDIO_MAX_BUFFERS_PER_Q) {
		unsigned int start, error;
		int completed;

		completed = qdio_inspect_queue(CARD_DDEV(card), 1, true, &start,
					       &error);
		if (completed <= 0)
			return;

		qeth_qdio_cq_handler(card, error, 1, start, completed);
		work_done += completed;
	}
}

6034 6035 6036 6037 6038 6039 6040
int qeth_poll(struct napi_struct *napi, int budget)
{
	struct qeth_card *card = container_of(napi, struct qeth_card, napi);
	unsigned int work_done;

	work_done = qeth_rx_poll(card, budget);

6041 6042 6043
	if (card->options.cq == QETH_CQ_ENABLED)
		qeth_cq_poll(card);

6044 6045 6046 6047 6048 6049 6050 6051 6052 6053
	if (budget) {
		struct qeth_rx *ctx = &card->rx;

		/* Process any substantial refill backlog: */
		ctx->bufs_refill -= qeth_rx_refill_queue(card, ctx->bufs_refill);

		/* Exhausted the RX budget. Keep IRQ disabled, we get called again. */
		if (work_done >= budget)
			return work_done;
	}
6054

6055
	if (napi_complete_done(napi, work_done) &&
6056
	    qdio_start_irq(CARD_DDEV(card)))
6057
		napi_schedule(napi);
6058

6059 6060 6061 6062
	return work_done;
}
EXPORT_SYMBOL_GPL(qeth_poll);

6063
static void qeth_iqd_tx_complete(struct qeth_qdio_out_q *queue,
6064 6065
				 unsigned int bidx, unsigned int qdio_error,
				 int budget)
6066 6067 6068 6069
{
	struct qeth_qdio_out_buffer *buffer = queue->bufs[bidx];
	u8 sflags = buffer->buffer->element[15].sflags;
	struct qeth_card *card = queue->card;
6070
	bool error = !!qdio_error;
6071

6072
	if (qdio_error == QDIO_ERROR_SLSB_PENDING) {
6073 6074
		WARN_ON_ONCE(card->options.cq != QETH_CQ_ENABLED);

6075 6076 6077 6078 6079 6080 6081
		QETH_CARD_TEXT_(card, 5, "pel%u", bidx);

		switch (atomic_cmpxchg(&buffer->state,
				       QETH_QDIO_BUF_PRIMED,
				       QETH_QDIO_BUF_PENDING)) {
		case QETH_QDIO_BUF_PRIMED:
			/* We have initial ownership, no QAOB (yet): */
6082 6083
			qeth_notify_skbs(queue, buffer, TX_NOTIFY_PENDING);

6084 6085 6086 6087 6088
			/* Handle race with qeth_qdio_handle_aob(): */
			switch (atomic_xchg(&buffer->state,
					    QETH_QDIO_BUF_NEED_QAOB)) {
			case QETH_QDIO_BUF_PENDING:
				/* No concurrent QAOB notification. */
6089 6090 6091

				/* Prepare the queue slot for immediate re-use: */
				qeth_scrub_qdio_buffer(buffer->buffer, queue->max_elements);
6092 6093
				if (qeth_alloc_out_buf(queue, bidx,
						       GFP_ATOMIC)) {
6094 6095 6096 6097
					QETH_CARD_TEXT(card, 2, "outofbuf");
					qeth_schedule_recovery(card);
				}

6098 6099
				list_add(&buffer->list_entry,
					 &queue->pending_bufs);
6100 6101
				/* Skip clearing the buffer: */
				return;
6102 6103 6104
			case QETH_QDIO_BUF_QAOB_OK:
				qeth_notify_skbs(queue, buffer,
						 TX_NOTIFY_DELAYED_OK);
6105
				error = false;
6106 6107 6108 6109
				break;
			case QETH_QDIO_BUF_QAOB_ERROR:
				qeth_notify_skbs(queue, buffer,
						 TX_NOTIFY_DELAYED_GENERALERROR);
6110
				error = true;
6111 6112 6113 6114
				break;
			default:
				WARN_ON_ONCE(1);
			}
6115

6116 6117 6118 6119 6120 6121 6122 6123 6124 6125 6126 6127 6128
			break;
		case QETH_QDIO_BUF_QAOB_OK:
			/* qeth_qdio_handle_aob() already received a QAOB: */
			qeth_notify_skbs(queue, buffer, TX_NOTIFY_OK);
			error = false;
			break;
		case QETH_QDIO_BUF_QAOB_ERROR:
			/* qeth_qdio_handle_aob() already received a QAOB: */
			qeth_notify_skbs(queue, buffer, TX_NOTIFY_GENERALERROR);
			error = true;
			break;
		default:
			WARN_ON_ONCE(1);
6129
		}
6130
	} else if (card->options.cq == QETH_CQ_ENABLED) {
6131 6132
		qeth_notify_skbs(queue, buffer,
				 qeth_compute_cq_notification(sflags, 0));
6133 6134
	}

6135
	qeth_clear_output_buffer(queue, buffer, error, budget);
6136 6137 6138 6139 6140 6141 6142 6143 6144 6145 6146 6147 6148 6149 6150
}

static int qeth_tx_poll(struct napi_struct *napi, int budget)
{
	struct qeth_qdio_out_q *queue = qeth_napi_to_out_queue(napi);
	unsigned int queue_no = queue->queue_no;
	struct qeth_card *card = queue->card;
	struct net_device *dev = card->dev;
	unsigned int work_done = 0;
	struct netdev_queue *txq;

	txq = netdev_get_tx_queue(dev, qeth_iqd_translate_txq(dev, queue_no));

	while (1) {
		unsigned int start, error, i;
6151 6152
		unsigned int packets = 0;
		unsigned int bytes = 0;
6153 6154
		int completed;

6155 6156
		qeth_tx_complete_pending_bufs(card, queue, false);

6157 6158 6159 6160 6161 6162 6163 6164 6165 6166 6167 6168 6169 6170 6171 6172 6173 6174
		if (qeth_out_queue_is_empty(queue)) {
			napi_complete(napi);
			return 0;
		}

		/* Give the CPU a breather: */
		if (work_done >= QDIO_MAX_BUFFERS_PER_Q) {
			QETH_TXQ_STAT_INC(queue, completion_yield);
			if (napi_complete_done(napi, 0))
				napi_schedule(napi);
			return 0;
		}

		completed = qdio_inspect_queue(CARD_DDEV(card), queue_no, false,
					       &start, &error);
		if (completed <= 0) {
			/* Ensure we see TX completion for pending work: */
			if (napi_complete_done(napi, 0))
6175
				qeth_tx_arm_timer(queue, QETH_TX_TIMER_USECS);
6176 6177 6178 6179
			return 0;
		}

		for (i = start; i < start + completed; i++) {
6180
			struct qeth_qdio_out_buffer *buffer;
6181 6182
			unsigned int bidx = QDIO_BUFNR(i);

6183
			buffer = queue->bufs[bidx];
6184
			packets += buffer->frames;
6185 6186 6187
			bytes += buffer->bytes;

			qeth_handle_send_error(card, buffer, error);
6188
			qeth_iqd_tx_complete(queue, bidx, error, budget);
6189 6190
		}

6191
		netdev_tx_completed_queue(txq, packets, bytes);
6192 6193 6194 6195 6196 6197 6198 6199 6200 6201 6202 6203 6204 6205
		atomic_sub(completed, &queue->used_buffers);
		work_done += completed;

		/* xmit may have observed the full-condition, but not yet
		 * stopped the txq. In which case the code below won't trigger.
		 * So before returning, xmit will re-check the txq's fill level
		 * and wake it up if needed.
		 */
		if (netif_tx_queue_stopped(txq) &&
		    !qeth_out_queue_is_full(queue))
			netif_tx_wake_queue(txq);
	}
}

6206 6207 6208 6209 6210 6211 6212
static int qeth_setassparms_inspect_rc(struct qeth_ipa_cmd *cmd)
{
	if (!cmd->hdr.return_code)
		cmd->hdr.return_code = cmd->data.setassparms.hdr.return_code;
	return cmd->hdr.return_code;
}

6213 6214 6215 6216 6217 6218 6219 6220
static int qeth_setassparms_get_caps_cb(struct qeth_card *card,
					struct qeth_reply *reply,
					unsigned long data)
{
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
	struct qeth_ipa_caps *caps = reply->param;

	if (qeth_setassparms_inspect_rc(cmd))
6221
		return -EIO;
6222 6223 6224 6225 6226 6227

	caps->supported = cmd->data.setassparms.data.caps.supported;
	caps->enabled = cmd->data.setassparms.data.caps.enabled;
	return 0;
}

6228 6229
int qeth_setassparms_cb(struct qeth_card *card,
			struct qeth_reply *reply, unsigned long data)
6230
{
6231
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
6232 6233 6234

	QETH_CARD_TEXT(card, 4, "defadpcb");

6235 6236 6237 6238 6239
	if (cmd->hdr.return_code)
		return -EIO;

	cmd->hdr.return_code = cmd->data.setassparms.hdr.return_code;
	if (cmd->hdr.prot_version == QETH_PROT_IPV4)
6240
		card->options.ipa4.enabled = cmd->hdr.assists.enabled;
6241
	if (cmd->hdr.prot_version == QETH_PROT_IPV6)
6242
		card->options.ipa6.enabled = cmd->hdr.assists.enabled;
6243 6244
	return 0;
}
6245
EXPORT_SYMBOL_GPL(qeth_setassparms_cb);
6246

6247 6248
struct qeth_cmd_buffer *qeth_get_setassparms_cmd(struct qeth_card *card,
						 enum qeth_ipa_funcs ipa_func,
6249 6250
						 u16 cmd_code,
						 unsigned int data_length,
6251
						 enum qeth_prot_versions prot)
6252
{
6253 6254
	struct qeth_ipacmd_setassparms *setassparms;
	struct qeth_ipacmd_setassparms_hdr *hdr;
6255 6256 6257
	struct qeth_cmd_buffer *iob;

	QETH_CARD_TEXT(card, 4, "getasscm");
6258 6259 6260 6261 6262 6263
	iob = qeth_ipa_alloc_cmd(card, IPA_CMD_SETASSPARMS, prot,
				 data_length +
				 offsetof(struct qeth_ipacmd_setassparms,
					  data));
	if (!iob)
		return NULL;
6264

6265 6266
	setassparms = &__ipa_cmd(iob)->data.setassparms;
	setassparms->assist_no = ipa_func;
6267

6268 6269 6270
	hdr = &setassparms->hdr;
	hdr->length = sizeof(*hdr) + data_length;
	hdr->command_code = cmd_code;
6271 6272
	return iob;
}
6273
EXPORT_SYMBOL_GPL(qeth_get_setassparms_cmd);
6274

6275 6276
int qeth_send_simple_setassparms_prot(struct qeth_card *card,
				      enum qeth_ipa_funcs ipa_func,
6277
				      u16 cmd_code, u32 *data,
6278
				      enum qeth_prot_versions prot)
6279
{
6280
	unsigned int length = data ? SETASS_DATA_SIZEOF(flags_32bit) : 0;
6281 6282
	struct qeth_cmd_buffer *iob;

6283 6284
	QETH_CARD_TEXT_(card, 4, "simassp%i", prot);
	iob = qeth_get_setassparms_cmd(card, ipa_func, cmd_code, length, prot);
6285 6286
	if (!iob)
		return -ENOMEM;
6287

6288 6289
	if (data)
		__ipa_cmd(iob)->data.setassparms.data.flags_32bit = *data;
6290
	return qeth_send_ipa_cmd(card, iob, qeth_setassparms_cb, NULL);
6291
}
6292
EXPORT_SYMBOL_GPL(qeth_send_simple_setassparms_prot);
6293

F
Frank Blaschka 已提交
6294 6295
static void qeth_unregister_dbf_views(void)
{
6296
	int x;
6297

6298 6299 6300 6301
	for (x = 0; x < QETH_DBF_INFOS; x++) {
		debug_unregister(qeth_dbf[x].id);
		qeth_dbf[x].id = NULL;
	}
F
Frank Blaschka 已提交
6302 6303
}

C
Carsten Otte 已提交
6304
void qeth_dbf_longtext(debug_info_t *id, int level, char *fmt, ...)
P
Peter Tiedemann 已提交
6305 6306
{
	char dbf_txt_buf[32];
6307
	va_list args;
P
Peter Tiedemann 已提交
6308

6309
	if (!debug_level_enabled(id, level))
P
Peter Tiedemann 已提交
6310
		return;
6311 6312 6313
	va_start(args, fmt);
	vsnprintf(dbf_txt_buf, sizeof(dbf_txt_buf), fmt, args);
	va_end(args);
C
Carsten Otte 已提交
6314
	debug_text_event(id, level, dbf_txt_buf);
P
Peter Tiedemann 已提交
6315 6316 6317
}
EXPORT_SYMBOL_GPL(qeth_dbf_longtext);

F
Frank Blaschka 已提交
6318 6319
static int qeth_register_dbf_views(void)
{
6320 6321 6322 6323 6324 6325 6326 6327 6328 6329 6330 6331 6332
	int ret;
	int x;

	for (x = 0; x < QETH_DBF_INFOS; x++) {
		/* register the areas */
		qeth_dbf[x].id = debug_register(qeth_dbf[x].name,
						qeth_dbf[x].pages,
						qeth_dbf[x].areas,
						qeth_dbf[x].len);
		if (qeth_dbf[x].id == NULL) {
			qeth_unregister_dbf_views();
			return -ENOMEM;
		}
F
Frank Blaschka 已提交
6333

6334 6335 6336 6337 6338 6339
		/* register a view */
		ret = debug_register_view(qeth_dbf[x].id, qeth_dbf[x].view);
		if (ret) {
			qeth_unregister_dbf_views();
			return ret;
		}
F
Frank Blaschka 已提交
6340

6341 6342 6343
		/* set a passing level */
		debug_set_level(qeth_dbf[x].id, qeth_dbf[x].level);
	}
F
Frank Blaschka 已提交
6344 6345 6346 6347

	return 0;
}

6348 6349
static DEFINE_MUTEX(qeth_mod_mutex);	/* for synchronized module loading */

6350 6351
int qeth_setup_discipline(struct qeth_card *card,
			  enum qeth_discipline_id discipline)
F
Frank Blaschka 已提交
6352
{
6353 6354
	int rc;

6355
	mutex_lock(&qeth_mod_mutex);
F
Frank Blaschka 已提交
6356 6357
	switch (discipline) {
	case QETH_DISCIPLINE_LAYER3:
6358 6359
		card->discipline = try_then_request_module(
			symbol_get(qeth_l3_discipline), "qeth_l3");
F
Frank Blaschka 已提交
6360 6361
		break;
	case QETH_DISCIPLINE_LAYER2:
6362 6363
		card->discipline = try_then_request_module(
			symbol_get(qeth_l2_discipline), "qeth_l2");
F
Frank Blaschka 已提交
6364
		break;
6365 6366
	default:
		break;
F
Frank Blaschka 已提交
6367
	}
6368
	mutex_unlock(&qeth_mod_mutex);
6369

6370
	if (!card->discipline) {
6371 6372
		dev_err(&card->gdev->dev, "There is no kernel module to "
			"support discipline %d\n", discipline);
6373
		return -EINVAL;
F
Frank Blaschka 已提交
6374
	}
6375

6376 6377 6378 6379 6380 6381 6382 6383 6384 6385 6386
	rc = card->discipline->setup(card->gdev);
	if (rc) {
		if (discipline == QETH_DISCIPLINE_LAYER2)
			symbol_put(qeth_l2_discipline);
		else
			symbol_put(qeth_l3_discipline);
		card->discipline = NULL;

		return rc;
	}

6387
	card->options.layer = discipline;
6388
	return 0;
F
Frank Blaschka 已提交
6389 6390
}

6391
void qeth_remove_discipline(struct qeth_card *card)
F
Frank Blaschka 已提交
6392
{
6393 6394
	card->discipline->remove(card->gdev);

6395
	if (IS_LAYER2(card))
6396
		symbol_put(qeth_l2_discipline);
F
Frank Blaschka 已提交
6397
	else
6398
		symbol_put(qeth_l3_discipline);
6399
	card->options.layer = QETH_DISCIPLINE_UNDETERMINED;
6400
	card->discipline = NULL;
F
Frank Blaschka 已提交
6401 6402
}

6403
const struct device_type qeth_generic_devtype = {
6404 6405
	.name = "qeth_generic",
};
6406 6407
EXPORT_SYMBOL_GPL(qeth_generic_devtype);

6408 6409 6410 6411
static const struct device_type qeth_osn_devtype = {
	.name = "qeth_osn",
};

6412 6413 6414 6415 6416 6417 6418 6419 6420 6421 6422 6423 6424 6425 6426 6427 6428 6429 6430 6431 6432 6433 6434 6435 6436 6437 6438 6439 6440 6441 6442 6443 6444 6445 6446 6447 6448 6449 6450 6451 6452 6453 6454 6455 6456 6457 6458 6459 6460 6461 6462 6463 6464 6465 6466 6467 6468 6469 6470 6471 6472 6473 6474 6475 6476 6477 6478 6479
#define DBF_NAME_LEN	20

struct qeth_dbf_entry {
	char dbf_name[DBF_NAME_LEN];
	debug_info_t *dbf_info;
	struct list_head dbf_list;
};

static LIST_HEAD(qeth_dbf_list);
static DEFINE_MUTEX(qeth_dbf_list_mutex);

static debug_info_t *qeth_get_dbf_entry(char *name)
{
	struct qeth_dbf_entry *entry;
	debug_info_t *rc = NULL;

	mutex_lock(&qeth_dbf_list_mutex);
	list_for_each_entry(entry, &qeth_dbf_list, dbf_list) {
		if (strcmp(entry->dbf_name, name) == 0) {
			rc = entry->dbf_info;
			break;
		}
	}
	mutex_unlock(&qeth_dbf_list_mutex);
	return rc;
}

static int qeth_add_dbf_entry(struct qeth_card *card, char *name)
{
	struct qeth_dbf_entry *new_entry;

	card->debug = debug_register(name, 2, 1, 8);
	if (!card->debug) {
		QETH_DBF_TEXT_(SETUP, 2, "%s", "qcdbf");
		goto err;
	}
	if (debug_register_view(card->debug, &debug_hex_ascii_view))
		goto err_dbg;
	new_entry = kzalloc(sizeof(struct qeth_dbf_entry), GFP_KERNEL);
	if (!new_entry)
		goto err_dbg;
	strncpy(new_entry->dbf_name, name, DBF_NAME_LEN);
	new_entry->dbf_info = card->debug;
	mutex_lock(&qeth_dbf_list_mutex);
	list_add(&new_entry->dbf_list, &qeth_dbf_list);
	mutex_unlock(&qeth_dbf_list_mutex);

	return 0;

err_dbg:
	debug_unregister(card->debug);
err:
	return -ENOMEM;
}

static void qeth_clear_dbf_list(void)
{
	struct qeth_dbf_entry *entry, *tmp;

	mutex_lock(&qeth_dbf_list_mutex);
	list_for_each_entry_safe(entry, tmp, &qeth_dbf_list, dbf_list) {
		list_del(&entry->dbf_list);
		debug_unregister(entry->dbf_info);
		kfree(entry);
	}
	mutex_unlock(&qeth_dbf_list_mutex);
}

6480 6481 6482
static struct net_device *qeth_alloc_netdev(struct qeth_card *card)
{
	struct net_device *dev;
6483
	struct qeth_priv *priv;
6484 6485 6486

	switch (card->info.type) {
	case QETH_CARD_TYPE_IQD:
6487
		dev = alloc_netdev_mqs(sizeof(*priv), "hsi%d", NET_NAME_UNKNOWN,
6488
				       ether_setup, QETH_MAX_OUT_QUEUES, 1);
6489
		break;
6490
	case QETH_CARD_TYPE_OSM:
6491
		dev = alloc_etherdev(sizeof(*priv));
6492
		break;
6493
	case QETH_CARD_TYPE_OSN:
6494 6495
		dev = alloc_netdev(sizeof(*priv), "osn%d", NET_NAME_UNKNOWN,
				   ether_setup);
6496 6497
		break;
	default:
6498
		dev = alloc_etherdev_mqs(sizeof(*priv), QETH_MAX_OUT_QUEUES, 1);
6499 6500 6501 6502 6503
	}

	if (!dev)
		return NULL;

6504 6505
	priv = netdev_priv(dev);
	priv->rx_copybreak = QETH_RX_COPYBREAK;
6506
	priv->tx_wanted_queues = IS_IQD(card) ? QETH_IQD_MIN_TXQ : 1;
6507

6508 6509
	dev->ml_priv = card;
	dev->watchdog_timeo = QETH_TX_TIMEOUT;
6510
	dev->min_mtu = IS_OSN(card) ? 64 : 576;
6511 6512 6513
	 /* initialized when device first goes online: */
	dev->max_mtu = 0;
	dev->mtu = 0;
6514 6515
	SET_NETDEV_DEV(dev, &card->gdev->dev);
	netif_carrier_off(dev);
6516

6517 6518 6519 6520 6521 6522 6523 6524 6525 6526
	if (IS_OSN(card)) {
		dev->ethtool_ops = &qeth_osn_ethtool_ops;
	} else {
		dev->ethtool_ops = &qeth_ethtool_ops;
		dev->priv_flags &= ~IFF_TX_SKB_SHARING;
		dev->hw_features |= NETIF_F_SG;
		dev->vlan_features |= NETIF_F_SG;
		if (IS_IQD(card))
			dev->features |= NETIF_F_SG;
	}
6527

6528 6529 6530 6531 6532 6533 6534 6535 6536 6537 6538 6539 6540 6541
	return dev;
}

struct net_device *qeth_clone_netdev(struct net_device *orig)
{
	struct net_device *clone = qeth_alloc_netdev(orig->ml_priv);

	if (!clone)
		return NULL;

	clone->dev_port = orig->dev_port;
	return clone;
}

F
Frank Blaschka 已提交
6542 6543 6544 6545 6546
static int qeth_core_probe_device(struct ccwgroup_device *gdev)
{
	struct qeth_card *card;
	struct device *dev;
	int rc;
6547
	enum qeth_discipline_id enforced_disc;
6548
	char dbf_name[DBF_NAME_LEN];
F
Frank Blaschka 已提交
6549

6550
	QETH_DBF_TEXT(SETUP, 2, "probedev");
F
Frank Blaschka 已提交
6551 6552 6553 6554 6555

	dev = &gdev->dev;
	if (!get_device(dev))
		return -ENODEV;

6556
	QETH_DBF_TEXT_(SETUP, 2, "%s", dev_name(&gdev->dev));
F
Frank Blaschka 已提交
6557

6558
	card = qeth_alloc_card(gdev);
F
Frank Blaschka 已提交
6559
	if (!card) {
6560
		QETH_DBF_TEXT_(SETUP, 2, "1err%d", -ENOMEM);
F
Frank Blaschka 已提交
6561 6562 6563
		rc = -ENOMEM;
		goto err_dev;
	}
6564 6565 6566

	snprintf(dbf_name, sizeof(dbf_name), "qeth_card_%s",
		dev_name(&gdev->dev));
6567
	card->debug = qeth_get_dbf_entry(dbf_name);
6568
	if (!card->debug) {
6569 6570 6571
		rc = qeth_add_dbf_entry(card, dbf_name);
		if (rc)
			goto err_card;
6572 6573
	}

6574
	qeth_setup_card(card);
6575
	card->dev = qeth_alloc_netdev(card);
6576 6577
	if (!card->dev) {
		rc = -ENOMEM;
6578
		goto err_card;
6579
	}
6580

6581 6582 6583
	qeth_determine_capabilities(card);
	qeth_set_blkt_defaults(card);

6584 6585 6586 6587
	card->qdio.no_out_queues = card->dev->num_tx_queues;
	rc = qeth_update_from_chp_desc(card);
	if (rc)
		goto err_chp_desc;
6588

6589 6590 6591 6592 6593
	if (IS_OSN(card))
		gdev->dev.groups = qeth_osn_dev_groups;
	else
		gdev->dev.groups = qeth_dev_groups;

6594 6595 6596 6597 6598 6599 6600
	enforced_disc = qeth_enforce_discipline(card);
	switch (enforced_disc) {
	case QETH_DISCIPLINE_UNDETERMINED:
		gdev->dev.type = &qeth_generic_devtype;
		break;
	default:
		card->info.layer_enforced = true;
6601
		/* It's so early that we don't need the discipline_mutex yet. */
6602
		rc = qeth_setup_discipline(card, enforced_disc);
6603
		if (rc)
6604
			goto err_setup_disc;
6605

6606 6607
		gdev->dev.type = IS_OSN(card) ? &qeth_osn_devtype :
						card->discipline->devtype;
6608
		break;
F
Frank Blaschka 已提交
6609 6610 6611 6612
	}

	return 0;

6613
err_setup_disc:
6614
err_chp_desc:
6615
	free_netdev(card->dev);
F
Frank Blaschka 已提交
6616 6617 6618 6619 6620 6621 6622 6623 6624 6625 6626
err_card:
	qeth_core_free_card(card);
err_dev:
	put_device(dev);
	return rc;
}

static void qeth_core_remove_device(struct ccwgroup_device *gdev)
{
	struct qeth_card *card = dev_get_drvdata(&gdev->dev);

6627
	QETH_CARD_TEXT(card, 2, "removedv");
F
Frank Blaschka 已提交
6628

6629
	mutex_lock(&card->discipline_mutex);
6630 6631
	if (card->discipline)
		qeth_remove_discipline(card);
6632
	mutex_unlock(&card->discipline_mutex);
6633

6634 6635
	qeth_free_qdio_queues(card);

6636
	free_netdev(card->dev);
F
Frank Blaschka 已提交
6637 6638 6639 6640 6641 6642 6643 6644
	qeth_core_free_card(card);
	put_device(&gdev->dev);
}

static int qeth_core_set_online(struct ccwgroup_device *gdev)
{
	struct qeth_card *card = dev_get_drvdata(&gdev->dev);
	int rc = 0;
6645
	enum qeth_discipline_id def_discipline;
F
Frank Blaschka 已提交
6646

6647
	mutex_lock(&card->discipline_mutex);
6648
	if (!card->discipline) {
6649 6650
		def_discipline = IS_IQD(card) ? QETH_DISCIPLINE_LAYER3 :
						QETH_DISCIPLINE_LAYER2;
6651
		rc = qeth_setup_discipline(card, def_discipline);
F
Frank Blaschka 已提交
6652 6653 6654
		if (rc)
			goto err;
	}
6655

6656 6657
	rc = qeth_set_online(card, card->discipline);

F
Frank Blaschka 已提交
6658
err:
6659
	mutex_unlock(&card->discipline_mutex);
F
Frank Blaschka 已提交
6660 6661 6662 6663 6664 6665
	return rc;
}

static int qeth_core_set_offline(struct ccwgroup_device *gdev)
{
	struct qeth_card *card = dev_get_drvdata(&gdev->dev);
6666
	int rc;
6667

6668 6669 6670 6671 6672
	mutex_lock(&card->discipline_mutex);
	rc = qeth_set_offline(card, card->discipline, false);
	mutex_unlock(&card->discipline_mutex);

	return rc;
F
Frank Blaschka 已提交
6673 6674 6675 6676 6677
}

static void qeth_core_shutdown(struct ccwgroup_device *gdev)
{
	struct qeth_card *card = dev_get_drvdata(&gdev->dev);
6678

6679 6680 6681 6682
	qeth_set_allowed_threads(card, 0, 1);
	if ((gdev->state == CCWGROUP_ONLINE) && card->info.hwtrap)
		qeth_hw_trap(card, QETH_DIAGS_TRAP_DISARM);
	qeth_qdio_clear_card(card, 0);
6683
	qeth_drain_output_queues(card);
6684
	qdio_free(CARD_DDEV(card));
F
Frank Blaschka 已提交
6685 6686
}

6687 6688
static ssize_t group_store(struct device_driver *ddrv, const char *buf,
			   size_t count)
F
Frank Blaschka 已提交
6689 6690 6691
{
	int err;

6692 6693
	err = ccwgroup_create_dev(qeth_core_root_dev, to_ccwgroupdrv(ddrv), 3,
				  buf);
6694 6695 6696

	return err ? err : count;
}
6697
static DRIVER_ATTR_WO(group);
F
Frank Blaschka 已提交
6698

6699 6700 6701 6702 6703 6704 6705 6706 6707 6708 6709 6710
static struct attribute *qeth_drv_attrs[] = {
	&driver_attr_group.attr,
	NULL,
};
static struct attribute_group qeth_drv_attr_group = {
	.attrs = qeth_drv_attrs,
};
static const struct attribute_group *qeth_drv_attr_groups[] = {
	&qeth_drv_attr_group,
	NULL,
};

6711 6712 6713 6714 6715 6716 6717 6718 6719 6720 6721 6722 6723 6724
static struct ccwgroup_driver qeth_core_ccwgroup_driver = {
	.driver = {
		.groups = qeth_drv_attr_groups,
		.owner = THIS_MODULE,
		.name = "qeth",
	},
	.ccw_driver = &qeth_ccw_driver,
	.setup = qeth_core_probe_device,
	.remove = qeth_core_remove_device,
	.set_online = qeth_core_set_online,
	.set_offline = qeth_core_set_offline,
	.shutdown = qeth_core_shutdown,
};

J
Julian Wiedmann 已提交
6725 6726 6727 6728 6729 6730 6731 6732 6733 6734 6735 6736 6737 6738 6739
struct qeth_card *qeth_get_card_by_busid(char *bus_id)
{
	struct ccwgroup_device *gdev;
	struct qeth_card *card;

	gdev = get_ccwgroupdev_by_busid(&qeth_core_ccwgroup_driver, bus_id);
	if (!gdev)
		return NULL;

	card = dev_get_drvdata(&gdev->dev);
	put_device(&gdev->dev);
	return card;
}
EXPORT_SYMBOL_GPL(qeth_get_card_by_busid);

6740 6741 6742 6743 6744 6745 6746 6747 6748 6749 6750
int qeth_do_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
{
	struct qeth_card *card = dev->ml_priv;
	struct mii_ioctl_data *mii_data;
	int rc = 0;

	switch (cmd) {
	case SIOC_QETH_ADP_SET_SNMP_CONTROL:
		rc = qeth_snmp_command(card, rq->ifr_ifru.ifru_data);
		break;
	case SIOC_QETH_GET_CARD_TYPE:
6751 6752
		if ((IS_OSD(card) || IS_OSM(card) || IS_OSX(card)) &&
		    !IS_VM_NIC(card))
6753
			return 1;
6754
		return 0;
6755 6756 6757 6758 6759 6760 6761 6762 6763 6764 6765 6766 6767 6768 6769 6770 6771 6772 6773 6774 6775 6776 6777 6778 6779 6780 6781
	case SIOCGMIIPHY:
		mii_data = if_mii(rq);
		mii_data->phy_id = 0;
		break;
	case SIOCGMIIREG:
		mii_data = if_mii(rq);
		if (mii_data->phy_id != 0)
			rc = -EINVAL;
		else
			mii_data->val_out = qeth_mdio_read(dev,
				mii_data->phy_id, mii_data->reg_num);
		break;
	case SIOC_QETH_QUERY_OAT:
		rc = qeth_query_oat_command(card, rq->ifr_ifru.ifru_data);
		break;
	default:
		if (card->discipline->do_ioctl)
			rc = card->discipline->do_ioctl(dev, rq, cmd);
		else
			rc = -EOPNOTSUPP;
	}
	if (rc)
		QETH_CARD_TEXT_(card, 2, "ioce%x", rc);
	return rc;
}
EXPORT_SYMBOL_GPL(qeth_do_ioctl);

6782 6783
static int qeth_start_csum_cb(struct qeth_card *card, struct qeth_reply *reply,
			      unsigned long data)
6784 6785
{
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
6786
	u32 *features = reply->param;
6787

6788
	if (qeth_setassparms_inspect_rc(cmd))
6789
		return -EIO;
6790

6791
	*features = cmd->data.setassparms.data.flags_32bit;
6792 6793 6794
	return 0;
}

6795 6796
static int qeth_set_csum_off(struct qeth_card *card, enum qeth_ipa_funcs cstype,
			     enum qeth_prot_versions prot)
6797
{
6798 6799
	return qeth_send_simple_setassparms_prot(card, cstype, IPA_CMD_ASS_STOP,
						 NULL, prot);
6800 6801
}

6802
static int qeth_set_csum_on(struct qeth_card *card, enum qeth_ipa_funcs cstype,
6803
			    enum qeth_prot_versions prot, u8 *lp2lp)
6804
{
6805
	u32 required_features = QETH_IPA_CHECKSUM_UDP | QETH_IPA_CHECKSUM_TCP;
6806 6807 6808
	struct qeth_cmd_buffer *iob;
	struct qeth_ipa_caps caps;
	u32 features;
6809 6810
	int rc;

6811 6812 6813
	/* some L3 HW requires combined L3+L4 csum offload: */
	if (IS_LAYER3(card) && prot == QETH_PROT_IPV4 &&
	    cstype == IPA_OUTBOUND_CHECKSUM)
6814
		required_features |= QETH_IPA_CHECKSUM_IP_HDR;
6815

6816 6817 6818 6819 6820 6821 6822
	iob = qeth_get_setassparms_cmd(card, cstype, IPA_CMD_ASS_START, 0,
				       prot);
	if (!iob)
		return -ENOMEM;

	rc = qeth_send_ipa_cmd(card, iob, qeth_start_csum_cb, &features);
	if (rc)
6823
		return rc;
6824

6825 6826 6827 6828
	if ((required_features & features) != required_features) {
		qeth_set_csum_off(card, cstype, prot);
		return -EOPNOTSUPP;
	}
6829

6830 6831
	iob = qeth_get_setassparms_cmd(card, cstype, IPA_CMD_ASS_ENABLE,
				       SETASS_DATA_SIZEOF(flags_32bit),
6832
				       prot);
6833 6834 6835
	if (!iob) {
		qeth_set_csum_off(card, cstype, prot);
		return -ENOMEM;
6836
	}
6837 6838 6839 6840 6841

	if (features & QETH_IPA_CHECKSUM_LP2LP)
		required_features |= QETH_IPA_CHECKSUM_LP2LP;
	__ipa_cmd(iob)->data.setassparms.data.flags_32bit = required_features;
	rc = qeth_send_ipa_cmd(card, iob, qeth_setassparms_get_caps_cb, &caps);
6842
	if (rc) {
6843
		qeth_set_csum_off(card, cstype, prot);
6844 6845
		return rc;
	}
6846

6847 6848 6849 6850 6851 6852
	if (!qeth_ipa_caps_supported(&caps, required_features) ||
	    !qeth_ipa_caps_enabled(&caps, required_features)) {
		qeth_set_csum_off(card, cstype, prot);
		return -EOPNOTSUPP;
	}

6853 6854
	dev_info(&card->gdev->dev, "HW Checksumming (%sbound IPv%d) enabled\n",
		 cstype == IPA_INBOUND_CHECKSUM ? "in" : "out", prot);
6855 6856 6857 6858

	if (lp2lp)
		*lp2lp = qeth_ipa_caps_enabled(&caps, QETH_IPA_CHECKSUM_LP2LP);

6859 6860 6861
	return 0;
}

6862
static int qeth_set_ipa_csum(struct qeth_card *card, bool on, int cstype,
6863
			     enum qeth_prot_versions prot, u8 *lp2lp)
6864
{
6865
	return on ? qeth_set_csum_on(card, cstype, prot, lp2lp) :
6866
		    qeth_set_csum_off(card, cstype, prot);
6867 6868
}

6869 6870 6871 6872 6873 6874 6875
static int qeth_start_tso_cb(struct qeth_card *card, struct qeth_reply *reply,
			     unsigned long data)
{
	struct qeth_ipa_cmd *cmd = (struct qeth_ipa_cmd *) data;
	struct qeth_tso_start_data *tso_data = reply->param;

	if (qeth_setassparms_inspect_rc(cmd))
6876
		return -EIO;
6877 6878 6879 6880 6881 6882

	tso_data->mss = cmd->data.setassparms.data.tso.mss;
	tso_data->supported = cmd->data.setassparms.data.tso.supported;
	return 0;
}

6883 6884
static int qeth_set_tso_off(struct qeth_card *card,
			    enum qeth_prot_versions prot)
6885
{
6886
	return qeth_send_simple_setassparms_prot(card, IPA_OUTBOUND_TSO,
6887
						 IPA_CMD_ASS_STOP, NULL, prot);
6888
}
6889

6890 6891 6892
static int qeth_set_tso_on(struct qeth_card *card,
			   enum qeth_prot_versions prot)
{
6893 6894 6895 6896 6897 6898 6899 6900 6901 6902
	struct qeth_tso_start_data tso_data;
	struct qeth_cmd_buffer *iob;
	struct qeth_ipa_caps caps;
	int rc;

	iob = qeth_get_setassparms_cmd(card, IPA_OUTBOUND_TSO,
				       IPA_CMD_ASS_START, 0, prot);
	if (!iob)
		return -ENOMEM;

6903
	rc = qeth_send_ipa_cmd(card, iob, qeth_start_tso_cb, &tso_data);
6904 6905 6906 6907 6908 6909 6910 6911 6912
	if (rc)
		return rc;

	if (!tso_data.mss || !(tso_data.supported & QETH_IPA_LARGE_SEND_TCP)) {
		qeth_set_tso_off(card, prot);
		return -EOPNOTSUPP;
	}

	iob = qeth_get_setassparms_cmd(card, IPA_OUTBOUND_TSO,
6913 6914
				       IPA_CMD_ASS_ENABLE,
				       SETASS_DATA_SIZEOF(caps), prot);
6915 6916 6917 6918 6919 6920
	if (!iob) {
		qeth_set_tso_off(card, prot);
		return -ENOMEM;
	}

	/* enable TSO capability */
6921 6922 6923
	__ipa_cmd(iob)->data.setassparms.data.caps.enabled =
		QETH_IPA_LARGE_SEND_TCP;
	rc = qeth_send_ipa_cmd(card, iob, qeth_setassparms_get_caps_cb, &caps);
6924 6925 6926 6927 6928 6929 6930 6931 6932 6933 6934 6935 6936 6937
	if (rc) {
		qeth_set_tso_off(card, prot);
		return rc;
	}

	if (!qeth_ipa_caps_supported(&caps, QETH_IPA_LARGE_SEND_TCP) ||
	    !qeth_ipa_caps_enabled(&caps, QETH_IPA_LARGE_SEND_TCP)) {
		qeth_set_tso_off(card, prot);
		return -EOPNOTSUPP;
	}

	dev_info(&card->gdev->dev, "TSOv%u enabled (MSS: %u)\n", prot,
		 tso_data.mss);
	return 0;
6938
}
6939

6940 6941 6942
static int qeth_set_ipa_tso(struct qeth_card *card, bool on,
			    enum qeth_prot_versions prot)
{
6943
	return on ? qeth_set_tso_on(card, prot) : qeth_set_tso_off(card, prot);
6944
}
6945

6946 6947 6948 6949 6950 6951 6952
static int qeth_set_ipa_rx_csum(struct qeth_card *card, bool on)
{
	int rc_ipv4 = (on) ? -EOPNOTSUPP : 0;
	int rc_ipv6;

	if (qeth_is_supported(card, IPA_INBOUND_CHECKSUM))
		rc_ipv4 = qeth_set_ipa_csum(card, on, IPA_INBOUND_CHECKSUM,
6953
					    QETH_PROT_IPV4, NULL);
6954 6955 6956
	if (!qeth_is_supported6(card, IPA_INBOUND_CHECKSUM_V6))
		/* no/one Offload Assist available, so the rc is trivial */
		return rc_ipv4;
6957

6958
	rc_ipv6 = qeth_set_ipa_csum(card, on, IPA_INBOUND_CHECKSUM,
6959
				    QETH_PROT_IPV6, NULL);
6960 6961 6962 6963 6964 6965 6966 6967 6968

	if (on)
		/* enable: success if any Assist is active */
		return (rc_ipv6) ? rc_ipv4 : 0;

	/* disable: failure if any Assist is still active */
	return (rc_ipv6) ? rc_ipv6 : rc_ipv4;
}

6969
/**
6970 6971
 * qeth_enable_hw_features() - (Re-)Enable HW functions for device features
 * @dev:	a net_device
6972
 */
6973
void qeth_enable_hw_features(struct net_device *dev)
6974 6975
{
	struct qeth_card *card = dev->ml_priv;
6976
	netdev_features_t features;
6977

6978
	features = dev->features;
6979
	/* force-off any feature that might need an IPA sequence.
6980 6981
	 * netdev_update_features() will restart them.
	 */
6982 6983 6984 6985 6986 6987
	dev->features &= ~dev->hw_features;
	/* toggle VLAN filter, so that VIDs are re-programmed: */
	if (IS_LAYER2(card) && IS_VM_NIC(card)) {
		dev->features &= ~NETIF_F_HW_VLAN_CTAG_FILTER;
		dev->wanted_features |= NETIF_F_HW_VLAN_CTAG_FILTER;
	}
6988
	netdev_update_features(dev);
6989 6990 6991
	if (features != dev->features)
		dev_warn(&card->gdev->dev,
			 "Device recovery failed to restore all offload features\n");
6992
}
6993
EXPORT_SYMBOL_GPL(qeth_enable_hw_features);
6994

6995 6996 6997 6998 6999 7000 7001 7002 7003 7004 7005 7006 7007 7008 7009 7010 7011 7012
static void qeth_check_restricted_features(struct qeth_card *card,
					   netdev_features_t changed,
					   netdev_features_t actual)
{
	netdev_features_t ipv6_features = NETIF_F_TSO6;
	netdev_features_t ipv4_features = NETIF_F_TSO;

	if (!card->info.has_lp2lp_cso_v6)
		ipv6_features |= NETIF_F_IPV6_CSUM;
	if (!card->info.has_lp2lp_cso_v4)
		ipv4_features |= NETIF_F_IP_CSUM;

	if ((changed & ipv6_features) && !(actual & ipv6_features))
		qeth_flush_local_addrs6(card);
	if ((changed & ipv4_features) && !(actual & ipv4_features))
		qeth_flush_local_addrs4(card);
}

7013 7014 7015
int qeth_set_features(struct net_device *dev, netdev_features_t features)
{
	struct qeth_card *card = dev->ml_priv;
7016
	netdev_features_t changed = dev->features ^ features;
7017 7018
	int rc = 0;

7019 7020
	QETH_CARD_TEXT(card, 2, "setfeat");
	QETH_CARD_HEX(card, 2, &features, sizeof(features));
7021

7022
	if ((changed & NETIF_F_IP_CSUM)) {
7023
		rc = qeth_set_ipa_csum(card, features & NETIF_F_IP_CSUM,
7024 7025
				       IPA_OUTBOUND_CHECKSUM, QETH_PROT_IPV4,
				       &card->info.has_lp2lp_cso_v4);
7026 7027 7028
		if (rc)
			changed ^= NETIF_F_IP_CSUM;
	}
7029 7030
	if (changed & NETIF_F_IPV6_CSUM) {
		rc = qeth_set_ipa_csum(card, features & NETIF_F_IPV6_CSUM,
7031 7032
				       IPA_OUTBOUND_CHECKSUM, QETH_PROT_IPV6,
				       &card->info.has_lp2lp_cso_v6);
7033 7034 7035
		if (rc)
			changed ^= NETIF_F_IPV6_CSUM;
	}
7036 7037
	if (changed & NETIF_F_RXCSUM) {
		rc = qeth_set_ipa_rx_csum(card, features & NETIF_F_RXCSUM);
7038 7039 7040
		if (rc)
			changed ^= NETIF_F_RXCSUM;
	}
7041 7042 7043
	if (changed & NETIF_F_TSO) {
		rc = qeth_set_ipa_tso(card, features & NETIF_F_TSO,
				      QETH_PROT_IPV4);
7044 7045 7046
		if (rc)
			changed ^= NETIF_F_TSO;
	}
7047 7048 7049 7050 7051 7052
	if (changed & NETIF_F_TSO6) {
		rc = qeth_set_ipa_tso(card, features & NETIF_F_TSO6,
				      QETH_PROT_IPV6);
		if (rc)
			changed ^= NETIF_F_TSO6;
	}
7053

7054 7055 7056
	qeth_check_restricted_features(card, dev->features ^ features,
				       dev->features ^ changed);

7057 7058 7059 7060 7061 7062
	/* everything changed successfully? */
	if ((dev->features ^ features) == changed)
		return 0;
	/* something went wrong. save changed features and return error */
	dev->features ^= changed;
	return -EIO;
7063 7064 7065 7066 7067 7068 7069 7070
}
EXPORT_SYMBOL_GPL(qeth_set_features);

netdev_features_t qeth_fix_features(struct net_device *dev,
				    netdev_features_t features)
{
	struct qeth_card *card = dev->ml_priv;

7071
	QETH_CARD_TEXT(card, 2, "fixfeat");
7072 7073
	if (!qeth_is_supported(card, IPA_OUTBOUND_CHECKSUM))
		features &= ~NETIF_F_IP_CSUM;
7074 7075
	if (!qeth_is_supported6(card, IPA_OUTBOUND_CHECKSUM_V6))
		features &= ~NETIF_F_IPV6_CSUM;
7076 7077
	if (!qeth_is_supported(card, IPA_INBOUND_CHECKSUM) &&
	    !qeth_is_supported6(card, IPA_INBOUND_CHECKSUM_V6))
7078
		features &= ~NETIF_F_RXCSUM;
7079
	if (!qeth_is_supported(card, IPA_OUTBOUND_TSO))
7080
		features &= ~NETIF_F_TSO;
7081 7082
	if (!qeth_is_supported6(card, IPA_OUTBOUND_TSO))
		features &= ~NETIF_F_TSO6;
7083

7084
	QETH_CARD_HEX(card, 2, &features, sizeof(features));
7085 7086 7087
	return features;
}
EXPORT_SYMBOL_GPL(qeth_fix_features);
7088

7089 7090 7091 7092
netdev_features_t qeth_features_check(struct sk_buff *skb,
				      struct net_device *dev,
				      netdev_features_t features)
{
7093 7094
	struct qeth_card *card = dev->ml_priv;

7095
	/* Traffic with local next-hop is not eligible for some offloads: */
7096
	if (skb->ip_summed == CHECKSUM_PARTIAL &&
7097
	    READ_ONCE(card->options.isolation) != ISOLATION_MODE_FWD) {
7098 7099 7100 7101 7102 7103 7104 7105 7106 7107 7108 7109 7110 7111 7112 7113 7114 7115 7116 7117 7118 7119 7120 7121 7122
		netdev_features_t restricted = 0;

		if (skb_is_gso(skb) && !netif_needs_gso(skb, features))
			restricted |= NETIF_F_ALL_TSO;

		switch (vlan_get_protocol(skb)) {
		case htons(ETH_P_IP):
			if (!card->info.has_lp2lp_cso_v4)
				restricted |= NETIF_F_IP_CSUM;

			if (restricted && qeth_next_hop_is_local_v4(card, skb))
				features &= ~restricted;
			break;
		case htons(ETH_P_IPV6):
			if (!card->info.has_lp2lp_cso_v6)
				restricted |= NETIF_F_IPV6_CSUM;

			if (restricted && qeth_next_hop_is_local_v6(card, skb))
				features &= ~restricted;
			break;
		default:
			break;
		}
	}

7123 7124 7125 7126 7127 7128 7129 7130 7131 7132 7133 7134 7135 7136 7137 7138 7139 7140 7141 7142 7143 7144
	/* GSO segmentation builds skbs with
	 *	a (small) linear part for the headers, and
	 *	page frags for the data.
	 * Compared to a linear skb, the header-only part consumes an
	 * additional buffer element. This reduces buffer utilization, and
	 * hurts throughput. So compress small segments into one element.
	 */
	if (netif_needs_gso(skb, features)) {
		/* match skb_segment(): */
		unsigned int doffset = skb->data - skb_mac_header(skb);
		unsigned int hsize = skb_shinfo(skb)->gso_size;
		unsigned int hroom = skb_headroom(skb);

		/* linearize only if resulting skb allocations are order-0: */
		if (SKB_DATA_ALIGN(hroom + doffset + hsize) <= SKB_MAX_HEAD(0))
			features &= ~NETIF_F_SG;
	}

	return vlan_features_check(skb, features);
}
EXPORT_SYMBOL_GPL(qeth_features_check);

7145 7146 7147 7148 7149 7150 7151 7152 7153 7154
void qeth_get_stats64(struct net_device *dev, struct rtnl_link_stats64 *stats)
{
	struct qeth_card *card = dev->ml_priv;
	struct qeth_qdio_out_q *queue;
	unsigned int i;

	QETH_CARD_TEXT(card, 5, "getstat");

	stats->rx_packets = card->stats.rx_packets;
	stats->rx_bytes = card->stats.rx_bytes;
7155
	stats->rx_errors = card->stats.rx_length_errors +
7156
			   card->stats.rx_frame_errors +
7157 7158
			   card->stats.rx_fifo_errors;
	stats->rx_dropped = card->stats.rx_dropped_nomem +
7159 7160
			    card->stats.rx_dropped_notsupp +
			    card->stats.rx_dropped_runt;
7161
	stats->multicast = card->stats.rx_multicast;
7162
	stats->rx_length_errors = card->stats.rx_length_errors;
7163
	stats->rx_frame_errors = card->stats.rx_frame_errors;
7164
	stats->rx_fifo_errors = card->stats.rx_fifo_errors;
7165 7166 7167 7168 7169 7170 7171 7172 7173 7174 7175 7176

	for (i = 0; i < card->qdio.no_out_queues; i++) {
		queue = card->qdio.out_qs[i];

		stats->tx_packets += queue->stats.tx_packets;
		stats->tx_bytes += queue->stats.tx_bytes;
		stats->tx_errors += queue->stats.tx_errors;
		stats->tx_dropped += queue->stats.tx_dropped;
	}
}
EXPORT_SYMBOL_GPL(qeth_get_stats64);

7177 7178 7179 7180 7181 7182 7183 7184 7185 7186 7187 7188 7189 7190 7191 7192 7193 7194 7195 7196 7197 7198 7199 7200 7201 7202 7203 7204 7205 7206 7207 7208 7209 7210 7211 7212 7213 7214 7215 7216
#define TC_IQD_UCAST   0
static void qeth_iqd_set_prio_tc_map(struct net_device *dev,
				     unsigned int ucast_txqs)
{
	unsigned int prio;

	/* IQD requires mcast traffic to be placed on a dedicated queue, and
	 * qeth_iqd_select_queue() deals with this.
	 * For unicast traffic, we defer the queue selection to the stack.
	 * By installing a trivial prio map that spans over only the unicast
	 * queues, we can encourage the stack to spread the ucast traffic evenly
	 * without selecting the mcast queue.
	 */

	/* One traffic class, spanning over all active ucast queues: */
	netdev_set_num_tc(dev, 1);
	netdev_set_tc_queue(dev, TC_IQD_UCAST, ucast_txqs,
			    QETH_IQD_MIN_UCAST_TXQ);

	/* Map all priorities to this traffic class: */
	for (prio = 0; prio <= TC_BITMASK; prio++)
		netdev_set_prio_tc_map(dev, prio, TC_IQD_UCAST);
}

int qeth_set_real_num_tx_queues(struct qeth_card *card, unsigned int count)
{
	struct net_device *dev = card->dev;
	int rc;

	/* Per netif_setup_tc(), adjust the mapping first: */
	if (IS_IQD(card))
		qeth_iqd_set_prio_tc_map(dev, count - 1);

	rc = netif_set_real_num_tx_queues(dev, count);

	if (rc && IS_IQD(card))
		qeth_iqd_set_prio_tc_map(dev, dev->real_num_tx_queues - 1);

	return rc;
}
7217
EXPORT_SYMBOL_GPL(qeth_set_real_num_tx_queues);
7218

7219 7220 7221
u16 qeth_iqd_select_queue(struct net_device *dev, struct sk_buff *skb,
			  u8 cast_type, struct net_device *sb_dev)
{
7222 7223
	u16 txq;

7224 7225
	if (cast_type != RTN_UNICAST)
		return QETH_IQD_MCAST_TXQ;
7226 7227
	if (dev->real_num_tx_queues == QETH_IQD_MIN_TXQ)
		return QETH_IQD_MIN_UCAST_TXQ;
7228 7229 7230

	txq = netdev_pick_tx(dev, skb, sb_dev);
	return (txq == QETH_IQD_MCAST_TXQ) ? QETH_IQD_MIN_UCAST_TXQ : txq;
7231 7232 7233
}
EXPORT_SYMBOL_GPL(qeth_iqd_select_queue);

7234
int qeth_open(struct net_device *dev)
7235 7236 7237 7238 7239 7240
{
	struct qeth_card *card = dev->ml_priv;

	QETH_CARD_TEXT(card, 4, "qethopen");

	card->data.state = CH_STATE_UP;
7241
	netif_tx_start_all_queues(dev);
7242 7243

	local_bh_disable();
7244 7245 7246 7247 7248 7249 7250 7251 7252 7253 7254
	if (IS_IQD(card)) {
		struct qeth_qdio_out_q *queue;
		unsigned int i;

		qeth_for_each_output_queue(card, queue, i) {
			netif_tx_napi_add(dev, &queue->napi, qeth_tx_poll,
					  QETH_NAPI_WEIGHT);
			napi_enable(&queue->napi);
			napi_schedule(&queue->napi);
		}
	}
7255 7256 7257

	napi_enable(&card->napi);
	napi_schedule(&card->napi);
7258 7259
	/* kick-start the NAPI softirq: */
	local_bh_enable();
7260

7261 7262 7263 7264 7265 7266 7267 7268 7269
	return 0;
}
EXPORT_SYMBOL_GPL(qeth_open);

int qeth_stop(struct net_device *dev)
{
	struct qeth_card *card = dev->ml_priv;

	QETH_CARD_TEXT(card, 4, "qethstop");
7270 7271 7272 7273 7274

	napi_disable(&card->napi);
	cancel_delayed_work_sync(&card->buffer_reclaim_work);
	qdio_stop_irq(CARD_DDEV(card));

7275 7276 7277 7278 7279
	if (IS_IQD(card)) {
		struct qeth_qdio_out_q *queue;
		unsigned int i;

		/* Quiesce the NAPI instances: */
7280
		qeth_for_each_output_queue(card, queue, i)
7281 7282 7283 7284 7285
			napi_disable(&queue->napi);

		/* Stop .ndo_start_xmit, might still access queue->napi. */
		netif_tx_disable(dev);

7286 7287 7288
		qeth_for_each_output_queue(card, queue, i) {
			del_timer_sync(&queue->timer);
			/* Queues may get re-allocated, so remove the NAPIs. */
7289
			netif_napi_del(&queue->napi);
7290
		}
7291 7292 7293 7294
	} else {
		netif_tx_disable(dev);
	}

7295 7296 7297 7298
	return 0;
}
EXPORT_SYMBOL_GPL(qeth_stop);

F
Frank Blaschka 已提交
7299 7300 7301 7302
static int __init qeth_core_init(void)
{
	int rc;

7303
	pr_info("loading core functions\n");
F
Frank Blaschka 已提交
7304

7305 7306
	qeth_debugfs_root = debugfs_create_dir("qeth", NULL);

F
Frank Blaschka 已提交
7307 7308
	rc = qeth_register_dbf_views();
	if (rc)
7309
		goto dbf_err;
M
Mark McLoughlin 已提交
7310
	qeth_core_root_dev = root_device_register("qeth");
7311
	rc = PTR_ERR_OR_ZERO(qeth_core_root_dev);
F
Frank Blaschka 已提交
7312 7313
	if (rc)
		goto register_err;
7314 7315 7316 7317
	qeth_core_header_cache =
		kmem_cache_create("qeth_hdr", QETH_HDR_CACHE_OBJ_SIZE,
				  roundup_pow_of_two(QETH_HDR_CACHE_OBJ_SIZE),
				  0, NULL);
7318 7319 7320 7321
	if (!qeth_core_header_cache) {
		rc = -ENOMEM;
		goto slab_err;
	}
7322 7323 7324 7325 7326 7327
	qeth_qdio_outbuf_cache = kmem_cache_create("qeth_buf",
			sizeof(struct qeth_qdio_out_buffer), 0, 0, NULL);
	if (!qeth_qdio_outbuf_cache) {
		rc = -ENOMEM;
		goto cqslab_err;
	}
7328 7329 7330 7331 7332 7333
	rc = ccw_driver_register(&qeth_ccw_driver);
	if (rc)
		goto ccw_err;
	rc = ccwgroup_driver_register(&qeth_core_ccwgroup_driver);
	if (rc)
		goto ccwgroup_err;
7334

7335
	return 0;
7336 7337 7338 7339 7340

ccwgroup_err:
	ccw_driver_unregister(&qeth_ccw_driver);
ccw_err:
	kmem_cache_destroy(qeth_qdio_outbuf_cache);
7341 7342
cqslab_err:
	kmem_cache_destroy(qeth_core_header_cache);
7343
slab_err:
M
Mark McLoughlin 已提交
7344
	root_device_unregister(qeth_core_root_dev);
F
Frank Blaschka 已提交
7345 7346
register_err:
	qeth_unregister_dbf_views();
7347
dbf_err:
7348
	debugfs_remove_recursive(qeth_debugfs_root);
7349
	pr_err("Initializing the qeth device driver failed\n");
F
Frank Blaschka 已提交
7350 7351 7352 7353 7354
	return rc;
}

static void __exit qeth_core_exit(void)
{
7355
	qeth_clear_dbf_list();
F
Frank Blaschka 已提交
7356 7357
	ccwgroup_driver_unregister(&qeth_core_ccwgroup_driver);
	ccw_driver_unregister(&qeth_ccw_driver);
7358
	kmem_cache_destroy(qeth_qdio_outbuf_cache);
7359
	kmem_cache_destroy(qeth_core_header_cache);
7360
	root_device_unregister(qeth_core_root_dev);
F
Frank Blaschka 已提交
7361
	qeth_unregister_dbf_views();
7362
	debugfs_remove_recursive(qeth_debugfs_root);
7363
	pr_info("core functions removed\n");
F
Frank Blaschka 已提交
7364 7365 7366 7367 7368 7369 7370
}

module_init(qeth_core_init);
module_exit(qeth_core_exit);
MODULE_AUTHOR("Frank Blaschka <frank.blaschka@de.ibm.com>");
MODULE_DESCRIPTION("qeth core functions");
MODULE_LICENSE("GPL");