#define SPM_MAX_BUS_PROT_DATA          5
 
-#define _BUS_PROT(_mask, _set, _clr, _sta, _update) {  \
-               .bus_prot_mask = (_mask),               \
-               .bus_prot_set = _set,                   \
-               .bus_prot_clr = _clr,                   \
-               .bus_prot_sta = _sta,                   \
-               .bus_prot_reg_update = _update,         \
+#define _BUS_PROT(_mask, _set, _clr, _sta, _update, _ignore) { \
+               .bus_prot_mask = (_mask),                       \
+               .bus_prot_set = _set,                           \
+               .bus_prot_clr = _clr,                           \
+               .bus_prot_sta = _sta,                           \
+               .bus_prot_reg_update = _update,                 \
+               .ignore_clr_ack = _ignore,                      \
        }
 
-#define BUS_PROT_WR(_mask, _set, _clr, _sta)           \
-               _BUS_PROT(_mask, _set, _clr, _sta, false)
+#define BUS_PROT_WR(_mask, _set, _clr, _sta)                   \
+               _BUS_PROT(_mask, _set, _clr, _sta, false, false)
+
+#define BUS_PROT_WR_IGN(_mask, _set, _clr, _sta)               \
+               _BUS_PROT(_mask, _set, _clr, _sta, false, true)
 
 #define BUS_PROT_UPDATE(_mask, _set, _clr, _sta)               \
-               _BUS_PROT(_mask, _set, _clr, _sta, true)
+               _BUS_PROT(_mask, _set, _clr, _sta, true, false)
 
 #define BUS_PROT_UPDATE_TOPAXI(_mask)                          \
                BUS_PROT_UPDATE(_mask,                          \
        u32 bus_prot_clr;
        u32 bus_prot_sta;
        bool bus_prot_reg_update;
+       bool ignore_clr_ack;
 };
 
 #define MAX_SUBSYS_CLKS 10