Commit f64cae79 authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] Altix update: pcibr_invalidate_ate check

From: Pat Gefre <pfg@sgi.com>

arch/ia64/sn/io/sn2/pcibr/pcibr_ate.c
    check for pcibr_invalidate_ate 0 used for debugging
parent c03b9444
...@@ -23,6 +23,7 @@ bridge_ate_t pcibr_flags_to_ate(pcibr_soft_t, unsigned); ...@@ -23,6 +23,7 @@ bridge_ate_t pcibr_flags_to_ate(pcibr_soft_t, unsigned);
bridge_ate_p pcibr_ate_addr(pcibr_soft_t, int); bridge_ate_p pcibr_ate_addr(pcibr_soft_t, int);
void ate_write(pcibr_soft_t, int, int, bridge_ate_t); void ate_write(pcibr_soft_t, int, int, bridge_ate_t);
int pcibr_invalidate_ate; /* by default don't invalidate ATE on free */
/* /*
* Allocate "count" contiguous Bridge Address Translation Entries * Allocate "count" contiguous Bridge Address Translation Entries
...@@ -64,9 +65,11 @@ pcibr_ate_free(pcibr_soft_t pcibr_soft, int index, int count, struct resource *r ...@@ -64,9 +65,11 @@ pcibr_ate_free(pcibr_soft_t pcibr_soft, int index, int count, struct resource *r
int status = 0; int status = 0;
unsigned long flags; unsigned long flags;
/* For debugging purposes, clear the valid bit in the ATE */ if (pcibr_invalidate_ate) {
ate = *pcibr_ate_addr(pcibr_soft, index); /* For debugging purposes, clear the valid bit in the ATE */
ate_write(pcibr_soft, index, count, ate & ~ATE_V); ate = *pcibr_ate_addr(pcibr_soft, index);
ate_write(pcibr_soft, index, count, (ate & ~ATE_V));
}
flags = pcibr_lock(pcibr_soft); flags = pcibr_lock(pcibr_soft);
status = release_resource(res); status = release_resource(res);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment