diff options
Diffstat (limited to 'drivers/firewire')
-rw-r--r-- | drivers/firewire/core-transaction.c | 6 | ||||
-rw-r--r-- | drivers/firewire/core.h | 3 | ||||
-rw-r--r-- | drivers/firewire/ohci.c | 8 |
3 files changed, 11 insertions, 6 deletions
diff --git a/drivers/firewire/core-transaction.c b/drivers/firewire/core-transaction.c index 0e799516a2ab..eb6935c8ad94 100644 --- a/drivers/firewire/core-transaction.c +++ b/drivers/firewire/core-transaction.c | |||
@@ -523,11 +523,11 @@ static DEFINE_SPINLOCK(address_handler_list_lock); | |||
523 | static LIST_HEAD(address_handler_list); | 523 | static LIST_HEAD(address_handler_list); |
524 | 524 | ||
525 | const struct fw_address_region fw_high_memory_region = | 525 | const struct fw_address_region fw_high_memory_region = |
526 | { .start = 0x000100000000ULL, .end = 0xffffe0000000ULL, }; | 526 | { .start = FW_MAX_PHYSICAL_RANGE, .end = 0xffffe0000000ULL, }; |
527 | EXPORT_SYMBOL(fw_high_memory_region); | 527 | EXPORT_SYMBOL(fw_high_memory_region); |
528 | 528 | ||
529 | static const struct fw_address_region low_memory_region = | 529 | static const struct fw_address_region low_memory_region = |
530 | { .start = 0x000000000000ULL, .end = 0x000100000000ULL, }; | 530 | { .start = 0x000000000000ULL, .end = FW_MAX_PHYSICAL_RANGE, }; |
531 | 531 | ||
532 | #if 0 | 532 | #if 0 |
533 | const struct fw_address_region fw_private_region = | 533 | const struct fw_address_region fw_private_region = |
@@ -1217,7 +1217,7 @@ static void handle_low_memory(struct fw_card *card, struct fw_request *request, | |||
1217 | } | 1217 | } |
1218 | 1218 | ||
1219 | static struct fw_address_handler low_memory = { | 1219 | static struct fw_address_handler low_memory = { |
1220 | .length = 0x000100000000ULL, | 1220 | .length = FW_MAX_PHYSICAL_RANGE, |
1221 | .address_callback = handle_low_memory, | 1221 | .address_callback = handle_low_memory, |
1222 | }; | 1222 | }; |
1223 | 1223 | ||
diff --git a/drivers/firewire/core.h b/drivers/firewire/core.h index 515a42c786d0..c98764aeeec6 100644 --- a/drivers/firewire/core.h +++ b/drivers/firewire/core.h | |||
@@ -237,6 +237,9 @@ static inline bool is_next_generation(int new_generation, int old_generation) | |||
237 | 237 | ||
238 | #define LOCAL_BUS 0xffc0 | 238 | #define LOCAL_BUS 0xffc0 |
239 | 239 | ||
240 | /* arbitrarily chosen maximum range for physical DMA: 128 TB */ | ||
241 | #define FW_MAX_PHYSICAL_RANGE (128ULL << 40) | ||
242 | |||
240 | void fw_core_handle_request(struct fw_card *card, struct fw_packet *request); | 243 | void fw_core_handle_request(struct fw_card *card, struct fw_packet *request); |
241 | void fw_core_handle_response(struct fw_card *card, struct fw_packet *packet); | 244 | void fw_core_handle_response(struct fw_card *card, struct fw_packet *packet); |
242 | int fw_get_response_length(struct fw_request *request); | 245 | int fw_get_response_length(struct fw_request *request); |
diff --git a/drivers/firewire/ohci.c b/drivers/firewire/ohci.c index 036fb3bd5659..6f74d8d3f700 100644 --- a/drivers/firewire/ohci.c +++ b/drivers/firewire/ohci.c | |||
@@ -2367,7 +2367,7 @@ static int ohci_enable(struct fw_card *card, | |||
2367 | reg_write(ohci, OHCI1394_FairnessControl, 0); | 2367 | reg_write(ohci, OHCI1394_FairnessControl, 0); |
2368 | card->priority_budget_implemented = ohci->pri_req_max != 0; | 2368 | card->priority_budget_implemented = ohci->pri_req_max != 0; |
2369 | 2369 | ||
2370 | reg_write(ohci, OHCI1394_PhyUpperBound, 0x00010000); | 2370 | reg_write(ohci, OHCI1394_PhyUpperBound, FW_MAX_PHYSICAL_RANGE >> 16); |
2371 | reg_write(ohci, OHCI1394_IntEventClear, ~0); | 2371 | reg_write(ohci, OHCI1394_IntEventClear, ~0); |
2372 | reg_write(ohci, OHCI1394_IntMaskClear, ~0); | 2372 | reg_write(ohci, OHCI1394_IntMaskClear, ~0); |
2373 | 2373 | ||
@@ -3723,9 +3723,11 @@ static int pci_probe(struct pci_dev *dev, | |||
3723 | version = reg_read(ohci, OHCI1394_Version) & 0x00ff00ff; | 3723 | version = reg_read(ohci, OHCI1394_Version) & 0x00ff00ff; |
3724 | ohci_notice(ohci, | 3724 | ohci_notice(ohci, |
3725 | "added OHCI v%x.%x device as card %d, " | 3725 | "added OHCI v%x.%x device as card %d, " |
3726 | "%d IR + %d IT contexts, quirks 0x%x\n", | 3726 | "%d IR + %d IT contexts, quirks 0x%x%s\n", |
3727 | version >> 16, version & 0xff, ohci->card.index, | 3727 | version >> 16, version & 0xff, ohci->card.index, |
3728 | ohci->n_ir, ohci->n_it, ohci->quirks); | 3728 | ohci->n_ir, ohci->n_it, ohci->quirks, |
3729 | reg_read(ohci, OHCI1394_PhyUpperBound) ? | ||
3730 | ", >4 GB phys DMA" : ""); | ||
3729 | 3731 | ||
3730 | return 0; | 3732 | return 0; |
3731 | 3733 | ||