diff --git a/drivers/arm/cci/cci.c b/drivers/arm/cci/cci.c index 81808b9f70de316ce6c66d057f1a7eac55a82e02..71b65f42ce2abaab44d2eea1f1ed5b1049a7c1ab 100644 --- a/drivers/arm/cci/cci.c +++ b/drivers/arm/cci/cci.c @@ -5,6 +5,7 @@ */ #include <arch.h> +#include <arch_helpers.h> #include <assert.h> #include <cci.h> #include <debug.h> @@ -142,6 +143,12 @@ void cci_enable_snoop_dvm_reqs(unsigned int master_id) SLAVE_IFACE_OFFSET(slave_if_id) + SNOOP_CTRL_REG, DVM_EN_BIT | SNOOP_EN_BIT); + /* + * Wait for the completion of the write to the Snoop Control Register + * before testing the change_pending bit + */ + dmbish(); + /* Wait for the dust to settle down */ while (mmio_read_32(cci_base + STATUS_REG) & CHANGE_PENDING_BIT) ; @@ -163,6 +170,12 @@ void cci_disable_snoop_dvm_reqs(unsigned int master_id) SLAVE_IFACE_OFFSET(slave_if_id) + SNOOP_CTRL_REG, ~(DVM_EN_BIT | SNOOP_EN_BIT)); + /* + * Wait for the completion of the write to the Snoop Control Register + * before testing the change_pending bit + */ + dmbish(); + /* Wait for the dust to settle down */ while (mmio_read_32(cci_base + STATUS_REG) & CHANGE_PENDING_BIT) ;