msi.c 29.5 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4 5 6 7 8
/*
 * File:	msi.c
 * Purpose:	PCI Message Signaled Interrupt (MSI)
 *
 * Copyright (C) 2003-2004 Intel
 * Copyright (C) Tom Long Nguyen (tom.l.nguyen@intel.com)
 */

9
#include <linux/err.h>
L
Linus Torvalds 已提交
10 11 12
#include <linux/mm.h>
#include <linux/irq.h>
#include <linux/interrupt.h>
13
#include <linux/export.h>
L
Linus Torvalds 已提交
14 15 16
#include <linux/ioport.h>
#include <linux/pci.h>
#include <linux/proc_fs.h>
17
#include <linux/msi.h>
D
Dan Williams 已提交
18
#include <linux/smp.h>
H
Hidetoshi Seto 已提交
19 20
#include <linux/errno.h>
#include <linux/io.h>
21
#include <linux/slab.h>
L
Linus Torvalds 已提交
22 23 24 25 26

#include "pci.h"

static int pci_msi_enable = 1;

27 28 29
#define msix_table_size(flags)	((flags & PCI_MSIX_FLAGS_QSIZE) + 1)


30 31
/* Arch hooks */

32 33
int __weak arch_setup_msi_irq(struct pci_dev *dev, struct msi_desc *desc)
{
34 35 36 37 38 39 40 41 42 43 44 45 46
	struct msi_chip *chip = dev->bus->msi;
	int err;

	if (!chip || !chip->setup_irq)
		return -EINVAL;

	err = chip->setup_irq(chip, dev, desc);
	if (err < 0)
		return err;

	irq_set_chip_data(desc->irq, chip);

	return 0;
47 48 49
}

void __weak arch_teardown_msi_irq(unsigned int irq)
50
{
51 52 53 54 55 56
	struct msi_chip *chip = irq_get_chip_data(irq);

	if (!chip || !chip->teardown_irq)
		return;

	chip->teardown_irq(chip, irq);
57 58
}

59 60
int __weak arch_msi_check_device(struct pci_dev *dev, int nvec, int type)
{
61 62 63 64 65 66
	struct msi_chip *chip = dev->bus->msi;

	if (!chip || !chip->check_device)
		return 0;

	return chip->check_device(chip, dev, nvec, type);
67
}
68

69
int __weak arch_setup_msi_irqs(struct pci_dev *dev, int nvec, int type)
70 71 72 73
{
	struct msi_desc *entry;
	int ret;

74 75 76 77 78 79 80
	/*
	 * If an architecture wants to support multiple MSI, it needs to
	 * override arch_setup_msi_irqs()
	 */
	if (type == PCI_CAP_ID_MSI && nvec > 1)
		return 1;

81 82
	list_for_each_entry(entry, &dev->msi_list, list) {
		ret = arch_setup_msi_irq(dev, entry);
83
		if (ret < 0)
84
			return ret;
85 86
		if (ret > 0)
			return -ENOSPC;
87 88 89 90
	}

	return 0;
}
91

92 93 94 95
/*
 * We have a default implementation available as a separate non-weak
 * function, as it is used by the Xen x86 PCI code
 */
96
void default_teardown_msi_irqs(struct pci_dev *dev)
97 98 99 100
{
	struct msi_desc *entry;

	list_for_each_entry(entry, &dev->msi_list, list) {
101 102 103
		int i, nvec;
		if (entry->irq == 0)
			continue;
104 105 106 107
		if (entry->nvec_used)
			nvec = entry->nvec_used;
		else
			nvec = 1 << entry->msi_attrib.multiple;
108 109
		for (i = 0; i < nvec; i++)
			arch_teardown_msi_irq(entry->irq + i);
110 111 112
	}
}

113 114 115 116
void __weak arch_teardown_msi_irqs(struct pci_dev *dev)
{
	return default_teardown_msi_irqs(dev);
}
117

118
static void default_restore_msi_irq(struct pci_dev *dev, int irq)
119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134
{
	struct msi_desc *entry;

	entry = NULL;
	if (dev->msix_enabled) {
		list_for_each_entry(entry, &dev->msi_list, list) {
			if (irq == entry->irq)
				break;
		}
	} else if (dev->msi_enabled)  {
		entry = irq_get_msi_desc(irq);
	}

	if (entry)
		write_msi_msg(irq, &entry->msg);
}
135

136
void __weak arch_restore_msi_irqs(struct pci_dev *dev)
137
{
138
	return default_restore_msi_irqs(dev);
139
}
140

141
static void msi_set_enable(struct pci_dev *dev, int enable)
142 143 144
{
	u16 control;

145
	pci_read_config_word(dev, dev->msi_cap + PCI_MSI_FLAGS, &control);
146 147 148
	control &= ~PCI_MSI_FLAGS_ENABLE;
	if (enable)
		control |= PCI_MSI_FLAGS_ENABLE;
149
	pci_write_config_word(dev, dev->msi_cap + PCI_MSI_FLAGS, control);
150 151
}

152 153 154 155
static void msix_set_enable(struct pci_dev *dev, int enable)
{
	u16 control;

156 157 158 159 160
	pci_read_config_word(dev, dev->msix_cap + PCI_MSIX_FLAGS, &control);
	control &= ~PCI_MSIX_FLAGS_ENABLE;
	if (enable)
		control |= PCI_MSIX_FLAGS_ENABLE;
	pci_write_config_word(dev, dev->msix_cap + PCI_MSIX_FLAGS, control);
161 162
}

163 164
static inline __attribute_const__ u32 msi_mask(unsigned x)
{
165 166 167 168
	/* Don't shift by >= width of type */
	if (x >= 5)
		return 0xffffffff;
	return (1 << (1 << x)) - 1;
169 170
}

171
static inline __attribute_const__ u32 msi_capable_mask(u16 control)
M
Mitch Williams 已提交
172
{
173 174
	return msi_mask((control >> 1) & 7);
}
M
Mitch Williams 已提交
175

176 177 178
static inline __attribute_const__ u32 msi_enabled_mask(u16 control)
{
	return msi_mask((control >> 4) & 7);
M
Mitch Williams 已提交
179 180
}

181 182 183 184 185 186
/*
 * PCI 2.3 does not specify mask bits for each MSI interrupt.  Attempting to
 * mask all MSI interrupts by clearing the MSI enable bit does not work
 * reliably as devices without an INTx disable bit will then generate a
 * level IRQ which will never be cleared.
 */
187
u32 default_msi_mask_irq(struct msi_desc *desc, u32 mask, u32 flag)
L
Linus Torvalds 已提交
188
{
189
	u32 mask_bits = desc->masked;
L
Linus Torvalds 已提交
190

191
	if (!desc->msi_attrib.maskbit)
192
		return 0;
193 194 195 196

	mask_bits &= ~mask;
	mask_bits |= flag;
	pci_write_config_dword(desc->dev, desc->mask_pos, mask_bits);
197 198 199 200

	return mask_bits;
}

201 202 203 204 205
__weak u32 arch_msi_mask_irq(struct msi_desc *desc, u32 mask, u32 flag)
{
	return default_msi_mask_irq(desc, mask, flag);
}

206 207
static void msi_mask_irq(struct msi_desc *desc, u32 mask, u32 flag)
{
208
	desc->masked = arch_msi_mask_irq(desc, mask, flag);
209 210 211 212 213 214 215 216 217
}

/*
 * This internal function does not flush PCI writes to the device.
 * All users must ensure that they read from the device before either
 * assuming that the device state is up to date, or returning out of this
 * file.  This saves a few milliseconds when initialising devices with lots
 * of MSI-X interrupts.
 */
218
u32 default_msix_mask_irq(struct msi_desc *desc, u32 flag)
219 220 221
{
	u32 mask_bits = desc->masked;
	unsigned offset = desc->msi_attrib.entry_nr * PCI_MSIX_ENTRY_SIZE +
222
						PCI_MSIX_ENTRY_VECTOR_CTRL;
223 224 225
	mask_bits &= ~PCI_MSIX_ENTRY_CTRL_MASKBIT;
	if (flag)
		mask_bits |= PCI_MSIX_ENTRY_CTRL_MASKBIT;
226
	writel(mask_bits, desc->mask_base + offset);
227 228 229 230

	return mask_bits;
}

231 232 233 234 235
__weak u32 arch_msix_mask_irq(struct msi_desc *desc, u32 flag)
{
	return default_msix_mask_irq(desc, flag);
}

236 237
static void msix_mask_irq(struct msi_desc *desc, u32 flag)
{
238
	desc->masked = arch_msix_mask_irq(desc, flag);
239
}
240

241
static void msi_set_mask_bit(struct irq_data *data, u32 flag)
242
{
243
	struct msi_desc *desc = irq_data_get_msi(data);
244

245 246 247 248
	if (desc->msi_attrib.is_msix) {
		msix_mask_irq(desc, flag);
		readl(desc->mask_base);		/* Flush write to device */
	} else {
249
		unsigned offset = data->irq - desc->dev->irq;
250
		msi_mask_irq(desc, 1 << offset, flag << offset);
L
Linus Torvalds 已提交
251
	}
252 253
}

254
void mask_msi_irq(struct irq_data *data)
255
{
256
	msi_set_mask_bit(data, 1);
257 258
}

259
void unmask_msi_irq(struct irq_data *data)
260
{
261
	msi_set_mask_bit(data, 0);
L
Linus Torvalds 已提交
262 263
}

264 265 266 267 268 269 270 271 272
void default_restore_msi_irqs(struct pci_dev *dev)
{
	struct msi_desc *entry;

	list_for_each_entry(entry, &dev->msi_list, list) {
		default_restore_msi_irq(dev, entry->irq);
	}
}

273
void __read_msi_msg(struct msi_desc *entry, struct msi_msg *msg)
L
Linus Torvalds 已提交
274
{
275 276 277 278 279 280 281 282 283 284 285
	BUG_ON(entry->dev->current_state != PCI_D0);

	if (entry->msi_attrib.is_msix) {
		void __iomem *base = entry->mask_base +
			entry->msi_attrib.entry_nr * PCI_MSIX_ENTRY_SIZE;

		msg->address_lo = readl(base + PCI_MSIX_ENTRY_LOWER_ADDR);
		msg->address_hi = readl(base + PCI_MSIX_ENTRY_UPPER_ADDR);
		msg->data = readl(base + PCI_MSIX_ENTRY_DATA);
	} else {
		struct pci_dev *dev = entry->dev;
286
		int pos = dev->msi_cap;
287 288
		u16 data;

289 290
		pci_read_config_dword(dev, pos + PCI_MSI_ADDRESS_LO,
				      &msg->address_lo);
291
		if (entry->msi_attrib.is_64) {
292 293
			pci_read_config_dword(dev, pos + PCI_MSI_ADDRESS_HI,
					      &msg->address_hi);
B
Bjorn Helgaas 已提交
294
			pci_read_config_word(dev, pos + PCI_MSI_DATA_64, &data);
295 296
		} else {
			msg->address_hi = 0;
B
Bjorn Helgaas 已提交
297
			pci_read_config_word(dev, pos + PCI_MSI_DATA_32, &data);
298 299 300 301 302 303 304
		}
		msg->data = data;
	}
}

void read_msi_msg(unsigned int irq, struct msi_msg *msg)
{
305
	struct msi_desc *entry = irq_get_msi_desc(irq);
306

307
	__read_msi_msg(entry, msg);
308 309
}

310
void __get_cached_msi_msg(struct msi_desc *entry, struct msi_msg *msg)
311 312
{
	/* Assert that the cache is valid, assuming that
313 314 315
	 * valid messages are not all-zeroes. */
	BUG_ON(!(entry->msg.address_hi | entry->msg.address_lo |
		 entry->msg.data));
316

317
	*msg = entry->msg;
318
}
L
Linus Torvalds 已提交
319

320
void get_cached_msi_msg(unsigned int irq, struct msi_msg *msg)
321
{
322
	struct msi_desc *entry = irq_get_msi_desc(irq);
Y
Yinghai Lu 已提交
323

324
	__get_cached_msi_msg(entry, msg);
Y
Yinghai Lu 已提交
325 326
}

327
void __write_msi_msg(struct msi_desc *entry, struct msi_msg *msg)
Y
Yinghai Lu 已提交
328
{
329 330 331
	if (entry->dev->current_state != PCI_D0) {
		/* Don't touch the hardware now */
	} else if (entry->msi_attrib.is_msix) {
332 333 334 335
		void __iomem *base;
		base = entry->mask_base +
			entry->msi_attrib.entry_nr * PCI_MSIX_ENTRY_SIZE;

336 337 338
		writel(msg->address_lo, base + PCI_MSIX_ENTRY_LOWER_ADDR);
		writel(msg->address_hi, base + PCI_MSIX_ENTRY_UPPER_ADDR);
		writel(msg->data, base + PCI_MSIX_ENTRY_DATA);
339
	} else {
340
		struct pci_dev *dev = entry->dev;
341
		int pos = dev->msi_cap;
342 343
		u16 msgctl;

344
		pci_read_config_word(dev, pos + PCI_MSI_FLAGS, &msgctl);
345 346
		msgctl &= ~PCI_MSI_FLAGS_QSIZE;
		msgctl |= entry->msi_attrib.multiple << 4;
347
		pci_write_config_word(dev, pos + PCI_MSI_FLAGS, msgctl);
348

349 350
		pci_write_config_dword(dev, pos + PCI_MSI_ADDRESS_LO,
				       msg->address_lo);
351
		if (entry->msi_attrib.is_64) {
352 353
			pci_write_config_dword(dev, pos + PCI_MSI_ADDRESS_HI,
					       msg->address_hi);
B
Bjorn Helgaas 已提交
354 355
			pci_write_config_word(dev, pos + PCI_MSI_DATA_64,
					      msg->data);
356
		} else {
B
Bjorn Helgaas 已提交
357 358
			pci_write_config_word(dev, pos + PCI_MSI_DATA_32,
					      msg->data);
359
		}
L
Linus Torvalds 已提交
360
	}
361
	entry->msg = *msg;
L
Linus Torvalds 已提交
362
}
363

Y
Yinghai Lu 已提交
364 365
void write_msi_msg(unsigned int irq, struct msi_msg *msg)
{
366
	struct msi_desc *entry = irq_get_msi_desc(irq);
Y
Yinghai Lu 已提交
367

368
	__write_msi_msg(entry, msg);
Y
Yinghai Lu 已提交
369 370
}

371 372 373
static void free_msi_irqs(struct pci_dev *dev)
{
	struct msi_desc *entry, *tmp;
374 375 376
	struct attribute **msi_attrs;
	struct device_attribute *dev_attr;
	int count = 0;
377 378 379 380 381

	list_for_each_entry(entry, &dev->msi_list, list) {
		int i, nvec;
		if (!entry->irq)
			continue;
382 383 384 385
		if (entry->nvec_used)
			nvec = entry->nvec_used;
		else
			nvec = 1 << entry->msi_attrib.multiple;
386 387 388 389 390 391 392 393 394 395 396
		for (i = 0; i < nvec; i++)
			BUG_ON(irq_has_action(entry->irq + i));
	}

	arch_teardown_msi_irqs(dev);

	list_for_each_entry_safe(entry, tmp, &dev->msi_list, list) {
		if (entry->msi_attrib.is_msix) {
			if (list_is_last(&entry->list, &dev->msi_list))
				iounmap(entry->mask_base);
		}
397 398 399 400 401 402 403 404 405 406 407 408

		/*
		 * Its possible that we get into this path
		 * When populate_msi_sysfs fails, which means the entries
		 * were not registered with sysfs.  In that case don't
		 * unregister them.
		 */
		if (entry->kobj.parent) {
			kobject_del(&entry->kobj);
			kobject_put(&entry->kobj);
		}

409 410 411
		list_del(&entry->list);
		kfree(entry);
	}
412 413 414 415

	if (dev->msi_irq_groups) {
		sysfs_remove_groups(&dev->dev.kobj, dev->msi_irq_groups);
		msi_attrs = dev->msi_irq_groups[0]->attrs;
416
		while (msi_attrs[count]) {
417 418 419 420 421 422 423 424 425 426 427
			dev_attr = container_of(msi_attrs[count],
						struct device_attribute, attr);
			kfree(dev_attr->attr.name);
			kfree(dev_attr);
			++count;
		}
		kfree(msi_attrs);
		kfree(dev->msi_irq_groups[0]);
		kfree(dev->msi_irq_groups);
		dev->msi_irq_groups = NULL;
	}
428
}
S
Satoru Takeuchi 已提交
429

430
static struct msi_desc *alloc_msi_entry(struct pci_dev *dev)
L
Linus Torvalds 已提交
431
{
432 433
	struct msi_desc *desc = kzalloc(sizeof(*desc), GFP_KERNEL);
	if (!desc)
L
Linus Torvalds 已提交
434 435
		return NULL;

436 437
	INIT_LIST_HEAD(&desc->list);
	desc->dev = dev;
L
Linus Torvalds 已提交
438

439
	return desc;
L
Linus Torvalds 已提交
440 441
}

442 443 444 445 446 447
static void pci_intx_for_msi(struct pci_dev *dev, int enable)
{
	if (!(dev->dev_flags & PCI_DEV_FLAGS_MSI_INTX_DISABLE_BUG))
		pci_intx(dev, enable);
}

448
static void __pci_restore_msi_state(struct pci_dev *dev)
449 450
{
	u16 control;
451
	struct msi_desc *entry;
452

453 454 455
	if (!dev->msi_enabled)
		return;

456
	entry = irq_get_msi_desc(dev->irq);
457

458
	pci_intx_for_msi(dev, 0);
459
	msi_set_enable(dev, 0);
460
	arch_restore_msi_irqs(dev);
461

462
	pci_read_config_word(dev, dev->msi_cap + PCI_MSI_FLAGS, &control);
463
	msi_mask_irq(entry, msi_capable_mask(control), entry->masked);
464
	control &= ~PCI_MSI_FLAGS_QSIZE;
465
	control |= (entry->msi_attrib.multiple << 4) | PCI_MSI_FLAGS_ENABLE;
466
	pci_write_config_word(dev, dev->msi_cap + PCI_MSI_FLAGS, control);
467 468 469
}

static void __pci_restore_msix_state(struct pci_dev *dev)
470 471
{
	struct msi_desc *entry;
472
	u16 control;
473

E
Eric W. Biederman 已提交
474 475
	if (!dev->msix_enabled)
		return;
476
	BUG_ON(list_empty(&dev->msi_list));
H
Hidetoshi Seto 已提交
477
	entry = list_first_entry(&dev->msi_list, struct msi_desc, list);
478
	pci_read_config_word(dev, dev->msix_cap + PCI_MSIX_FLAGS, &control);
E
Eric W. Biederman 已提交
479

480
	/* route the table */
481
	pci_intx_for_msi(dev, 0);
482
	control |= PCI_MSIX_FLAGS_ENABLE | PCI_MSIX_FLAGS_MASKALL;
483
	pci_write_config_word(dev, dev->msix_cap + PCI_MSIX_FLAGS, control);
484

485
	arch_restore_msi_irqs(dev);
486
	list_for_each_entry(entry, &dev->msi_list, list) {
487
		msix_mask_irq(entry, entry->masked);
488 489
	}

490
	control &= ~PCI_MSIX_FLAGS_MASKALL;
491
	pci_write_config_word(dev, dev->msix_cap + PCI_MSIX_FLAGS, control);
492
}
493 494 495 496 497 498

void pci_restore_msi_state(struct pci_dev *dev)
{
	__pci_restore_msi_state(dev);
	__pci_restore_msix_state(dev);
}
499
EXPORT_SYMBOL_GPL(pci_restore_msi_state);
500

501
static ssize_t msi_mode_show(struct device *dev, struct device_attribute *attr,
502 503
			     char *buf)
{
504 505 506 507
	struct pci_dev *pdev = to_pci_dev(dev);
	struct msi_desc *entry;
	unsigned long irq;
	int retval;
508

509 510 511
	retval = kstrtoul(attr->attr.name, 10, &irq);
	if (retval)
		return retval;
512

513 514 515 516 517 518 519
	list_for_each_entry(entry, &pdev->msi_list, list) {
		if (entry->irq == irq) {
			return sprintf(buf, "%s\n",
				       entry->msi_attrib.is_msix ? "msix" : "msi");
		}
	}
	return -ENODEV;
520 521 522 523
}

static int populate_msi_sysfs(struct pci_dev *pdev)
{
524 525 526 527 528
	struct attribute **msi_attrs;
	struct attribute *msi_attr;
	struct device_attribute *msi_dev_attr;
	struct attribute_group *msi_irq_group;
	const struct attribute_group **msi_irq_groups;
529
	struct msi_desc *entry;
530 531
	int ret = -ENOMEM;
	int num_msi = 0;
532 533
	int count = 0;

534 535 536 537 538 539
	/* Determine how many msi entries we have */
	list_for_each_entry(entry, &pdev->msi_list, list) {
		++num_msi;
	}
	if (!num_msi)
		return 0;
540

541 542 543 544
	/* Dynamically create the MSI attributes for the PCI device */
	msi_attrs = kzalloc(sizeof(void *) * (num_msi + 1), GFP_KERNEL);
	if (!msi_attrs)
		return -ENOMEM;
545
	list_for_each_entry(entry, &pdev->msi_list, list) {
546
		msi_dev_attr = kzalloc(sizeof(*msi_dev_attr), GFP_KERNEL);
547
		if (!msi_dev_attr)
548
			goto error_attrs;
549
		msi_attrs[count] = &msi_dev_attr->attr;
550

551
		sysfs_attr_init(&msi_dev_attr->attr);
552 553 554 555
		msi_dev_attr->attr.name = kasprintf(GFP_KERNEL, "%d",
						    entry->irq);
		if (!msi_dev_attr->attr.name)
			goto error_attrs;
556 557 558
		msi_dev_attr->attr.mode = S_IRUGO;
		msi_dev_attr->show = msi_mode_show;
		++count;
559 560
	}

561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576
	msi_irq_group = kzalloc(sizeof(*msi_irq_group), GFP_KERNEL);
	if (!msi_irq_group)
		goto error_attrs;
	msi_irq_group->name = "msi_irqs";
	msi_irq_group->attrs = msi_attrs;

	msi_irq_groups = kzalloc(sizeof(void *) * 2, GFP_KERNEL);
	if (!msi_irq_groups)
		goto error_irq_group;
	msi_irq_groups[0] = msi_irq_group;

	ret = sysfs_create_groups(&pdev->dev.kobj, msi_irq_groups);
	if (ret)
		goto error_irq_groups;
	pdev->msi_irq_groups = msi_irq_groups;

577 578
	return 0;

579 580 581 582 583 584 585 586 587 588 589 590 591
error_irq_groups:
	kfree(msi_irq_groups);
error_irq_group:
	kfree(msi_irq_group);
error_attrs:
	count = 0;
	msi_attr = msi_attrs[count];
	while (msi_attr) {
		msi_dev_attr = container_of(msi_attr, struct device_attribute, attr);
		kfree(msi_attr->name);
		kfree(msi_dev_attr);
		++count;
		msi_attr = msi_attrs[count];
592
	}
593
	kfree(msi_attrs);
594 595 596
	return ret;
}

L
Linus Torvalds 已提交
597 598 599
/**
 * msi_capability_init - configure device's MSI capability structure
 * @dev: pointer to the pci_dev data structure of MSI device function
600
 * @nvec: number of interrupts to allocate
L
Linus Torvalds 已提交
601
 *
602 603 604 605 606 607 608
 * Setup the MSI capability structure of the device with the requested
 * number of interrupts.  A return value of zero indicates the successful
 * setup of an entry with the new MSI irq.  A negative return value indicates
 * an error, and a positive return value indicates the number of interrupts
 * which could have been allocated.
 */
static int msi_capability_init(struct pci_dev *dev, int nvec)
L
Linus Torvalds 已提交
609 610
{
	struct msi_desc *entry;
611
	int ret;
L
Linus Torvalds 已提交
612
	u16 control;
613
	unsigned mask;
L
Linus Torvalds 已提交
614

615
	msi_set_enable(dev, 0);	/* Disable MSI during set up */
616

617
	pci_read_config_word(dev, dev->msi_cap + PCI_MSI_FLAGS, &control);
L
Linus Torvalds 已提交
618
	/* MSI Entry Initialization */
619
	entry = alloc_msi_entry(dev);
620 621
	if (!entry)
		return -ENOMEM;
622

H
Hidetoshi Seto 已提交
623
	entry->msi_attrib.is_msix	= 0;
624
	entry->msi_attrib.is_64		= !!(control & PCI_MSI_FLAGS_64BIT);
H
Hidetoshi Seto 已提交
625
	entry->msi_attrib.entry_nr	= 0;
626
	entry->msi_attrib.maskbit	= !!(control & PCI_MSI_FLAGS_MASKBIT);
H
Hidetoshi Seto 已提交
627
	entry->msi_attrib.default_irq	= dev->irq;	/* Save IOAPIC IRQ */
628
	entry->msi_attrib.pos		= dev->msi_cap;
629

D
Dan Carpenter 已提交
630 631 632 633
	if (control & PCI_MSI_FLAGS_64BIT)
		entry->mask_pos = dev->msi_cap + PCI_MSI_MASK_64;
	else
		entry->mask_pos = dev->msi_cap + PCI_MSI_MASK_32;
634 635 636 637 638 639
	/* All MSIs are unmasked by default, Mask them all */
	if (entry->msi_attrib.maskbit)
		pci_read_config_dword(dev, entry->mask_pos, &entry->masked);
	mask = msi_capable_mask(control);
	msi_mask_irq(entry, mask, mask);

640
	list_add_tail(&entry->list, &dev->msi_list);
641

L
Linus Torvalds 已提交
642
	/* Configure MSI capability structure */
643
	ret = arch_setup_msi_irqs(dev, nvec, PCI_CAP_ID_MSI);
644
	if (ret) {
645
		msi_mask_irq(entry, mask, ~mask);
646
		free_msi_irqs(dev);
647
		return ret;
648
	}
649

650 651 652 653 654 655 656
	ret = populate_msi_sysfs(dev);
	if (ret) {
		msi_mask_irq(entry, mask, ~mask);
		free_msi_irqs(dev);
		return ret;
	}

L
Linus Torvalds 已提交
657
	/* Set MSI enabled bits	 */
658
	pci_intx_for_msi(dev, 0);
659
	msi_set_enable(dev, 1);
660
	dev->msi_enabled = 1;
L
Linus Torvalds 已提交
661

662
	dev->irq = entry->irq;
L
Linus Torvalds 已提交
663 664 665
	return 0;
}

666
static void __iomem *msix_map_region(struct pci_dev *dev, unsigned nr_entries)
667
{
668
	resource_size_t phys_addr;
669 670 671
	u32 table_offset;
	u8 bir;

672 673
	pci_read_config_dword(dev, dev->msix_cap + PCI_MSIX_TABLE,
			      &table_offset);
674 675
	bir = (u8)(table_offset & PCI_MSIX_TABLE_BIR);
	table_offset &= PCI_MSIX_TABLE_OFFSET;
676 677 678 679 680
	phys_addr = pci_resource_start(dev, bir) + table_offset;

	return ioremap_nocache(phys_addr, nr_entries * PCI_MSIX_ENTRY_SIZE);
}

681 682
static int msix_setup_entries(struct pci_dev *dev, void __iomem *base,
			      struct msix_entry *entries, int nvec)
683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701
{
	struct msi_desc *entry;
	int i;

	for (i = 0; i < nvec; i++) {
		entry = alloc_msi_entry(dev);
		if (!entry) {
			if (!i)
				iounmap(base);
			else
				free_msi_irqs(dev);
			/* No enough memory. Don't try again */
			return -ENOMEM;
		}

		entry->msi_attrib.is_msix	= 1;
		entry->msi_attrib.is_64		= 1;
		entry->msi_attrib.entry_nr	= entries[i].entry;
		entry->msi_attrib.default_irq	= dev->irq;
702
		entry->msi_attrib.pos		= dev->msix_cap;
703 704 705 706 707 708 709 710
		entry->mask_base		= base;

		list_add_tail(&entry->list, &dev->msi_list);
	}

	return 0;
}

711
static void msix_program_entries(struct pci_dev *dev,
712
				 struct msix_entry *entries)
713 714 715 716 717 718 719 720 721
{
	struct msi_desc *entry;
	int i = 0;

	list_for_each_entry(entry, &dev->msi_list, list) {
		int offset = entries[i].entry * PCI_MSIX_ENTRY_SIZE +
						PCI_MSIX_ENTRY_VECTOR_CTRL;

		entries[i].vector = entry->irq;
722
		irq_set_msi_desc(entry->irq, entry);
723 724 725 726 727 728
		entry->masked = readl(entry->mask_base + offset);
		msix_mask_irq(entry, 1);
		i++;
	}
}

L
Linus Torvalds 已提交
729 730 731
/**
 * msix_capability_init - configure device's MSI-X capability
 * @dev: pointer to the pci_dev data structure of MSI-X device function
R
Randy Dunlap 已提交
732 733
 * @entries: pointer to an array of struct msix_entry entries
 * @nvec: number of @entries
L
Linus Torvalds 已提交
734
 *
735
 * Setup the MSI-X capability structure of device function with a
736 737
 * single MSI-X irq. A return of zero indicates the successful setup of
 * requested MSI-X entries with allocated irqs or non-zero for otherwise.
L
Linus Torvalds 已提交
738 739 740 741
 **/
static int msix_capability_init(struct pci_dev *dev,
				struct msix_entry *entries, int nvec)
{
742
	int ret;
743
	u16 control;
L
Linus Torvalds 已提交
744 745
	void __iomem *base;

746
	pci_read_config_word(dev, dev->msix_cap + PCI_MSIX_FLAGS, &control);
747 748 749

	/* Ensure MSI-X is disabled while it is set up */
	control &= ~PCI_MSIX_FLAGS_ENABLE;
750
	pci_write_config_word(dev, dev->msix_cap + PCI_MSIX_FLAGS, control);
751

L
Linus Torvalds 已提交
752
	/* Request & Map MSI-X table region */
753
	base = msix_map_region(dev, msix_table_size(control));
754
	if (!base)
L
Linus Torvalds 已提交
755 756
		return -ENOMEM;

757
	ret = msix_setup_entries(dev, base, entries, nvec);
758 759
	if (ret)
		return ret;
760 761

	ret = arch_setup_msi_irqs(dev, nvec, PCI_CAP_ID_MSIX);
762
	if (ret)
763
		goto out_avail;
764

765 766 767 768 769 770
	/*
	 * Some devices require MSI-X to be enabled before we can touch the
	 * MSI-X registers.  We need to mask all the vectors to prevent
	 * interrupts coming in before they're fully set up.
	 */
	control |= PCI_MSIX_FLAGS_MASKALL | PCI_MSIX_FLAGS_ENABLE;
771
	pci_write_config_word(dev, dev->msix_cap + PCI_MSIX_FLAGS, control);
772

773
	msix_program_entries(dev, entries);
774

775
	ret = populate_msi_sysfs(dev);
776 777
	if (ret)
		goto out_free;
778

779
	/* Set MSI-X enabled bits and unmask the function */
780
	pci_intx_for_msi(dev, 0);
781
	dev->msix_enabled = 1;
L
Linus Torvalds 已提交
782

783
	control &= ~PCI_MSIX_FLAGS_MASKALL;
784
	pci_write_config_word(dev, dev->msix_cap + PCI_MSIX_FLAGS, control);
785

L
Linus Torvalds 已提交
786
	return 0;
787

788
out_avail:
789 790 791 792 793
	if (ret < 0) {
		/*
		 * If we had some success, report the number of irqs
		 * we succeeded in setting up.
		 */
794
		struct msi_desc *entry;
795 796 797 798 799 800 801 802 803 804
		int avail = 0;

		list_for_each_entry(entry, &dev->msi_list, list) {
			if (entry->irq != 0)
				avail++;
		}
		if (avail != 0)
			ret = avail;
	}

805
out_free:
806 807 808
	free_msi_irqs(dev);

	return ret;
L
Linus Torvalds 已提交
809 810
}

811
/**
812
 * pci_msi_check_device - check whether MSI may be enabled on a device
813
 * @dev: pointer to the pci_dev data structure of MSI device function
814
 * @nvec: how many MSIs have been requested ?
815
 * @type: are we checking for MSI or MSI-X ?
816
 *
817
 * Look at global flags, the device itself, and its parent buses
818 819
 * to determine if MSI/-X are supported for the device. If MSI/-X is
 * supported return 0, else return an error code.
820
 **/
H
Hidetoshi Seto 已提交
821
static int pci_msi_check_device(struct pci_dev *dev, int nvec, int type)
822 823
{
	struct pci_bus *bus;
824
	int ret;
825

826
	/* MSI must be globally enabled and supported by the device */
827 828 829
	if (!pci_msi_enable || !dev || dev->no_msi)
		return -EINVAL;

830 831 832 833 834 835 836 837
	/*
	 * You can't ask to have 0 or less MSIs configured.
	 *  a) it's stupid ..
	 *  b) the list manipulation code assumes nvec >= 1.
	 */
	if (nvec < 1)
		return -ERANGE;

H
Hidetoshi Seto 已提交
838 839 840
	/*
	 * Any bridge which does NOT route MSI transactions from its
	 * secondary bus to its primary bus must set NO_MSI flag on
841 842 843 844
	 * the secondary pci_bus.
	 * We expect only arch-specific PCI host bus controller driver
	 * or quirks for specific PCI bridges to be setting NO_MSI.
	 */
845 846 847 848
	for (bus = dev->bus; bus; bus = bus->parent)
		if (bus->bus_flags & PCI_BUS_FLAGS_NO_MSI)
			return -EINVAL;

849 850 851 852
	ret = arch_msi_check_device(dev, nvec, type);
	if (ret)
		return ret;

853 854 855
	return 0;
}

856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880
/**
 * pci_msi_vec_count - Return the number of MSI vectors a device can send
 * @dev: device to report about
 *
 * This function returns the number of MSI vectors a device requested via
 * Multiple Message Capable register. It returns a negative errno if the
 * device is not capable sending MSI interrupts. Otherwise, the call succeeds
 * and returns a power of two, up to a maximum of 2^5 (32), according to the
 * MSI specification.
 **/
int pci_msi_vec_count(struct pci_dev *dev)
{
	int ret;
	u16 msgctl;

	if (!dev->msi_cap)
		return -EINVAL;

	pci_read_config_word(dev, dev->msi_cap + PCI_MSI_FLAGS, &msgctl);
	ret = 1 << ((msgctl & PCI_MSI_FLAGS_QMASK) >> 1);

	return ret;
}
EXPORT_SYMBOL(pci_msi_vec_count);

881
void pci_msi_shutdown(struct pci_dev *dev)
L
Linus Torvalds 已提交
882
{
883 884 885
	struct msi_desc *desc;
	u32 mask;
	u16 ctrl;
L
Linus Torvalds 已提交
886

887
	if (!pci_msi_enable || !dev || !dev->msi_enabled)
E
Eric W. Biederman 已提交
888 889
		return;

890 891 892
	BUG_ON(list_empty(&dev->msi_list));
	desc = list_first_entry(&dev->msi_list, struct msi_desc, list);

893
	msi_set_enable(dev, 0);
894
	pci_intx_for_msi(dev, 1);
895
	dev->msi_enabled = 0;
896

897
	/* Return the device with MSI unmasked as initial states */
898
	pci_read_config_word(dev, dev->msi_cap + PCI_MSI_FLAGS, &ctrl);
899
	mask = msi_capable_mask(ctrl);
900
	/* Keep cached state to be restored */
901
	arch_msi_mask_irq(desc, mask, ~mask);
902 903

	/* Restore dev->irq to its default pin-assertion irq */
904
	dev->irq = desc->msi_attrib.default_irq;
905
}
906

H
Hidetoshi Seto 已提交
907
void pci_disable_msi(struct pci_dev *dev)
908 909 910 911 912
{
	if (!pci_msi_enable || !dev || !dev->msi_enabled)
		return;

	pci_msi_shutdown(dev);
913
	free_msi_irqs(dev);
L
Linus Torvalds 已提交
914
}
915
EXPORT_SYMBOL(pci_disable_msi);
L
Linus Torvalds 已提交
916

917
/**
918
 * pci_msix_vec_count - return the number of device's MSI-X table entries
919
 * @dev: pointer to the pci_dev data structure of MSI-X device function
920 921 922 923 924 925
 * This function returns the number of device's MSI-X table entries and
 * therefore the number of MSI-X vectors device is capable of sending.
 * It returns a negative errno if the device is not capable of sending MSI-X
 * interrupts.
 **/
int pci_msix_vec_count(struct pci_dev *dev)
926 927 928
{
	u16 control;

929
	if (!dev->msix_cap)
930
		return -EINVAL;
931

932
	pci_read_config_word(dev, dev->msix_cap + PCI_MSIX_FLAGS, &control);
933
	return msix_table_size(control);
934
}
935
EXPORT_SYMBOL(pci_msix_vec_count);
936

L
Linus Torvalds 已提交
937 938 939
/**
 * pci_enable_msix - configure device's MSI-X capability structure
 * @dev: pointer to the pci_dev data structure of MSI-X device function
940
 * @entries: pointer to an array of MSI-X entries
941
 * @nvec: number of MSI-X irqs requested for allocation by device driver
L
Linus Torvalds 已提交
942 943
 *
 * Setup the MSI-X capability structure of device function with the number
944
 * of requested irqs upon its software driver call to request for
L
Linus Torvalds 已提交
945 946
 * MSI-X mode enabled on its hardware device function. A return of zero
 * indicates the successful configuration of MSI-X capability structure
947
 * with new allocated MSI-X irqs. A return of < 0 indicates a failure.
L
Linus Torvalds 已提交
948
 * Or a return of > 0 indicates that driver request is exceeding the number
949 950
 * of irqs or MSI-X vectors available. Driver should use the returned value to
 * re-send its request.
L
Linus Torvalds 已提交
951
 **/
H
Hidetoshi Seto 已提交
952
int pci_enable_msix(struct pci_dev *dev, struct msix_entry *entries, int nvec)
L
Linus Torvalds 已提交
953
{
954
	int status, nr_entries;
E
Eric W. Biederman 已提交
955
	int i, j;
L
Linus Torvalds 已提交
956

957
	if (!entries || !dev->msix_cap || dev->current_state != PCI_D0)
H
Hidetoshi Seto 已提交
958
		return -EINVAL;
L
Linus Torvalds 已提交
959

960 961 962 963
	status = pci_msi_check_device(dev, nvec, PCI_CAP_ID_MSIX);
	if (status)
		return status;

964 965 966
	nr_entries = pci_msix_vec_count(dev);
	if (nr_entries < 0)
		return nr_entries;
L
Linus Torvalds 已提交
967
	if (nvec > nr_entries)
968
		return nr_entries;
L
Linus Torvalds 已提交
969 970 971 972 973 974 975 976 977 978

	/* Check for any invalid entries */
	for (i = 0; i < nvec; i++) {
		if (entries[i].entry >= nr_entries)
			return -EINVAL;		/* invalid entry */
		for (j = i + 1; j < nvec; j++) {
			if (entries[i].entry == entries[j].entry)
				return -EINVAL;	/* duplicate entry */
		}
	}
E
Eric W. Biederman 已提交
979
	WARN_ON(!!dev->msix_enabled);
980

981
	/* Check whether driver already requested for MSI irq */
H
Hidetoshi Seto 已提交
982
	if (dev->msi_enabled) {
983
		dev_info(&dev->dev, "can't enable MSI-X (MSI IRQ already assigned)\n");
L
Linus Torvalds 已提交
984 985 986 987 988
		return -EINVAL;
	}
	status = msix_capability_init(dev, entries, nvec);
	return status;
}
989
EXPORT_SYMBOL(pci_enable_msix);
L
Linus Torvalds 已提交
990

H
Hidetoshi Seto 已提交
991
void pci_msix_shutdown(struct pci_dev *dev)
992
{
993 994
	struct msi_desc *entry;

995
	if (!pci_msi_enable || !dev || !dev->msix_enabled)
E
Eric W. Biederman 已提交
996 997
		return;

998 999 1000
	/* Return the device with MSI-X masked as initial states */
	list_for_each_entry(entry, &dev->msi_list, list) {
		/* Keep cached states to be restored */
1001
		arch_msix_mask_irq(entry, 1);
1002 1003
	}

1004
	msix_set_enable(dev, 0);
1005
	pci_intx_for_msi(dev, 1);
1006
	dev->msix_enabled = 0;
1007
}
1008

H
Hidetoshi Seto 已提交
1009
void pci_disable_msix(struct pci_dev *dev)
1010 1011 1012 1013 1014
{
	if (!pci_msi_enable || !dev || !dev->msix_enabled)
		return;

	pci_msix_shutdown(dev);
1015
	free_msi_irqs(dev);
L
Linus Torvalds 已提交
1016
}
1017
EXPORT_SYMBOL(pci_disable_msix);
L
Linus Torvalds 已提交
1018 1019

/**
1020
 * msi_remove_pci_irq_vectors - reclaim MSI(X) irqs to unused state
L
Linus Torvalds 已提交
1021 1022
 * @dev: pointer to the pci_dev data structure of MSI(X) device function
 *
1023
 * Being called during hotplug remove, from which the device function
1024
 * is hot-removed. All previous assigned MSI/MSI-X irqs, if
L
Linus Torvalds 已提交
1025 1026 1027
 * allocated for this device function, are reclaimed to unused state,
 * which may be used later on.
 **/
H
Hidetoshi Seto 已提交
1028
void msi_remove_pci_irq_vectors(struct pci_dev *dev)
L
Linus Torvalds 已提交
1029 1030
{
	if (!pci_msi_enable || !dev)
H
Hidetoshi Seto 已提交
1031
		return;
L
Linus Torvalds 已提交
1032

1033 1034
	if (dev->msi_enabled || dev->msix_enabled)
		free_msi_irqs(dev);
L
Linus Torvalds 已提交
1035 1036
}

1037 1038 1039 1040
void pci_no_msi(void)
{
	pci_msi_enable = 0;
}
1041

1042 1043 1044 1045 1046 1047 1048
/**
 * pci_msi_enabled - is MSI enabled?
 *
 * Returns true if MSI has not been disabled by the command-line option
 * pci=nomsi.
 **/
int pci_msi_enabled(void)
1049
{
1050
	return pci_msi_enable;
1051
}
1052
EXPORT_SYMBOL(pci_msi_enabled);
1053

1054
void pci_msi_init_pci_dev(struct pci_dev *dev)
1055
{
1056
	INIT_LIST_HEAD(&dev->msi_list);
1057 1058 1059 1060 1061

	/* Disable the msi hardware to avoid screaming interrupts
	 * during boot.  This is the power on reset default so
	 * usually this should be a noop.
	 */
1062 1063 1064 1065 1066 1067 1068
	dev->msi_cap = pci_find_capability(dev, PCI_CAP_ID_MSI);
	if (dev->msi_cap)
		msi_set_enable(dev, 0);

	dev->msix_cap = pci_find_capability(dev, PCI_CAP_ID_MSIX);
	if (dev->msix_cap)
		msix_set_enable(dev, 0);
1069
}
1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084

/**
 * pci_enable_msi_range - configure device's MSI capability structure
 * @dev: device to configure
 * @minvec: minimal number of interrupts to configure
 * @maxvec: maximum number of interrupts to configure
 *
 * This function tries to allocate a maximum possible number of interrupts in a
 * range between @minvec and @maxvec. It returns a negative errno if an error
 * occurs. If it succeeds, it returns the actual number of interrupts allocated
 * and updates the @dev's irq member to the lowest new interrupt number;
 * the other interrupt numbers allocated to this device are consecutive.
 **/
int pci_enable_msi_range(struct pci_dev *dev, int minvec, int maxvec)
{
1085
	int nvec;
1086 1087
	int rc;

1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099
	if (dev->current_state != PCI_D0)
		return -EINVAL;

	WARN_ON(!!dev->msi_enabled);

	/* Check whether driver already requested MSI-X irqs */
	if (dev->msix_enabled) {
		dev_info(&dev->dev,
			 "can't enable MSI (MSI-X already enabled)\n");
		return -EINVAL;
	}

1100 1101 1102
	if (maxvec < minvec)
		return -ERANGE;

1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120 1121
	nvec = pci_msi_vec_count(dev);
	if (nvec < 0)
		return nvec;
	else if (nvec < minvec)
		return -EINVAL;
	else if (nvec > maxvec)
		nvec = maxvec;

	do {
		rc = pci_msi_check_device(dev, nvec, PCI_CAP_ID_MSI);
		if (rc < 0) {
			return rc;
		} else if (rc > 0) {
			if (rc < minvec)
				return -ENOSPC;
			nvec = rc;
		}
	} while (rc);

1122
	do {
1123
		rc = msi_capability_init(dev, nvec);
1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173 1174
		if (rc < 0) {
			return rc;
		} else if (rc > 0) {
			if (rc < minvec)
				return -ENOSPC;
			nvec = rc;
		}
	} while (rc);

	return nvec;
}
EXPORT_SYMBOL(pci_enable_msi_range);

/**
 * pci_enable_msix_range - configure device's MSI-X capability structure
 * @dev: pointer to the pci_dev data structure of MSI-X device function
 * @entries: pointer to an array of MSI-X entries
 * @minvec: minimum number of MSI-X irqs requested
 * @maxvec: maximum number of MSI-X irqs requested
 *
 * Setup the MSI-X capability structure of device function with a maximum
 * possible number of interrupts in the range between @minvec and @maxvec
 * upon its software driver call to request for MSI-X mode enabled on its
 * hardware device function. It returns a negative errno if an error occurs.
 * If it succeeds, it returns the actual number of interrupts allocated and
 * indicates the successful configuration of MSI-X capability structure
 * with new allocated MSI-X interrupts.
 **/
int pci_enable_msix_range(struct pci_dev *dev, struct msix_entry *entries,
			       int minvec, int maxvec)
{
	int nvec = maxvec;
	int rc;

	if (maxvec < minvec)
		return -ERANGE;

	do {
		rc = pci_enable_msix(dev, entries, nvec);
		if (rc < 0) {
			return rc;
		} else if (rc > 0) {
			if (rc < minvec)
				return -ENOSPC;
			nvec = rc;
		}
	} while (rc);

	return nvec;
}
EXPORT_SYMBOL(pci_enable_msix_range);