#define hr_reg_clear(ptr, field) _hr_reg_clear(ptr, field)
 
+#define _hr_reg_write_bool(ptr, field_type, field_h, field_l, val)             \
+       ({                                                                     \
+               (val) ? _hr_reg_enable(ptr, field_type, field_h, field_l) :    \
+                       _hr_reg_clear(ptr, field_type, field_h, field_l);      \
+       })
+
+#define hr_reg_write_bool(ptr, field, val) _hr_reg_write_bool(ptr, field, val)
+
 #define _hr_reg_write(ptr, field_type, field_h, field_l, val)                  \
        ({                                                                     \
                _hr_reg_clear(ptr, field_type, field_h, field_l);              \
 
        hr_reg_write(mpt_entry, MPT_PD, mr->pd);
        hr_reg_enable(mpt_entry, MPT_L_INV_EN);
 
-       hr_reg_write(mpt_entry, MPT_BIND_EN,
-                    !!(mr->access & IB_ACCESS_MW_BIND));
-       hr_reg_write(mpt_entry, MPT_ATOMIC_EN,
-                    !!(mr->access & IB_ACCESS_REMOTE_ATOMIC));
-       hr_reg_write(mpt_entry, MPT_RR_EN,
-                    !!(mr->access & IB_ACCESS_REMOTE_READ));
-       hr_reg_write(mpt_entry, MPT_RW_EN,
-                    !!(mr->access & IB_ACCESS_REMOTE_WRITE));
-       hr_reg_write(mpt_entry, MPT_LW_EN,
-                    !!((mr->access & IB_ACCESS_LOCAL_WRITE)));
+       hr_reg_write_bool(mpt_entry, MPT_BIND_EN,
+                         mr->access & IB_ACCESS_MW_BIND);
+       hr_reg_write_bool(mpt_entry, MPT_ATOMIC_EN,
+                         mr->access & IB_ACCESS_REMOTE_ATOMIC);
+       hr_reg_write_bool(mpt_entry, MPT_RR_EN,
+                         mr->access & IB_ACCESS_REMOTE_READ);
+       hr_reg_write_bool(mpt_entry, MPT_RW_EN,
+                         mr->access & IB_ACCESS_REMOTE_WRITE);
+       hr_reg_write_bool(mpt_entry, MPT_LW_EN,
+                         mr->access & IB_ACCESS_LOCAL_WRITE);
 
        mpt_entry->len_l = cpu_to_le32(lower_32_bits(mr->size));
        mpt_entry->len_h = cpu_to_le32(upper_32_bits(mr->size));
        }
 
        hr_reg_write(ctx, SRQC_SRQ_ST, 1);
-       hr_reg_write(ctx, SRQC_SRQ_TYPE,
-                    !!(srq->ibsrq.srq_type == IB_SRQT_XRC));
+       hr_reg_write_bool(ctx, SRQC_SRQ_TYPE,
+                         srq->ibsrq.srq_type == IB_SRQT_XRC);
        hr_reg_write(ctx, SRQC_PD, to_hr_pd(srq->ibsrq.pd)->pdn);
        hr_reg_write(ctx, SRQC_SRQN, srq->srqn);
        hr_reg_write(ctx, SRQC_XRCD, srq->xrcdn);