int hns_roce_init(struct hns_roce_dev *hr_dev);
 void hns_roce_exit(struct hns_roce_dev *hr_dev);
 int hns_roce_fill_res_cq_entry(struct sk_buff *msg, struct ib_cq *ib_cq);
+int hns_roce_fill_res_cq_entry_raw(struct sk_buff *msg, struct ib_cq *ib_cq);
 struct hns_user_mmap_entry *
 hns_roce_user_mmap_entry_insert(struct ib_ucontext *ucontext, u64 address,
                                size_t length,
 
 #include "hns_roce_device.h"
 #include "hns_roce_hw_v2.h"
 
+#define MAX_ENTRY_NUM 256
+
 int hns_roce_fill_res_cq_entry(struct sk_buff *msg, struct ib_cq *ib_cq)
 {
        struct hns_roce_cq *hr_cq = to_hr_cq(ib_cq);
 
        return -EMSGSIZE;
 }
+
+int hns_roce_fill_res_cq_entry_raw(struct sk_buff *msg, struct ib_cq *ib_cq)
+{
+       struct hns_roce_dev *hr_dev = to_hr_dev(ib_cq->device);
+       struct hns_roce_cq *hr_cq = to_hr_cq(ib_cq);
+       struct hns_roce_v2_cq_context context;
+       u32 data[MAX_ENTRY_NUM] = {};
+       int offset = 0;
+       int ret;
+
+       if (!hr_dev->hw->query_cqc)
+               return -EINVAL;
+
+       ret = hr_dev->hw->query_cqc(hr_dev, hr_cq->cqn, &context);
+       if (ret)
+               return -EINVAL;
+
+       data[offset++] = hr_reg_read(&context, CQC_CQ_ST);
+       data[offset++] = hr_reg_read(&context, CQC_SHIFT);
+       data[offset++] = hr_reg_read(&context, CQC_CQE_SIZE);
+       data[offset++] = hr_reg_read(&context, CQC_CQE_CNT);
+       data[offset++] = hr_reg_read(&context, CQC_CQ_PRODUCER_IDX);
+       data[offset++] = hr_reg_read(&context, CQC_CQ_CONSUMER_IDX);
+       data[offset++] = hr_reg_read(&context, CQC_DB_RECORD_EN);
+       data[offset++] = hr_reg_read(&context, CQC_ARM_ST);
+       data[offset++] = hr_reg_read(&context, CQC_CMD_SN);
+       data[offset++] = hr_reg_read(&context, CQC_CEQN);
+       data[offset++] = hr_reg_read(&context, CQC_CQ_MAX_CNT);
+       data[offset++] = hr_reg_read(&context, CQC_CQ_PERIOD);
+       data[offset++] = hr_reg_read(&context, CQC_CQE_HOP_NUM);
+       data[offset++] = hr_reg_read(&context, CQC_CQE_BAR_PG_SZ);
+       data[offset++] = hr_reg_read(&context, CQC_CQE_BUF_PG_SZ);
+
+       ret = nla_put(msg, RDMA_NLDEV_ATTR_RES_RAW, offset * sizeof(u32), data);
+
+       return ret;
+}