[PATCH 15/19] powerpc: htab routines for Celleb

Benjamin Herrenschmidt benh at kernel.crashing.org
Thu Jan 18 11:36:29 EST 2007


> +
> +	dummy0 = beat_lpar_hpte_getword0(slot);
> +	if ((dummy0 & ~0x7FUL) != (want_v & ~0x7FUL)) {
> +		DBG_LOW("not found !\n");
> +		return -1;
> +	}
> +
> +	lpar_rc = beat_write_htab_entry(0, slot, 0, newpp, 0, 7, &dummy0,
> +					&dummy1);
> +	if (lpar_rc != 0 || dummy0 == 0) {
> +		DBG_LOW("not found !\n");
> +		return -1;
> +	}
> +
> +	DBG_LOW("ok %lx %lx\n", dummy0, dummy1);
> +

I just noticed... isn't there a race condition if the HPTE gets evicted
between those two calls and/or replaced by another one ?

That would be generally harmless unless the one replacing it is bolted,
in which case you might override a bolted entry. Fortunately we don't
currently insert much bolted entries after boot, but I still see a
potential for trouble there.

The best solution here is to actually add a function to the hypervisor,
along the line of what I described in my document a while ago, which
atomically compares AVPN and replaces the PP and N bits if it didn't
change.

Another possible issue is that two processors or threads might
continuously evict each other that way I think.

Since the bug only affect your platform and might actually not trigger
at all in the current system since we don't play much with bolted
entries, I'm acking it, but you should look into fixing it.

Acked-by: Benjamin Herrenschmidt <benh at kernel.crashing.org>

Cheers,
Ben.





More information about the Linuxppc-dev mailing list