aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/misc/sgi-xp/xpc_partition.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/misc/sgi-xp/xpc_partition.c')
-rw-r--r--drivers/misc/sgi-xp/xpc_partition.c33
1 files changed, 17 insertions, 16 deletions
diff --git a/drivers/misc/sgi-xp/xpc_partition.c b/drivers/misc/sgi-xp/xpc_partition.c
index 4e14effdeddb..90ec5ca8c9ab 100644
--- a/drivers/misc/sgi-xp/xpc_partition.c
+++ b/drivers/misc/sgi-xp/xpc_partition.c
@@ -152,6 +152,7 @@ xpc_setup_rsvd_page(void)
152{ 152{
153 struct xpc_rsvd_page *rp; 153 struct xpc_rsvd_page *rp;
154 u64 rp_pa; 154 u64 rp_pa;
155 unsigned long new_stamp;
155 156
156 /* get the local reserved page's address */ 157 /* get the local reserved page's address */
157 158
@@ -201,7 +202,10 @@ xpc_setup_rsvd_page(void)
201 * This signifies to the remote partition that our reserved 202 * This signifies to the remote partition that our reserved
202 * page is initialized. 203 * page is initialized.
203 */ 204 */
204 rp->stamp = CURRENT_TIME; 205 new_stamp = jiffies;
206 if (new_stamp == 0 || new_stamp == rp->stamp)
207 new_stamp++;
208 rp->stamp = new_stamp;
205 209
206 return rp; 210 return rp;
207} 211}
@@ -350,18 +354,8 @@ xpc_get_remote_rp(int nasid, u64 *discovered_nasids,
350 discovered_nasids[i] |= remote_part_nasids[i]; 354 discovered_nasids[i] |= remote_part_nasids[i];
351 } 355 }
352 356
353 /* check that the partid is valid and is for another partition */ 357 /* see if the reserved page has been set up by XPC */
354 358 if (remote_rp->stamp == 0)
355 if (remote_rp->SAL_partid < 0 ||
356 remote_rp->SAL_partid >= xp_max_npartitions) {
357 return xpInvalidPartid;
358 }
359
360 if (remote_rp->SAL_partid == sn_partition_id)
361 return xpLocalPartid;
362
363 /* see if the rest of the reserved page has been set up by XPC */
364 if (timespec_equal(&remote_rp->stamp, &ZERO_STAMP))
365 return xpRsvdPageNotSet; 359 return xpRsvdPageNotSet;
366 360
367 if (XPC_VERSION_MAJOR(remote_rp->version) != 361 if (XPC_VERSION_MAJOR(remote_rp->version) !=
@@ -369,8 +363,15 @@ xpc_get_remote_rp(int nasid, u64 *discovered_nasids,
369 return xpBadVersion; 363 return xpBadVersion;
370 } 364 }
371 365
372 if (remote_rp->max_npartitions <= sn_partition_id) 366 /* check that both local and remote partids are valid for each side */
367 if (remote_rp->SAL_partid < 0 ||
368 remote_rp->SAL_partid >= xp_max_npartitions ||
369 remote_rp->max_npartitions <= sn_partition_id) {
373 return xpInvalidPartid; 370 return xpInvalidPartid;
371 }
372
373 if (remote_rp->SAL_partid == sn_partition_id)
374 return xpLocalPartid;
374 375
375 return xpSuccess; 376 return xpSuccess;
376} 377}
@@ -388,8 +389,8 @@ xpc_partition_disengaged(struct xpc_partition *part)
388 disengaged = (xpc_partition_engaged(1UL << partid) == 0); 389 disengaged = (xpc_partition_engaged(1UL << partid) == 0);
389 if (part->disengage_request_timeout) { 390 if (part->disengage_request_timeout) {
390 if (!disengaged) { 391 if (!disengaged) {
391 if (time_before(jiffies, 392 if (time_is_after_jiffies(part->
392 part->disengage_request_timeout)) { 393 disengage_request_timeout)) {
393 /* timelimit hasn't been reached yet */ 394 /* timelimit hasn't been reached yet */
394 return 0; 395 return 0;
395 } 396 }