diff options
| -rw-r--r-- | arch/x86/include/asm/uv/uv_bau.h | 9 | ||||
| -rw-r--r-- | arch/x86/platform/uv/tlb_uv.c | 22 |
2 files changed, 23 insertions, 8 deletions
diff --git a/arch/x86/include/asm/uv/uv_bau.h b/arch/x86/include/asm/uv/uv_bau.h index 42d412fd8b02..ce1d54c8a433 100644 --- a/arch/x86/include/asm/uv/uv_bau.h +++ b/arch/x86/include/asm/uv/uv_bau.h | |||
| @@ -26,20 +26,22 @@ | |||
| 26 | * BAU_SB_DESCRIPTOR_BASE register, set 1 is located at BASE + 512, | 26 | * BAU_SB_DESCRIPTOR_BASE register, set 1 is located at BASE + 512, |
| 27 | * set 2 is at BASE + 2*512, set 3 at BASE + 3*512, and so on. | 27 | * set 2 is at BASE + 2*512, set 3 at BASE + 3*512, and so on. |
| 28 | * | 28 | * |
| 29 | * We will use 31 sets, one for sending BAU messages from each of the 32 | 29 | * We will use one set for sending BAU messages from each of the |
| 30 | * cpu's on the uvhub. | 30 | * cpu's on the uvhub. |
| 31 | * | 31 | * |
| 32 | * TLB shootdown will use the first of the 8 descriptors of each set. | 32 | * TLB shootdown will use the first of the 8 descriptors of each set. |
| 33 | * Each of the descriptors is 64 bytes in size (8*64 = 512 bytes in a set). | 33 | * Each of the descriptors is 64 bytes in size (8*64 = 512 bytes in a set). |
| 34 | */ | 34 | */ |
| 35 | 35 | ||
| 36 | #define MAX_CPUS_PER_UVHUB 64 | ||
| 37 | #define MAX_CPUS_PER_SOCKET 32 | ||
| 38 | #define UV_ADP_SIZE 64 /* hardware-provided max. */ | ||
| 39 | #define UV_CPUS_PER_ACT_STATUS 32 /* hardware-provided max. */ | ||
| 36 | #define UV_ITEMS_PER_DESCRIPTOR 8 | 40 | #define UV_ITEMS_PER_DESCRIPTOR 8 |
| 37 | /* the 'throttle' to prevent the hardware stay-busy bug */ | 41 | /* the 'throttle' to prevent the hardware stay-busy bug */ |
| 38 | #define MAX_BAU_CONCURRENT 3 | 42 | #define MAX_BAU_CONCURRENT 3 |
| 39 | #define UV_CPUS_PER_ACT_STATUS 32 | ||
| 40 | #define UV_ACT_STATUS_MASK 0x3 | 43 | #define UV_ACT_STATUS_MASK 0x3 |
| 41 | #define UV_ACT_STATUS_SIZE 2 | 44 | #define UV_ACT_STATUS_SIZE 2 |
| 42 | #define UV_ADP_SIZE 32 | ||
| 43 | #define UV_DISTRIBUTION_SIZE 256 | 45 | #define UV_DISTRIBUTION_SIZE 256 |
| 44 | #define UV_SW_ACK_NPENDING 8 | 46 | #define UV_SW_ACK_NPENDING 8 |
| 45 | #define UV_NET_ENDPOINT_INTD 0x38 | 47 | #define UV_NET_ENDPOINT_INTD 0x38 |
| @@ -100,7 +102,6 @@ | |||
| 100 | * number of destination side software ack resources | 102 | * number of destination side software ack resources |
| 101 | */ | 103 | */ |
| 102 | #define DEST_NUM_RESOURCES 8 | 104 | #define DEST_NUM_RESOURCES 8 |
| 103 | #define MAX_CPUS_PER_NODE 32 | ||
| 104 | /* | 105 | /* |
| 105 | * completion statuses for sending a TLB flush message | 106 | * completion statuses for sending a TLB flush message |
| 106 | */ | 107 | */ |
diff --git a/arch/x86/platform/uv/tlb_uv.c b/arch/x86/platform/uv/tlb_uv.c index ba9caa808a9c..df58e9cad96a 100644 --- a/arch/x86/platform/uv/tlb_uv.c +++ b/arch/x86/platform/uv/tlb_uv.c | |||
| @@ -1341,7 +1341,7 @@ uv_activation_descriptor_init(int node, int pnode) | |||
| 1341 | 1341 | ||
| 1342 | /* | 1342 | /* |
| 1343 | * each bau_desc is 64 bytes; there are 8 (UV_ITEMS_PER_DESCRIPTOR) | 1343 | * each bau_desc is 64 bytes; there are 8 (UV_ITEMS_PER_DESCRIPTOR) |
| 1344 | * per cpu; and up to 32 (UV_ADP_SIZE) cpu's per uvhub | 1344 | * per cpu; and one per cpu on the uvhub (UV_ADP_SIZE) |
| 1345 | */ | 1345 | */ |
| 1346 | bau_desc = kmalloc_node(sizeof(struct bau_desc) * UV_ADP_SIZE | 1346 | bau_desc = kmalloc_node(sizeof(struct bau_desc) * UV_ADP_SIZE |
| 1347 | * UV_ITEMS_PER_DESCRIPTOR, GFP_KERNEL, node); | 1347 | * UV_ITEMS_PER_DESCRIPTOR, GFP_KERNEL, node); |
| @@ -1490,7 +1490,7 @@ calculate_destination_timeout(void) | |||
| 1490 | /* | 1490 | /* |
| 1491 | * initialize the bau_control structure for each cpu | 1491 | * initialize the bau_control structure for each cpu |
| 1492 | */ | 1492 | */ |
| 1493 | static void __init uv_init_per_cpu(int nuvhubs) | 1493 | static int __init uv_init_per_cpu(int nuvhubs) |
| 1494 | { | 1494 | { |
| 1495 | int i; | 1495 | int i; |
| 1496 | int cpu; | 1496 | int cpu; |
| @@ -1507,7 +1507,7 @@ static void __init uv_init_per_cpu(int nuvhubs) | |||
| 1507 | struct bau_control *smaster = NULL; | 1507 | struct bau_control *smaster = NULL; |
| 1508 | struct socket_desc { | 1508 | struct socket_desc { |
| 1509 | short num_cpus; | 1509 | short num_cpus; |
| 1510 | short cpu_number[16]; | 1510 | short cpu_number[MAX_CPUS_PER_SOCKET]; |
| 1511 | }; | 1511 | }; |
| 1512 | struct uvhub_desc { | 1512 | struct uvhub_desc { |
| 1513 | unsigned short socket_mask; | 1513 | unsigned short socket_mask; |
| @@ -1540,6 +1540,10 @@ static void __init uv_init_per_cpu(int nuvhubs) | |||
| 1540 | sdp = &bdp->socket[socket]; | 1540 | sdp = &bdp->socket[socket]; |
| 1541 | sdp->cpu_number[sdp->num_cpus] = cpu; | 1541 | sdp->cpu_number[sdp->num_cpus] = cpu; |
| 1542 | sdp->num_cpus++; | 1542 | sdp->num_cpus++; |
| 1543 | if (sdp->num_cpus > MAX_CPUS_PER_SOCKET) { | ||
| 1544 | printk(KERN_EMERG "%d cpus per socket invalid\n", sdp->num_cpus); | ||
| 1545 | return 1; | ||
| 1546 | } | ||
| 1543 | } | 1547 | } |
| 1544 | for (uvhub = 0; uvhub < nuvhubs; uvhub++) { | 1548 | for (uvhub = 0; uvhub < nuvhubs; uvhub++) { |
| 1545 | if (!(*(uvhub_mask + (uvhub/8)) & (1 << (uvhub%8)))) | 1549 | if (!(*(uvhub_mask + (uvhub/8)) & (1 << (uvhub%8)))) |
| @@ -1570,6 +1574,12 @@ static void __init uv_init_per_cpu(int nuvhubs) | |||
| 1570 | bcp->uvhub_master = hmaster; | 1574 | bcp->uvhub_master = hmaster; |
| 1571 | bcp->uvhub_cpu = uv_cpu_hub_info(cpu)-> | 1575 | bcp->uvhub_cpu = uv_cpu_hub_info(cpu)-> |
| 1572 | blade_processor_id; | 1576 | blade_processor_id; |
| 1577 | if (bcp->uvhub_cpu >= MAX_CPUS_PER_UVHUB) { | ||
| 1578 | printk(KERN_EMERG | ||
| 1579 | "%d cpus per uvhub invalid\n", | ||
| 1580 | bcp->uvhub_cpu); | ||
| 1581 | return 1; | ||
| 1582 | } | ||
| 1573 | } | 1583 | } |
| 1574 | nextsocket: | 1584 | nextsocket: |
| 1575 | socket++; | 1585 | socket++; |
| @@ -1595,6 +1605,7 @@ nextsocket: | |||
| 1595 | bcp->congested_reps = congested_reps; | 1605 | bcp->congested_reps = congested_reps; |
| 1596 | bcp->congested_period = congested_period; | 1606 | bcp->congested_period = congested_period; |
| 1597 | } | 1607 | } |
| 1608 | return 0; | ||
| 1598 | } | 1609 | } |
| 1599 | 1610 | ||
| 1600 | /* | 1611 | /* |
| @@ -1625,7 +1636,10 @@ static int __init uv_bau_init(void) | |||
| 1625 | spin_lock_init(&disable_lock); | 1636 | spin_lock_init(&disable_lock); |
| 1626 | congested_cycles = microsec_2_cycles(congested_response_us); | 1637 | congested_cycles = microsec_2_cycles(congested_response_us); |
| 1627 | 1638 | ||
| 1628 | uv_init_per_cpu(nuvhubs); | 1639 | if (uv_init_per_cpu(nuvhubs)) { |
| 1640 | nobau = 1; | ||
| 1641 | return 0; | ||
| 1642 | } | ||
| 1629 | 1643 | ||
| 1630 | uv_partition_base_pnode = 0x7fffffff; | 1644 | uv_partition_base_pnode = 0x7fffffff; |
| 1631 | for (uvhub = 0; uvhub < nuvhubs; uvhub++) | 1645 | for (uvhub = 0; uvhub < nuvhubs; uvhub++) |
