struct beiscsi_session *beiscsi_sess;
        struct beiscsi_io_task *io_task;
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_session_create\n");
 
        if (!ep) {
-               SE_DEBUG(DBG_LVL_1, "beiscsi_session_create: invalid ep\n");
+               printk(KERN_ERR
+                      "beiscsi_session_create: invalid ep\n");
                return NULL;
        }
        beiscsi_ep = ep->dd_data;
        phba = beiscsi_ep->phba;
        shost = phba->shost;
+
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BS_%d : In beiscsi_session_create\n");
+
        if (cmds_max > beiscsi_ep->phba->params.wrbs_per_cxn) {
-               shost_printk(KERN_ERR, shost, "Cannot handle %d cmds."
-                            "Max cmds per session supported is %d. Using %d. "
-                            "\n", cmds_max,
-                             beiscsi_ep->phba->params.wrbs_per_cxn,
-                             beiscsi_ep->phba->params.wrbs_per_cxn);
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Cannot handle %d cmds."
+                           "Max cmds per session supported is %d. Using %d."
+                           "\n", cmds_max,
+                           beiscsi_ep->phba->params.wrbs_per_cxn,
+                           beiscsi_ep->phba->params.wrbs_per_cxn);
+
                cmds_max = beiscsi_ep->phba->params.wrbs_per_cxn;
        }
 
        struct iscsi_session *sess = cls_session->dd_data;
        struct beiscsi_session *beiscsi_sess = sess->dd_data;
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_session_destroy\n");
+       printk(KERN_INFO "In beiscsi_session_destroy\n");
        pci_pool_destroy(beiscsi_sess->bhs_pool);
        iscsi_session_teardown(cls_session);
 }
        struct iscsi_session *sess;
        struct beiscsi_session *beiscsi_sess;
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_conn_create ,cid"
-                "from iscsi layer=%d\n", cid);
        shost = iscsi_session_to_shost(cls_session);
        phba = iscsi_host_priv(shost);
 
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BS_%d : In beiscsi_conn_create ,cid"
+                   "from iscsi layer=%d\n", cid);
+
        cls_conn = iscsi_conn_setup(cls_session, sizeof(*beiscsi_conn), cid);
        if (!cls_conn)
                return NULL;
                                unsigned int cid)
 {
        if (phba->conn_table[cid]) {
-               SE_DEBUG(DBG_LVL_1,
-                        "Connection table already occupied. Detected clash\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Connection table already occupied. Detected clash\n");
+
                return -EINVAL;
        } else {
-               SE_DEBUG(DBG_LVL_8, "phba->conn_table[%d]=%p(beiscsi_conn)\n",
-                        cid, beiscsi_conn);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                           "BS_%d : phba->conn_table[%d]=%p(beiscsi_conn)\n",
+                           cid, beiscsi_conn);
+
                phba->conn_table[cid] = beiscsi_conn;
        }
        return 0;
        struct beiscsi_endpoint *beiscsi_ep;
        struct iscsi_endpoint *ep;
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_conn_bind\n");
        ep = iscsi_lookup_endpoint(transport_fd);
        if (!ep)
                return -EINVAL;
                return -EINVAL;
 
        if (beiscsi_ep->phba != phba) {
-               SE_DEBUG(DBG_LVL_8,
-                        "beiscsi_ep->hba=%p not equal to phba=%p\n",
-                        beiscsi_ep->phba, phba);
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : beiscsi_ep->hba=%p not equal to phba=%p\n",
+                           beiscsi_ep->phba, phba);
+
                return -EEXIST;
        }
 
        beiscsi_conn->beiscsi_conn_cid = beiscsi_ep->ep_cid;
        beiscsi_conn->ep = beiscsi_ep;
        beiscsi_ep->conn = beiscsi_conn;
-       SE_DEBUG(DBG_LVL_8, "beiscsi_conn=%p conn=%p ep_cid=%d\n",
-                beiscsi_conn, conn, beiscsi_ep->ep_cid);
+
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BS_%d : beiscsi_conn=%p conn=%p ep_cid=%d\n",
+                   beiscsi_conn, conn, beiscsi_ep->ep_cid);
+
        return beiscsi_bindconn_cid(phba, beiscsi_conn, beiscsi_ep->ep_cid);
 }
 
                                              ISCSI_IFACE_TYPE_IPV4,
                                              0, 0);
        if (!phba->ipv4_iface) {
-               shost_printk(KERN_ERR, phba->shost, "Could not "
-                            "create default IPv4 address.\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Could not "
+                           "create default IPv4 address.\n");
                return -ENODEV;
        }
 
                                              ISCSI_IFACE_TYPE_IPV6,
                                              0, 0);
        if (!phba->ipv6_iface) {
-               shost_printk(KERN_ERR, phba->shost, "Could not "
-                            "create default IPv6 address.\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Could not "
+                           "create default IPv6 address.\n");
                return -ENODEV;
        }
 
                        iface_ip = nla_data(nla);
                break;
        default:
-               shost_printk(KERN_ERR, shost, "Unsupported param %d\n",
-                            iface_param->param);
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Unsupported param %d\n",
+                           iface_param->param);
        }
 
        if (!iface_ip || !iface_subnet) {
-               shost_printk(KERN_ERR, shost, "IP and Subnet Mask required\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : IP and Subnet Mask required\n");
                return -EINVAL;
        }
 
                        ret = beiscsi_set_static_ip(shost, iface_param,
                                                    data, dt_len);
                else
-                       shost_printk(KERN_ERR, shost, "Invalid BOOTPROTO: %d\n",
-                                       iface_param->value[0]);
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                                   "BS_%d : Invalid BOOTPROTO: %d\n",
+                                   iface_param->value[0]);
                break;
        case ISCSI_NET_PARAM_IFACE_ENABLE:
                if (iface_param->value[0] == ISCSI_IFACE_ENABLE)
                                            data, dt_len);
                break;
        default:
-               shost_printk(KERN_ERR, shost, "Param %d not supported\n",
-                            iface_param->param);
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Param %d not supported\n",
+                           iface_param->param);
        }
 
        return ret;
                                  ISCSI_BOOTPROTO_STATIC);
                break;
        default:
-               shost_printk(KERN_ERR, shost, "Param %d not supported\n",
-                            iface_param->param);
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Param %d not supported\n",
+                           iface_param->param);
        }
 
        return ret;
                void *data, uint32_t dt_len)
 {
        struct iscsi_iface_param_info *iface_param = NULL;
+       struct beiscsi_hba *phba = iscsi_host_priv(shost);
        struct nlattr *attrib;
        uint32_t rm_len = dt_len;
        int ret = 0 ;
                 * BE2ISCSI only supports 1 interface
                 */
                if (iface_param->iface_num) {
-                       shost_printk(KERN_ERR, shost, "Invalid iface_num %d."
-                                    "Only iface_num 0 is supported.\n",
-                                    iface_param->iface_num);
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                                   "BS_%d : Invalid iface_num %d."
+                                   "Only iface_num 0 is supported.\n",
+                                   iface_param->iface_num);
+
                        return -EINVAL;
                }
 
                                               data, dt_len);
                        break;
                default:
-                       shost_printk(KERN_ERR, shost,
-                                    "Invalid iface type :%d passed\n",
-                                    iface_param->iface_type);
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                                   "BS_%d : Invalid iface type :%d passed\n",
+                                   iface_param->iface_type);
                        break;
                }
 
        struct beiscsi_endpoint *beiscsi_ep = ep->dd_data;
        int len = 0;
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_ep_get_param, param= %d\n", param);
+       beiscsi_log(beiscsi_ep->phba, KERN_INFO,
+                   BEISCSI_LOG_CONFIG,
+                   "BS_%d : In beiscsi_ep_get_param,"
+                   " param= %d\n", param);
 
        switch (param) {
        case ISCSI_PARAM_CONN_PORT:
 {
        struct iscsi_conn *conn = cls_conn->dd_data;
        struct iscsi_session *session = conn->session;
+       struct beiscsi_hba *phba = NULL;
        int ret;
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_conn_set_param, param= %d\n", param);
+       phba = ((struct beiscsi_conn *)conn->dd_data)->phba;
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BS_%d : In beiscsi_conn_set_param,"
+                   " param= %d\n", param);
+
        ret = iscsi_set_param(cls_conn, param, buf, buflen);
        if (ret)
                return ret;
 
        tag = be_cmd_get_initname(phba);
        if (!tag) {
-               SE_DEBUG(DBG_LVL_1, "Getting Initiator Name Failed\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Getting Initiator Name Failed\n");
+
                return -EBUSY;
        } else
                wait_event_interruptible(phba->ctrl.mcc_wait[tag],
        status = phba->ctrl.mcc_numtag[tag] & 0x000000FF;
 
        if (status || extd_status) {
-               SE_DEBUG(DBG_LVL_1, "MailBox Command Failed with "
-                               "status = %d extd_status = %d\n",
-                               status, extd_status);
+               beiscsi_log(phba, KERN_ERR,
+                           BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
+                           "BS_%d : MailBox Command Failed with "
+                           "status = %d extd_status = %d\n",
+                           status, extd_status);
+
                free_mcc_tag(&phba->ctrl, tag);
                return -EAGAIN;
        }
 
        tag = be_cmd_get_port_speed(phba);
        if (!tag) {
-               SE_DEBUG(DBG_LVL_1, "Getting Port Speed Failed\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Getting Port Speed Failed\n");
+
                 return -EBUSY;
         } else
                wait_event_interruptible(phba->ctrl.mcc_wait[tag],
        status = phba->ctrl.mcc_numtag[tag] & 0x000000FF;
 
        if (status || extd_status) {
-               SE_DEBUG(DBG_LVL_1, "MailBox Command Failed with "
-                               "status = %d extd_status = %d\n",
-                               status, extd_status);
+               beiscsi_log(phba, KERN_ERR,
+                           BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
+                           "BS_%d : MailBox Command Failed with "
+                           "status = %d extd_status = %d\n",
+                           status, extd_status);
+
                free_mcc_tag(&phba->ctrl, tag);
                return -EAGAIN;
        }
        struct beiscsi_hba *phba = iscsi_host_priv(shost);
        int status = 0;
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_get_host_param, param= %d\n", param);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BS_%d : In beiscsi_get_host_param,"
+                   " param= %d\n", param);
+
        switch (param) {
        case ISCSI_HOST_PARAM_HWADDRESS:
                status = beiscsi_get_macaddr(buf, phba);
                if (status < 0) {
-                       SE_DEBUG(DBG_LVL_1, "beiscsi_get_macaddr Failed\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                                   "BS_%d : beiscsi_get_macaddr Failed\n");
                        return status;
                }
                break;
        case ISCSI_HOST_PARAM_INITIATOR_NAME:
                status = beiscsi_get_initname(buf, phba);
                if (status < 0) {
-                       SE_DEBUG(DBG_LVL_1,
-                                       "Retreiving Initiator Name Failed\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                                   "BS_%d : Retreiving Initiator Name Failed\n");
                        return status;
                }
                break;
        case ISCSI_HOST_PARAM_PORT_SPEED:
                status = beiscsi_get_port_speed(shost);
                if (status) {
-                       SE_DEBUG(DBG_LVL_1,
-                                       "Retreiving Port Speed Failed\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                                   "BS_%d : Retreiving Port Speed Failed\n");
                        return status;
                }
                status = sprintf(buf, "%s\n", iscsi_get_port_speed_name(shost));
                            struct iscsi_stats *stats)
 {
        struct iscsi_conn *conn = cls_conn->dd_data;
+       struct beiscsi_hba *phba = NULL;
+
+       phba = ((struct beiscsi_conn *)conn->dd_data)->phba;
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BS_%d : In beiscsi_conn_get_stats\n");
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_conn_get_stats\n");
        stats->txdata_octets = conn->txdata_octets;
        stats->rxdata_octets = conn->rxdata_octets;
        stats->dataout_pdus = conn->dataout_pdus_cnt;
        struct beiscsi_endpoint *beiscsi_ep;
        struct beiscsi_offload_params params;
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_conn_start\n");
+       beiscsi_log(beiscsi_conn->phba, KERN_INFO,
+                   BEISCSI_LOG_CONFIG,
+                   "BS_%d : In beiscsi_conn_start\n");
+
        memset(¶ms, 0, sizeof(struct beiscsi_offload_params));
        beiscsi_ep = beiscsi_conn->ep;
        if (!beiscsi_ep)
-               SE_DEBUG(DBG_LVL_1, "In beiscsi_conn_start , no beiscsi_ep\n");
+               beiscsi_log(beiscsi_conn->phba, KERN_ERR,
+                           BEISCSI_LOG_CONFIG,
+                           "BS_%d : In beiscsi_conn_start , no beiscsi_ep\n");
 
        beiscsi_conn->login_in_progress = 0;
        beiscsi_set_params_for_offld(beiscsi_conn, ¶ms);
        unsigned int tag, wrb_num;
        int ret = -ENOMEM;
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_open_conn\n");
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BS_%d : In beiscsi_open_conn\n");
+
        beiscsi_ep->ep_cid = beiscsi_get_cid(phba);
        if (beiscsi_ep->ep_cid == 0xFFFF) {
-               SE_DEBUG(DBG_LVL_1, "No free cid available\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : No free cid available\n");
                return ret;
        }
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_open_conn, ep_cid=%d\n",
-                beiscsi_ep->ep_cid);
+
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BS_%d : In beiscsi_open_conn, ep_cid=%d\n",
+                   beiscsi_ep->ep_cid);
+
        phba->ep_array[beiscsi_ep->ep_cid -
                       phba->fw_config.iscsi_cid_start] = ep;
        if (beiscsi_ep->ep_cid > (phba->fw_config.iscsi_cid_start +
                                  phba->params.cxns_per_ctrl * 2)) {
-               SE_DEBUG(DBG_LVL_1, "Failed in allocate iscsi cid\n");
+
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Failed in allocate iscsi cid\n");
                goto free_ep;
        }
 
                                sizeof(struct tcp_connect_and_offload_in),
                                &nonemb_cmd.dma);
        if (nonemb_cmd.va == NULL) {
-               SE_DEBUG(DBG_LVL_1,
-                        "Failed to allocate memory for mgmt_open_connection"
-                        "\n");
+
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Failed to allocate memory for"
+                           " mgmt_open_connection\n");
+
                beiscsi_put_cid(phba, beiscsi_ep->ep_cid);
                return -ENOMEM;
        }
        memset(nonemb_cmd.va, 0, nonemb_cmd.size);
        tag = mgmt_open_connection(phba, dst_addr, beiscsi_ep, &nonemb_cmd);
        if (!tag) {
-               SE_DEBUG(DBG_LVL_1,
-                        "mgmt_open_connection Failed for cid=%d\n",
-                        beiscsi_ep->ep_cid);
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : mgmt_open_connection Failed for cid=%d\n",
+                           beiscsi_ep->ep_cid);
+
                beiscsi_put_cid(phba, beiscsi_ep->ep_cid);
                pci_free_consistent(phba->ctrl.pdev, nonemb_cmd.size,
                                    nonemb_cmd.va, nonemb_cmd.dma);
        extd_status = (phba->ctrl.mcc_numtag[tag] & 0x0000FF00) >> 8;
        status = phba->ctrl.mcc_numtag[tag] & 0x000000FF;
        if (status || extd_status) {
-               SE_DEBUG(DBG_LVL_1, "mgmt_open_connection Failed"
-                                   " status = %d extd_status = %d\n",
-                                   status, extd_status);
+               beiscsi_log(phba, KERN_ERR,
+                           BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
+                           "BS_%d : mgmt_open_connection Failed"
+                           " status = %d extd_status = %d\n",
+                           status, extd_status);
+
                free_mcc_tag(&phba->ctrl, tag);
                pci_free_consistent(phba->ctrl.pdev, nonemb_cmd.size,
                            nonemb_cmd.va, nonemb_cmd.dma);
                beiscsi_ep = ep->dd_data;
                beiscsi_ep->fw_handle = ptcpcnct_out->connection_handle;
                beiscsi_ep->cid_vld = 1;
-               SE_DEBUG(DBG_LVL_8, "mgmt_open_connection Success\n");
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                           "BS_%d : mgmt_open_connection Success\n");
        }
        pci_free_consistent(phba->ctrl.pdev, nonemb_cmd.size,
                            nonemb_cmd.va, nonemb_cmd.dma);
        struct iscsi_endpoint *ep;
        int ret;
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_ep_connect\n");
        if (shost)
                phba = iscsi_host_priv(shost);
        else {
                ret = -ENXIO;
-               SE_DEBUG(DBG_LVL_1, "shost is NULL\n");
+               printk(KERN_ERR
+                      "beiscsi_ep_connect shost is NULL\n");
                return ERR_PTR(ret);
        }
 
        if (phba->state != BE_ADAPTER_UP) {
                ret = -EBUSY;
-               SE_DEBUG(DBG_LVL_1, "The Adapter state is Not UP\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : The Adapter state is Not UP\n");
                return ERR_PTR(ret);
        }
 
        beiscsi_ep->openiscsi_ep = ep;
        ret = beiscsi_open_conn(ep, NULL, dst_addr, non_blocking);
        if (ret) {
-               SE_DEBUG(DBG_LVL_1, "Failed in beiscsi_open_conn\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Failed in beiscsi_open_conn\n");
                goto free_ep;
        }
 
 {
        struct beiscsi_endpoint *beiscsi_ep = ep->dd_data;
 
-       SE_DEBUG(DBG_LVL_8, "In  beiscsi_ep_poll\n");
+       beiscsi_log(beiscsi_ep->phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BS_%d : In  beiscsi_ep_poll\n");
+
        if (beiscsi_ep->cid_vld == 1)
                return 1;
        else
 
        tag = mgmt_upload_connection(phba, beiscsi_ep->ep_cid, flag);
        if (!tag) {
-               SE_DEBUG(DBG_LVL_8, "upload failed for cid 0x%x\n",
-                        beiscsi_ep->ep_cid);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                           "BS_%d : upload failed for cid 0x%x\n",
+                           beiscsi_ep->ep_cid);
+
                ret = -EAGAIN;
        } else {
                wait_event_interruptible(phba->ctrl.mcc_wait[tag],
        if (phba->conn_table[cid])
                phba->conn_table[cid] = NULL;
        else {
-               SE_DEBUG(DBG_LVL_8, "Connection table Not occupied.\n");
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                           "BS_%d : Connection table Not occupied.\n");
                return -EINVAL;
        }
        return 0;
 
        beiscsi_ep = ep->dd_data;
        phba = beiscsi_ep->phba;
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_ep_disconnect for ep_cid = %d\n",
-                            beiscsi_ep->ep_cid);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BS_%d : In beiscsi_ep_disconnect for ep_cid = %d\n",
+                   beiscsi_ep->ep_cid);
 
        if (!beiscsi_ep->conn) {
-               SE_DEBUG(DBG_LVL_8, "In beiscsi_ep_disconnect, no "
-                        "beiscsi_ep\n");
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                           "BS_%d : In beiscsi_ep_disconnect, no "
+                           "beiscsi_ep\n");
                return;
        }
        beiscsi_conn = beiscsi_ep->conn;
        iscsi_suspend_queue(beiscsi_conn->conn);
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_ep_disconnect ep_cid = %d\n",
-                beiscsi_ep->ep_cid);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BS_%d : In beiscsi_ep_disconnect ep_cid = %d\n",
+                   beiscsi_ep->ep_cid);
 
        tag = mgmt_invalidate_connection(phba, beiscsi_ep,
                                            beiscsi_ep->ep_cid, 1,
                                            savecfg_flag);
        if (!tag) {
-               SE_DEBUG(DBG_LVL_1,
-                        "mgmt_invalidate_connection Failed for cid=%d\n",
-                         beiscsi_ep->ep_cid);
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BS_%d : mgmt_invalidate_connection"
+                           " Failed for cid=%d\n",
+                           beiscsi_ep->ep_cid);
        } else {
                wait_event_interruptible(phba->ctrl.mcc_wait[tag],
                                         phba->ctrl.mcc_numtag[tag]);
 
 module_param(be_iopoll_budget, int, 0);
 module_param(enable_msix, int, 0);
 module_param(be_max_phys_size, uint, S_IRUGO);
-MODULE_PARM_DESC(be_max_phys_size, "Maximum Size (In Kilobytes) of physically"
-                                  "contiguous memory that can be allocated."
-                                  "Range is 16 - 128");
+MODULE_PARM_DESC(be_max_phys_size,
+               "Maximum Size (In Kilobytes) of physically contiguous "
+               "memory that can be allocated. Range is 16 - 128");
+
+#define beiscsi_disp_param(_name)\
+ssize_t        \
+beiscsi_##_name##_disp(struct device *dev,\
+                       struct device_attribute *attrib, char *buf)     \
+{      \
+       struct Scsi_Host *shost = class_to_shost(dev);\
+       struct beiscsi_hba *phba = iscsi_host_priv(shost); \
+       uint32_t param_val = 0; \
+       param_val = phba->attr_##_name;\
+       return snprintf(buf, PAGE_SIZE, "%d\n",\
+                       phba->attr_##_name);\
+}
+
+#define beiscsi_change_param(_name, _minval, _maxval, _defaval)\
+int \
+beiscsi_##_name##_change(struct beiscsi_hba *phba, uint32_t val)\
+{\
+       if (val >= _minval && val <= _maxval) {\
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,\
+                           "BA_%d : beiscsi_"#_name" updated "\
+                           "from 0x%x ==> 0x%x\n",\
+                           phba->attr_##_name, val); \
+               phba->attr_##_name = val;\
+               return 0;\
+       } \
+       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT, \
+                   "BA_%d beiscsi_"#_name" attribute "\
+                   "cannot be updated to 0x%x, "\
+                   "range allowed is ["#_minval" - "#_maxval"]\n", val);\
+               return -EINVAL;\
+}
+
+#define beiscsi_store_param(_name)  \
+ssize_t \
+beiscsi_##_name##_store(struct device *dev,\
+                        struct device_attribute *attr, const char *buf,\
+                        size_t count) \
+{ \
+       struct Scsi_Host  *shost = class_to_shost(dev);\
+       struct beiscsi_hba *phba = iscsi_host_priv(shost);\
+       uint32_t param_val = 0;\
+       if (!isdigit(buf[0]))\
+               return -EINVAL;\
+       if (sscanf(buf, "%i", ¶m_val) != 1)\
+               return -EINVAL;\
+       if (beiscsi_##_name##_change(phba, param_val) == 0) \
+               return strlen(buf);\
+       else \
+               return -EINVAL;\
+}
+
+#define beiscsi_init_param(_name, _minval, _maxval, _defval) \
+int \
+beiscsi_##_name##_init(struct beiscsi_hba *phba, uint32_t val) \
+{ \
+       if (val >= _minval && val <= _maxval) {\
+               phba->attr_##_name = val;\
+               return 0;\
+       } \
+       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,\
+                   "BA_%d beiscsi_"#_name" attribute " \
+                   "cannot be updated to 0x%x, "\
+                   "range allowed is ["#_minval" - "#_maxval"]\n", val);\
+       phba->attr_##_name = _defval;\
+       return -EINVAL;\
+}
+
+#define BEISCSI_RW_ATTR(_name, _minval, _maxval, _defval, _descp) \
+static uint beiscsi_##_name = _defval;\
+module_param(beiscsi_##_name, uint, S_IRUGO);\
+MODULE_PARM_DESC(beiscsi_##_name, _descp);\
+beiscsi_disp_param(_name)\
+beiscsi_change_param(_name, _minval, _maxval, _defval)\
+beiscsi_store_param(_name)\
+beiscsi_init_param(_name, _minval, _maxval, _defval)\
+DEVICE_ATTR(beiscsi_##_name, S_IRUGO | S_IWUSR,\
+             beiscsi_##_name##_disp, beiscsi_##_name##_store)
+
+/*
+ * When new log level added update the
+ * the MAX allowed value for log_enable
+ */
+BEISCSI_RW_ATTR(log_enable, 0x00,
+               0xFF, 0x00, "Enable logging Bit Mask\n"
+               "\t\t\t\tInitialization Events  : 0x01\n"
+               "\t\t\t\tMailbox Events         : 0x02\n"
+               "\t\t\t\tMiscellaneous Events   : 0x04\n"
+               "\t\t\t\tError Handling         : 0x08\n"
+               "\t\t\t\tIO Path Events         : 0x10\n"
+               "\t\t\t\tConfiguration Path     : 0x20\n");
+
+struct device_attribute *beiscsi_attrs[] = {
+       &dev_attr_beiscsi_log_enable,
+       NULL,
+};
 
 static int beiscsi_slave_configure(struct scsi_device *sdev)
 {
                                sizeof(struct invalidate_commands_params_in),
                                &nonemb_cmd.dma);
        if (nonemb_cmd.va == NULL) {
-               SE_DEBUG(DBG_LVL_1,
-                        "Failed to allocate memory for"
-                        "mgmt_invalidate_icds\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_EH,
+                           "BM_%d : Failed to allocate memory for"
+                           "mgmt_invalidate_icds\n");
                return FAILED;
        }
        nonemb_cmd.size = sizeof(struct invalidate_commands_params_in);
        tag = mgmt_invalidate_icds(phba, inv_tbl, num_invalidate,
                                   cid, &nonemb_cmd);
        if (!tag) {
-               shost_printk(KERN_WARNING, phba->shost,
-                            "mgmt_invalidate_icds could not be"
-                            " submitted\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_EH,
+                           "BM_%d : mgmt_invalidate_icds could not be"
+                           "submitted\n");
                pci_free_consistent(phba->ctrl.pdev, nonemb_cmd.size,
                                    nonemb_cmd.va, nonemb_cmd.dma);
 
                                sizeof(struct invalidate_commands_params_in),
                                &nonemb_cmd.dma);
        if (nonemb_cmd.va == NULL) {
-               SE_DEBUG(DBG_LVL_1,
-                        "Failed to allocate memory for"
-                        "mgmt_invalidate_icds\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_EH,
+                           "BM_%d : Failed to allocate memory for"
+                           "mgmt_invalidate_icds\n");
                return FAILED;
        }
        nonemb_cmd.size = sizeof(struct invalidate_commands_params_in);
        tag = mgmt_invalidate_icds(phba, inv_tbl, num_invalidate,
                                   cid, &nonemb_cmd);
        if (!tag) {
-               shost_printk(KERN_WARNING, phba->shost,
-                            "mgmt_invalidate_icds could not be"
-                            " submitted\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_EH,
+                           "BM_%d : mgmt_invalidate_icds could not be"
+                           " submitted\n");
                pci_free_consistent(phba->ctrl.pdev, nonemb_cmd.size,
                                    nonemb_cmd.va, nonemb_cmd.dma);
                return FAILED;
 };
 MODULE_DEVICE_TABLE(pci, beiscsi_pci_id_table);
 
+
 static struct scsi_host_template beiscsi_sht = {
        .module = THIS_MODULE,
        .name = "Emulex 10Gbe open-iscsi Initiator Driver",
        .eh_abort_handler = beiscsi_eh_abort,
        .eh_device_reset_handler = beiscsi_eh_device_reset,
        .eh_target_reset_handler = iscsi_eh_session_reset,
+       .shost_attrs = beiscsi_attrs,
        .sg_tablesize = BEISCSI_SGLIST_ELEMENTS,
        .can_queue = BE2_IO_DEPTH,
        .this_id = -1,
 
        shost = iscsi_host_alloc(&beiscsi_sht, sizeof(*phba), 0);
        if (!shost) {
-               dev_err(&pcidev->dev, "beiscsi_hba_alloc -"
-                       "iscsi_host_alloc failed\n");
+               dev_err(&pcidev->dev,
+                       "beiscsi_hba_alloc - iscsi_host_alloc failed\n");
                return NULL;
        }
        shost->dma_boundary = pcidev->dma_mask;
 
        ret = pci_enable_device(pcidev);
        if (ret) {
-               dev_err(&pcidev->dev, "beiscsi_enable_pci - enable device "
-                       "failed. Returning -ENODEV\n");
+               dev_err(&pcidev->dev,
+                       "beiscsi_enable_pci - enable device failed\n");
                return ret;
        }
 
                                    + BE2_TMFS) / 512) + 1) * 512;
        phba->params.num_eq_entries = (phba->params.num_eq_entries < 1024)
                                ? 1024 : phba->params.num_eq_entries;
-       SE_DEBUG(DBG_LVL_8, "phba->params.num_eq_entries=%d\n",
-                            phba->params.num_eq_entries);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                   "BM_%d : phba->params.num_eq_entries=%d\n",
+                   phba->params.num_eq_entries);
        phba->params.num_cq_entries =
            (((BE2_CMDS_PER_CXN * 2 +  phba->fw_config.iscsi_cid_count * 2
                                    + BE2_TMFS) / 512) + 1) * 512;
        phba =  pbe_eq->phba;
        mcc = &phba->ctrl.mcc_obj.cq;
        eqe = queue_tail_node(eq);
-       if (!eqe)
-               SE_DEBUG(DBG_LVL_1, "eqe is NULL\n");
 
        num_eq_processed = 0;
 
        eq = &pbe_eq->q;
        cq = pbe_eq->cq;
        eqe = queue_tail_node(eq);
-       if (!eqe)
-               SE_DEBUG(DBG_LVL_1, "eqe is NULL\n");
 
        phba = pbe_eq->phba;
        num_eq_processed = 0;
        mcc = &phba->ctrl.mcc_obj.cq;
        index = 0;
        eqe = queue_tail_node(eq);
-       if (!eqe)
-               SE_DEBUG(DBG_LVL_1, "eqe is NULL\n");
 
        num_ioeq_processed = 0;
        num_mcceq_processed = 0;
                                          phba->msi_name[i],
                                          &phwi_context->be_eq[i]);
                        if (ret) {
-                               shost_printk(KERN_ERR, phba->shost,
-                                            "beiscsi_init_irqs-Failed to"
-                                            "register msix for i = %d\n", i);
+                               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                           "BM_%d : beiscsi_init_irqs-Failed to"
+                                           "register msix for i = %d\n",
+                                           i);
                                kfree(phba->msi_name[i]);
                                goto free_msix_irqs;
                        }
                ret = request_irq(msix_vec, be_isr_mcc, 0, phba->msi_name[i],
                                  &phwi_context->be_eq[i]);
                if (ret) {
-                       shost_printk(KERN_ERR, phba->shost, "beiscsi_init_irqs-"
-                                    "Failed to register beiscsi_msix_mcc\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT ,
+                                   "BM_%d : beiscsi_init_irqs-"
+                                   "Failed to register beiscsi_msix_mcc\n");
                        kfree(phba->msi_name[i]);
                        goto free_msix_irqs;
                }
                ret = request_irq(pcidev->irq, be_isr, IRQF_SHARED,
                                  "beiscsi", phba);
                if (ret) {
-                       shost_printk(KERN_ERR, phba->shost, "beiscsi_init_irqs-"
-                                    "Failed to register irq\\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : beiscsi_init_irqs-"
+                                   "Failed to register irq\\n");
                        return ret;
                }
        }
        case ISCSI_OP_REJECT:
                WARN_ON(!pbuffer);
                WARN_ON(!(buf_len == 48));
-               SE_DEBUG(DBG_LVL_1, "In ISCSI_OP_REJECT\n");
+               beiscsi_log(phba, KERN_ERR,
+                           BEISCSI_LOG_CONFIG | BEISCSI_LOG_IO,
+                           "BM_%d : In ISCSI_OP_REJECT\n");
                break;
        case ISCSI_OP_LOGIN_RSP:
        case ISCSI_OP_TEXT_RSP:
                login_hdr->itt = io_task->libiscsi_itt;
                break;
        default:
-               shost_printk(KERN_WARNING, phba->shost,
-                            "Unrecognized opcode 0x%x in async msg\n",
-                            (ppdu->
+               beiscsi_log(phba, KERN_WARNING,
+                           BEISCSI_LOG_IO | BEISCSI_LOG_CONFIG,
+                           "BM_%d : Unrecognized opcode 0x%x in async msg\n",
+                           (ppdu->
                             dw[offsetof(struct amap_pdu_base, opcode) / 32]
-                                               & PDUBASE_OPCODE_MASK));
+                            & PDUBASE_OPCODE_MASK));
                return 1;
        }
 
        struct sgl_handle *psgl_handle;
 
        if (phba->io_sgl_hndl_avbl) {
-               SE_DEBUG(DBG_LVL_8,
-                        "In alloc_io_sgl_handle,io_sgl_alloc_index=%d\n",
-                        phba->io_sgl_alloc_index);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_IO,
+                           "BM_%d : In alloc_io_sgl_handle,"
+                           " io_sgl_alloc_index=%d\n",
+                           phba->io_sgl_alloc_index);
+
                psgl_handle = phba->io_sgl_hndl_base[phba->
                                                io_sgl_alloc_index];
                phba->io_sgl_hndl_base[phba->io_sgl_alloc_index] = NULL;
 static void
 free_io_sgl_handle(struct beiscsi_hba *phba, struct sgl_handle *psgl_handle)
 {
-       SE_DEBUG(DBG_LVL_8, "In free_,io_sgl_free_index=%d\n",
-                phba->io_sgl_free_index);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_IO,
+                   "BM_%d : In free_,io_sgl_free_index=%d\n",
+                   phba->io_sgl_free_index);
+
        if (phba->io_sgl_hndl_base[phba->io_sgl_free_index]) {
                /*
                 * this can happen if clean_task is called on a task that
                 * failed in xmit_task or alloc_pdu.
                 */
-                SE_DEBUG(DBG_LVL_8,
-                        "Double Free in IO SGL io_sgl_free_index=%d,"
-                        "value there=%p\n", phba->io_sgl_free_index,
-                        phba->io_sgl_hndl_base[phba->io_sgl_free_index]);
+                beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_IO,
+                            "BM_%d : Double Free in IO SGL io_sgl_free_index=%d,"
+                            "value there=%p\n", phba->io_sgl_free_index,
+                            phba->io_sgl_hndl_base
+                            [phba->io_sgl_free_index]);
                return;
        }
        phba->io_sgl_hndl_base[phba->io_sgl_free_index] = psgl_handle;
        else
                pwrb_context->free_index++;
 
-       SE_DEBUG(DBG_LVL_8,
-                "FREE WRB: pwrb_handle=%p free_index=0x%x"
-                "wrb_handles_available=%d\n",
-                pwrb_handle, pwrb_context->free_index,
-                pwrb_context->wrb_handles_available);
+       beiscsi_log(phba, KERN_INFO,
+                   BEISCSI_LOG_IO | BEISCSI_LOG_CONFIG,
+                   "BM_%d : FREE WRB: pwrb_handle=%p free_index=0x%x"
+                   "wrb_handles_available=%d\n",
+                   pwrb_handle, pwrb_context->free_index,
+                   pwrb_context->wrb_handles_available);
 }
 
 static struct sgl_handle *alloc_mgmt_sgl_handle(struct beiscsi_hba *phba)
        if (phba->eh_sgl_hndl_avbl) {
                psgl_handle = phba->eh_sgl_hndl_base[phba->eh_sgl_alloc_index];
                phba->eh_sgl_hndl_base[phba->eh_sgl_alloc_index] = NULL;
-               SE_DEBUG(DBG_LVL_8, "mgmt_sgl_alloc_index=%d=0x%x\n",
-                        phba->eh_sgl_alloc_index, phba->eh_sgl_alloc_index);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                           "BM_%d : mgmt_sgl_alloc_index=%d=0x%x\n",
+                           phba->eh_sgl_alloc_index,
+                           phba->eh_sgl_alloc_index);
+
                phba->eh_sgl_hndl_avbl--;
                if (phba->eh_sgl_alloc_index ==
                    (phba->params.icds_per_ctrl - phba->params.ios_per_ctrl -
 free_mgmt_sgl_handle(struct beiscsi_hba *phba, struct sgl_handle *psgl_handle)
 {
 
-       SE_DEBUG(DBG_LVL_8, "In  free_mgmt_sgl_handle,eh_sgl_free_index=%d\n",
-                            phba->eh_sgl_free_index);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BM_%d : In  free_mgmt_sgl_handle,"
+                   "eh_sgl_free_index=%d\n",
+                   phba->eh_sgl_free_index);
+
        if (phba->eh_sgl_hndl_base[phba->eh_sgl_free_index]) {
                /*
                 * this can happen if clean_task is called on a task that
                 * failed in xmit_task or alloc_pdu.
                 */
-               SE_DEBUG(DBG_LVL_8,
-                        "Double Free in eh SGL ,eh_sgl_free_index=%d\n",
-                        phba->eh_sgl_free_index);
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_CONFIG,
+                           "BM_%d : Double Free in eh SGL ,"
+                           "eh_sgl_free_index=%d\n",
+                           phba->eh_sgl_free_index);
                return;
        }
        phba->eh_sgl_hndl_base[phba->eh_sgl_free_index] = psgl_handle;
                break;
 
        case HWH_TYPE_LOGIN:
-               SE_DEBUG(DBG_LVL_1,
-                        "\t\t No HWH_TYPE_LOGIN Expected in hwi_complete_cmd"
-                        "- Solicited path\n");
+               beiscsi_log(phba, KERN_ERR,
+                           BEISCSI_LOG_CONFIG | BEISCSI_LOG_IO,
+                           "BM_%d :\t\t No HWH_TYPE_LOGIN Expected in"
+                           " hwi_complete_cmd- Solicited path\n");
                break;
 
        case HWH_TYPE_NOP:
                break;
 
        default:
-               shost_printk(KERN_WARNING, phba->shost,
-                               "In hwi_complete_cmd, unknown type = %d"
-                               "wrb_index 0x%x CID 0x%x\n", type,
-                               ((psol->dw[offsetof(struct amap_iscsi_wrb,
-                               type) / 32] & SOL_WRB_INDEX_MASK) >> 16),
-                               ((psol->dw[offsetof(struct amap_sol_cqe,
-                               cid) / 32] & SOL_CID_MASK) >> 6));
+               beiscsi_log(phba, KERN_WARNING,
+                           BEISCSI_LOG_CONFIG | BEISCSI_LOG_IO,
+                           "BM_%d : In hwi_complete_cmd, unknown type = %d"
+                           "wrb_index 0x%x CID 0x%x\n", type,
+                           ((psol->dw[offsetof(struct amap_iscsi_wrb,
+                           type) / 32] & SOL_WRB_INDEX_MASK) >> 16),
+                           ((psol->dw[offsetof(struct amap_sol_cqe,
+                           cid) / 32] & SOL_CID_MASK) >> 6));
                break;
        }
 
                break;
        default:
                pbusy_list = NULL;
-               shost_printk(KERN_WARNING, phba->shost,
-                       "Unexpected code=%d\n",
-                        pdpdu_cqe->dw[offsetof(struct amap_i_t_dpdu_cqe,
-                                       code) / 32] & PDUCQE_CODE_MASK);
+               beiscsi_log(phba, KERN_WARNING,
+                           BEISCSI_LOG_IO | BEISCSI_LOG_CONFIG,
+                           "BM_%d : Unexpected code=%d\n",
+                           pdpdu_cqe->dw[offsetof(struct amap_i_t_dpdu_cqe,
+                           code) / 32] & PDUCQE_CODE_MASK);
                return NULL;
        }
 
 }
 
 static unsigned int
-hwi_update_async_writables(struct hwi_async_pdu_context *pasync_ctx,
-                          unsigned int is_header, unsigned int cq_index)
+hwi_update_async_writables(struct beiscsi_hba *phba,
+                           struct hwi_async_pdu_context *pasync_ctx,
+                           unsigned int is_header, unsigned int cq_index)
 {
        struct list_head *pbusy_list;
        struct async_pdu_handle *pasync_handle;
        }
 
        if (!writables) {
-               SE_DEBUG(DBG_LVL_1,
-                        "Duplicate notification received - index 0x%x!!\n",
-                        cq_index);
+               beiscsi_log(phba, KERN_ERR,
+                           BEISCSI_LOG_CONFIG | BEISCSI_LOG_IO,
+                           "BM_%d : Duplicate notification received - index 0x%x!!\n",
+                           cq_index);
                WARN_ON(1);
        }
 
                                             pdpdu_cqe, &cq_index);
        BUG_ON(pasync_handle->is_header != 0);
        if (pasync_handle->consumed == 0)
-               hwi_update_async_writables(pasync_ctx, pasync_handle->is_header,
-                                          cq_index);
+               hwi_update_async_writables(phba, pasync_ctx,
+                                          pasync_handle->is_header, cq_index);
 
        hwi_free_async_msg(phba, pasync_handle->cri);
        hwi_post_async_buffers(phba, pasync_handle->is_header);
                                             pdpdu_cqe, &cq_index);
 
        if (pasync_handle->consumed == 0)
-               hwi_update_async_writables(pasync_ctx, pasync_handle->is_header,
-                                          cq_index);
+               hwi_update_async_writables(phba, pasync_ctx,
+                                          pasync_handle->is_header, cq_index);
+
        hwi_gather_async_pdu(beiscsi_conn, phba, pasync_handle);
        hwi_post_async_buffers(phba, pasync_handle->is_header);
 }
                                beiscsi_async_link_state_process(phba,
                                (struct be_async_event_link_state *) mcc_compl);
                        else
-                               SE_DEBUG(DBG_LVL_1,
-                                       " Unsupported Async Event, flags"
-                                       " = 0x%08x\n", mcc_compl->flags);
+                               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_MBOX,
+                                           "BM_%d :  Unsupported Async Event, flags"
+                                           " = 0x%08x\n",
+                                           mcc_compl->flags);
                } else if (mcc_compl->flags & CQE_FLAGS_COMPLETED_MASK) {
                        be_mcc_compl_process_isr(&phba->ctrl, mcc_compl);
                        atomic_dec(&phba->ctrl.mcc_obj.q.used);
                        hwi_complete_cmd(beiscsi_conn, phba, sol);
                        break;
                case DRIVERMSG_NOTIFY:
-                       SE_DEBUG(DBG_LVL_8, "Received DRIVERMSG_NOTIFY\n");
+                       beiscsi_log(phba, KERN_INFO,
+                                   BEISCSI_LOG_IO | BEISCSI_LOG_CONFIG,
+                                   "BM_%d : Received DRIVERMSG_NOTIFY\n");
+
                        dmsg = (struct dmsg_cqe *)sol;
                        hwi_complete_drvr_msgs(beiscsi_conn, phba, sol);
                        break;
                case UNSOL_HDR_NOTIFY:
-                       SE_DEBUG(DBG_LVL_8, "Received UNSOL_HDR_ NOTIFY\n");
+                       beiscsi_log(phba, KERN_INFO,
+                                   BEISCSI_LOG_IO | BEISCSI_LOG_CONFIG,
+                                   "BM_%d : Received UNSOL_HDR_ NOTIFY\n");
+
                        hwi_process_default_pdu_ring(beiscsi_conn, phba,
                                             (struct i_t_dpdu_cqe *)sol);
                        break;
                case UNSOL_DATA_NOTIFY:
-                       SE_DEBUG(DBG_LVL_8, "Received UNSOL_DATA_NOTIFY\n");
+                       beiscsi_log(phba, KERN_INFO,
+                                   BEISCSI_LOG_CONFIG | BEISCSI_LOG_IO,
+                                   "BM_%d : Received UNSOL_DATA_NOTIFY\n");
+
                        hwi_process_default_pdu_ring(beiscsi_conn, phba,
                                             (struct i_t_dpdu_cqe *)sol);
                        break;
                case CXN_INVALIDATE_INDEX_NOTIFY:
                case CMD_INVALIDATED_NOTIFY:
                case CXN_INVALIDATE_NOTIFY:
-                       SE_DEBUG(DBG_LVL_1,
-                                "Ignoring CQ Error notification for cmd/cxn"
-                                "invalidate\n");
+                       beiscsi_log(phba, KERN_ERR,
+                                   BEISCSI_LOG_IO | BEISCSI_LOG_CONFIG,
+                                   "BM_%d : Ignoring CQ Error notification for"
+                                   " cmd/cxn invalidate\n");
                        break;
                case SOL_CMD_KILLED_DATA_DIGEST_ERR:
                case CMD_KILLED_INVALID_STATSN_RCVD:
                case CMD_CXN_KILLED_ITT_INVALID:
                case CMD_CXN_KILLED_SEQ_OUTOFORDER:
                case CMD_CXN_KILLED_INVALID_DATASN_RCVD:
-                       SE_DEBUG(DBG_LVL_1,
-                                "CQ Error notification for cmd.. "
-                                "code %d cid 0x%x\n",
-                                sol->dw[offsetof(struct amap_sol_cqe, code) /
-                                32] & CQE_CODE_MASK,
-                                (sol->dw[offsetof(struct amap_sol_cqe, cid) /
-                                32] & SOL_CID_MASK));
+                       beiscsi_log(phba, KERN_ERR,
+                                   BEISCSI_LOG_CONFIG | BEISCSI_LOG_IO,
+                                   "BM_%d : CQ Error notification for cmd.. "
+                                   "code %d cid 0x%x\n",
+                                   sol->dw[offsetof(struct amap_sol_cqe,
+                                   code) / 32] & CQE_CODE_MASK,
+                                   sol->dw[offsetof(struct amap_sol_cqe,
+                                   cid) / 32] & SOL_CID_MASK);
                        break;
                case UNSOL_DATA_DIGEST_ERROR_NOTIFY:
-                       SE_DEBUG(DBG_LVL_1,
-                                "Digest error on def pdu ring, dropping..\n");
+                       beiscsi_log(phba, KERN_ERR,
+                                   BEISCSI_LOG_IO | BEISCSI_LOG_CONFIG,
+                                   "BM_%d : Digest error on def pdu ring,"
+                                   " dropping..\n");
                        hwi_flush_default_pdu_buffer(phba, beiscsi_conn,
                                             (struct i_t_dpdu_cqe *) sol);
                        break;
                case CXN_KILLED_OVER_RUN_RESIDUAL:
                case CXN_KILLED_UNDER_RUN_RESIDUAL:
                case CXN_KILLED_CMND_DATA_NOT_ON_SAME_CONN:
-                       SE_DEBUG(DBG_LVL_1, "CQ Error %d, reset CID "
-                                "0x%x...\n",
-                                sol->dw[offsetof(struct amap_sol_cqe, code) /
-                                32] & CQE_CODE_MASK,
-                                (sol->dw[offsetof(struct amap_sol_cqe, cid) /
-                                32] & CQE_CID_MASK));
+                       beiscsi_log(phba, KERN_ERR,
+                                   BEISCSI_LOG_IO | BEISCSI_LOG_CONFIG,
+                                   "BM_%d : CQ Error %d, reset CID 0x%x...\n",
+                                   sol->dw[offsetof(struct amap_sol_cqe,
+                                   code) / 32] & CQE_CODE_MASK,
+                                   sol->dw[offsetof(struct amap_sol_cqe,
+                                   cid) / 32] & CQE_CID_MASK);
                        iscsi_conn_failure(beiscsi_conn->conn,
                                           ISCSI_ERR_CONN_FAILED);
                        break;
                case CXN_KILLED_RST_SENT:
                case CXN_KILLED_RST_RCVD:
-                       SE_DEBUG(DBG_LVL_1, "CQ Error %d, reset"
-                               "received/sent on CID 0x%x...\n",
-                                sol->dw[offsetof(struct amap_sol_cqe, code) /
-                                32] & CQE_CODE_MASK,
-                                (sol->dw[offsetof(struct amap_sol_cqe, cid) /
-                                32] & CQE_CID_MASK));
+                       beiscsi_log(phba, KERN_ERR,
+                                   BEISCSI_LOG_IO | BEISCSI_LOG_CONFIG,
+                                   "BM_%d : CQ Error %d, reset"
+                                   "received/sent on CID 0x%x...\n",
+                                   sol->dw[offsetof(struct amap_sol_cqe,
+                                       code) / 32] & CQE_CODE_MASK,
+                                   sol->dw[offsetof(struct amap_sol_cqe,
+                                       cid) / 32] & CQE_CID_MASK);
                        iscsi_conn_failure(beiscsi_conn->conn,
                                           ISCSI_ERR_CONN_FAILED);
                        break;
                default:
-                       SE_DEBUG(DBG_LVL_1, "CQ Error Invalid code= %d "
-                                "received on CID 0x%x...\n",
-                                sol->dw[offsetof(struct amap_sol_cqe, code) /
-                                32] & CQE_CODE_MASK,
-                                (sol->dw[offsetof(struct amap_sol_cqe, cid) /
-                                32] & CQE_CID_MASK));
+                       beiscsi_log(phba, KERN_ERR,
+                                   BEISCSI_LOG_IO | BEISCSI_LOG_CONFIG,
+                                   "BM_%d : CQ Error Invalid code= %d "
+                                   "received on CID 0x%x...\n",
+                                   sol->dw[offsetof(struct amap_sol_cqe,
+                                   code) / 32] & CQE_CODE_MASK,
+                                   sol->dw[offsetof(struct amap_sol_cqe,
+                                   cid) / 32] & CQE_CID_MASK);
                        break;
                }
 
        if (ret < budget) {
                phba = pbe_eq->phba;
                blk_iopoll_complete(iop);
-               SE_DEBUG(DBG_LVL_8, "rearm pbe_eq->q.id =%d\n", pbe_eq->q.id);
+               beiscsi_log(phba, KERN_INFO,
+                           BEISCSI_LOG_CONFIG | BEISCSI_LOG_IO,
+                           "BM_%d : rearm pbe_eq->q.id =%d\n",
+                           pbe_eq->q.id);
                hwi_ring_eq_db(phba, pbe_eq->q.id, 0, 0, 1, 1);
        }
        return ret;
                                kzalloc(sizeof(struct wrb_handle *) *
                                        phba->params.wrbs_per_cxn, GFP_KERNEL);
                if (!pwrb_context->pwrb_handle_base) {
-                       shost_printk(KERN_ERR, phba->shost,
-                                       "Mem Alloc Failed. Failing to load\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : Mem Alloc Failed. Failing to load\n");
                        goto init_wrb_hndl_failed;
                }
                pwrb_context->pwrb_handle_basestd =
                                kzalloc(sizeof(struct wrb_handle *) *
                                        phba->params.wrbs_per_cxn, GFP_KERNEL);
                if (!pwrb_context->pwrb_handle_basestd) {
-                       shost_printk(KERN_ERR, phba->shost,
-                                       "Mem Alloc Failed. Failing to load\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : Mem Alloc Failed. Failing to load\n");
                        goto init_wrb_hndl_failed;
                }
                if (!num_cxn_wrbh) {
        mem_descr = (struct be_mem_descriptor *)phba->init_mem;
        mem_descr += HWI_MEM_ASYNC_HEADER_BUF;
        if (mem_descr->mem_array[0].virtual_address) {
-               SE_DEBUG(DBG_LVL_8,
-                        "hwi_init_async_pdu_ctx HWI_MEM_ASYNC_HEADER_BUF"
-                        "va=%p\n", mem_descr->mem_array[0].virtual_address);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BM_%d : hwi_init_async_pdu_ctx"
+                           " HWI_MEM_ASYNC_HEADER_BUF va=%p\n",
+                           mem_descr->mem_array[0].virtual_address);
        } else
-               shost_printk(KERN_WARNING, phba->shost,
-                            "No Virtual address\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_INIT,
+                           "BM_%d : No Virtual address\n");
 
        pasync_ctx->async_header.va_base =
                        mem_descr->mem_array[0].virtual_address;
        mem_descr = (struct be_mem_descriptor *)phba->init_mem;
        mem_descr += HWI_MEM_ASYNC_HEADER_RING;
        if (mem_descr->mem_array[0].virtual_address) {
-               SE_DEBUG(DBG_LVL_8,
-                        "hwi_init_async_pdu_ctx HWI_MEM_ASYNC_HEADER_RING"
-                        "va=%p\n", mem_descr->mem_array[0].virtual_address);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BM_%d : hwi_init_async_pdu_ctx"
+                           " HWI_MEM_ASYNC_HEADER_RING va=%p\n",
+                           mem_descr->mem_array[0].virtual_address);
        } else
-               shost_printk(KERN_WARNING, phba->shost,
-                           "No Virtual address\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_INIT,
+                           "BM_%d : No Virtual address\n");
+
        pasync_ctx->async_header.ring_base =
                        mem_descr->mem_array[0].virtual_address;
 
        mem_descr = (struct be_mem_descriptor *)phba->init_mem;
        mem_descr += HWI_MEM_ASYNC_HEADER_HANDLE;
        if (mem_descr->mem_array[0].virtual_address) {
-               SE_DEBUG(DBG_LVL_8,
-                        "hwi_init_async_pdu_ctx HWI_MEM_ASYNC_HEADER_HANDLE"
-                        "va=%p\n", mem_descr->mem_array[0].virtual_address);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BM_%d : hwi_init_async_pdu_ctx"
+                           " HWI_MEM_ASYNC_HEADER_HANDLE va=%p\n",
+                           mem_descr->mem_array[0].virtual_address);
        } else
-               shost_printk(KERN_WARNING, phba->shost,
-                           "No Virtual address\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_INIT,
+                           "BM_%d : No Virtual address\n");
 
        pasync_ctx->async_header.handle_base =
                        mem_descr->mem_array[0].virtual_address;
        mem_descr = (struct be_mem_descriptor *)phba->init_mem;
        mem_descr += HWI_MEM_ASYNC_DATA_RING;
        if (mem_descr->mem_array[0].virtual_address) {
-               SE_DEBUG(DBG_LVL_8,
-                        "hwi_init_async_pdu_ctx HWI_MEM_ASYNC_DATA_RING"
-                        "va=%p\n", mem_descr->mem_array[0].virtual_address);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BM_%d : hwi_init_async_pdu_ctx"
+                           " HWI_MEM_ASYNC_DATA_RING va=%p\n",
+                           mem_descr->mem_array[0].virtual_address);
        } else
-               shost_printk(KERN_WARNING, phba->shost,
-                            "No Virtual address\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_INIT,
+                           "BM_%d : No Virtual address\n");
 
        pasync_ctx->async_data.ring_base =
                        mem_descr->mem_array[0].virtual_address;
        mem_descr = (struct be_mem_descriptor *)phba->init_mem;
        mem_descr += HWI_MEM_ASYNC_DATA_HANDLE;
        if (!mem_descr->mem_array[0].virtual_address)
-               shost_printk(KERN_WARNING, phba->shost,
-                           "No Virtual address\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_INIT,
+                           "BM_%d : No Virtual address\n");
 
        pasync_ctx->async_data.handle_base =
                        mem_descr->mem_array[0].virtual_address;
        mem_descr = (struct be_mem_descriptor *)phba->init_mem;
        mem_descr += HWI_MEM_ASYNC_DATA_BUF;
        if (mem_descr->mem_array[0].virtual_address) {
-               SE_DEBUG(DBG_LVL_8,
-                        "hwi_init_async_pdu_ctx HWI_MEM_ASYNC_DATA_BUF"
-                        "va=%p\n", mem_descr->mem_array[0].virtual_address);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BM_%d : hwi_init_async_pdu_ctx"
+                           " HWI_MEM_ASYNC_DATA_BUF va=%p\n",
+                           mem_descr->mem_array[0].virtual_address);
        } else
-               shost_printk(KERN_WARNING, phba->shost,
-                           "No Virtual address\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_INIT,
+                           "BM_%d : No Virtual address\n");
+
        idx = 0;
        pasync_ctx->async_data.va_base =
                        mem_descr->mem_array[idx].virtual_address;
                             struct hwi_context_memory *phwi_context)
 {
        unsigned int i, num_eq_pages;
-       int ret, eq_for_mcc;
+       int ret = 0, eq_for_mcc;
        struct be_queue_info *eq;
        struct be_dma_mem *mem;
        void *eq_vaddress;
                ret = be_fill_queue(eq, phba->params.num_eq_entries,
                                    sizeof(struct be_eq_entry), eq_vaddress);
                if (ret) {
-                       shost_printk(KERN_ERR, phba->shost,
-                                    "be_fill_queue Failed for EQ\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : be_fill_queue Failed for EQ\n");
                        goto create_eq_error;
                }
 
                ret = beiscsi_cmd_eq_create(&phba->ctrl, eq,
                                            phwi_context->cur_eqd);
                if (ret) {
-                       shost_printk(KERN_ERR, phba->shost,
-                                    "beiscsi_cmd_eq_create"
-                                    "Failedfor EQ\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : beiscsi_cmd_eq_create"
+                                   "Failed for EQ\n");
                        goto create_eq_error;
                }
-               SE_DEBUG(DBG_LVL_8, "eqid = %d\n", phwi_context->be_eq[i].q.id);
+
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BM_%d : eqid = %d\n",
+                           phwi_context->be_eq[i].q.id);
        }
        return 0;
 create_eq_error:
                             struct hwi_context_memory *phwi_context)
 {
        unsigned int i, num_cq_pages;
-       int ret;
+       int ret = 0;
        struct be_queue_info *cq, *eq;
        struct be_dma_mem *mem;
        struct be_eq_obj *pbe_eq;
                ret = be_fill_queue(cq, phba->params.num_cq_entries,
                                    sizeof(struct sol_cqe), cq_vaddress);
                if (ret) {
-                       shost_printk(KERN_ERR, phba->shost,
-                                    "be_fill_queue Failed for ISCSI CQ\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : be_fill_queue Failed "
+                                   "for ISCSI CQ\n");
                        goto create_cq_error;
                }
 
                ret = beiscsi_cmd_cq_create(&phba->ctrl, cq, eq, false,
                                            false, 0);
                if (ret) {
-                       shost_printk(KERN_ERR, phba->shost,
-                                    "beiscsi_cmd_eq_create"
-                                    "Failed for ISCSI CQ\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : beiscsi_cmd_eq_create"
+                                   "Failed for ISCSI CQ\n");
                        goto create_cq_error;
                }
-               SE_DEBUG(DBG_LVL_8, "iscsi cq_id is %d for eq_id %d\n",
-                                                cq->id, eq->id);
-               SE_DEBUG(DBG_LVL_8, "ISCSI CQ CREATED\n");
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BM_%d : iscsi cq_id is %d for eq_id %d\n"
+                           "iSCSI CQ CREATED\n", cq->id, eq->id);
        }
        return 0;
 
                            sizeof(struct phys_addr),
                            sizeof(struct phys_addr), dq_vaddress);
        if (ret) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "be_fill_queue Failed for DEF PDU HDR\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : be_fill_queue Failed for DEF PDU HDR\n");
                return ret;
        }
        mem->dma = (unsigned long)mem_descr->mem_array[idx].
                                              def_pdu_ring_sz,
                                              phba->params.defpdu_hdr_sz);
        if (ret) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "be_cmd_create_default_pdu_queue Failed DEFHDR\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : be_cmd_create_default_pdu_queue Failed DEFHDR\n");
                return ret;
        }
        phwi_ctrlr->default_pdu_hdr.id = phwi_context->be_def_hdrq.id;
-       SE_DEBUG(DBG_LVL_8, "iscsi def pdu id is %d\n",
-                phwi_context->be_def_hdrq.id);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                   "BM_%d : iscsi def pdu id is %d\n",
+                   phwi_context->be_def_hdrq.id);
+
        hwi_post_async_buffers(phba, 1);
        return 0;
 }
                            sizeof(struct phys_addr),
                            sizeof(struct phys_addr), dq_vaddress);
        if (ret) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "be_fill_queue Failed for DEF PDU DATA\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : be_fill_queue Failed for DEF PDU DATA\n");
                return ret;
        }
        mem->dma = (unsigned long)mem_descr->mem_array[idx].
                                              def_pdu_ring_sz,
                                              phba->params.defpdu_data_sz);
        if (ret) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "be_cmd_create_default_pdu_queue Failed"
-                            " for DEF PDU DATA\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d be_cmd_create_default_pdu_queue"
+                           " Failed for DEF PDU DATA\n");
                return ret;
        }
        phwi_ctrlr->default_pdu_data.id = phwi_context->be_def_dataq.id;
-       SE_DEBUG(DBG_LVL_8, "iscsi def data id is %d\n",
-                phwi_context->be_def_dataq.id);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                   "BM_%d : iscsi def data id is %d\n",
+                   phwi_context->be_def_dataq.id);
+
        hwi_post_async_buffers(phba, 0);
-       SE_DEBUG(DBG_LVL_8, "DEFAULT PDU DATA RING CREATED\n");
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                   "BM_%d : DEFAULT PDU DATA RING CREATED\n");
+
        return 0;
 }
 
                                                (pm_arr->size / PAGE_SIZE));
                page_offset += pm_arr->size / PAGE_SIZE;
                if (status != 0) {
-                       shost_printk(KERN_ERR, phba->shost,
-                                    "post sgl failed.\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : post sgl failed.\n");
                        return status;
                }
                pm_arr++;
        }
-       SE_DEBUG(DBG_LVL_8, "POSTED PAGES\n");
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                   "BM_%d : POSTED PAGES\n");
        return 0;
 }
 
        pwrb_arr = kmalloc(sizeof(*pwrb_arr) * phba->params.cxns_per_ctrl,
                           GFP_KERNEL);
        if (!pwrb_arr) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "Memory alloc failed in create wrb ring.\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : Memory alloc failed in create wrb ring.\n");
                return -ENOMEM;
        }
        wrb_vaddr = mem_descr->mem_array[idx].virtual_address;
                status = be_cmd_wrbq_create(&phba->ctrl, &sgl,
                                            &phwi_context->be_wrbq[i]);
                if (status != 0) {
-                       shost_printk(KERN_ERR, phba->shost,
-                                    "wrbq create failed.");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : wrbq create failed.");
                        kfree(pwrb_arr);
                        return status;
                }
        if (num_cpus >= MAX_CPUS)
                num_cpus = MAX_CPUS - 1;
 
-       SE_DEBUG(DBG_LVL_8, "num_cpus = %d\n", num_cpus);
        return num_cpus;
 }
 
 
        status = beiscsi_create_eqs(phba, phwi_context);
        if (status != 0) {
-               shost_printk(KERN_ERR, phba->shost, "EQ not created\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : EQ not created\n");
                goto error;
        }
 
 
        status = mgmt_check_supported_fw(ctrl, phba);
        if (status != 0) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "Unsupported fw version\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : Unsupported fw version\n");
                goto error;
        }
 
        status = beiscsi_create_cqs(phba, phwi_context);
        if (status != 0) {
-               shost_printk(KERN_ERR, phba->shost, "CQ not created\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : CQ not created\n");
                goto error;
        }
 
        status = beiscsi_create_def_hdr(phba, phwi_context, phwi_ctrlr,
                                        def_pdu_ring_sz);
        if (status != 0) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "Default Header not created\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : Default Header not created\n");
                goto error;
        }
 
        status = beiscsi_create_def_data(phba, phwi_context,
                                         phwi_ctrlr, def_pdu_ring_sz);
        if (status != 0) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "Default Data not created\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : Default Data not created\n");
                goto error;
        }
 
        status = beiscsi_post_pages(phba);
        if (status != 0) {
-               shost_printk(KERN_ERR, phba->shost, "Post SGL Pages Failed\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : Post SGL Pages Failed\n");
                goto error;
        }
 
        status = beiscsi_create_wrb_rings(phba, phwi_context, phwi_ctrlr);
        if (status != 0) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "WRB Rings not created\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : WRB Rings not created\n");
                goto error;
        }
 
-       SE_DEBUG(DBG_LVL_8, "hwi_init_port success\n");
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                   "BM_%d : hwi_init_port success\n");
        return 0;
 
 error:
-       shost_printk(KERN_ERR, phba->shost, "hwi_init_port failed");
+       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                   "BM_%d : hwi_init_port failed");
        hwi_cleanup(phba);
        return status;
 }
        if (1 == phba->init_mem[HWI_MEM_ADDN_CONTEXT].num_elements) {
                phwi_ctrlr->phwi_ctxt = (struct hwi_context_memory *)phba->
                    init_mem[HWI_MEM_ADDN_CONTEXT].mem_array[0].virtual_address;
-               SE_DEBUG(DBG_LVL_8, " phwi_ctrlr->phwi_ctxt=%p\n",
-                        phwi_ctrlr->phwi_ctxt);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BM_%d :  phwi_ctrlr->phwi_ctxt=%p\n",
+                           phwi_ctrlr->phwi_ctxt);
        } else {
-               shost_printk(KERN_ERR, phba->shost,
-                            "HWI_MEM_ADDN_CONTEXT is more than one element."
-                            "Failing to load\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : HWI_MEM_ADDN_CONTEXT is more "
+                           "than one element.Failing to load\n");
                return -ENOMEM;
        }
 
 
        hwi_init_async_pdu_ctx(phba);
        if (hwi_init_port(phba) != 0) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "hwi_init_controller failed\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : hwi_init_controller failed\n");
+
                return -ENOMEM;
        }
        return 0;
 
        ret = beiscsi_get_memory(phba);
        if (ret < 0) {
-               shost_printk(KERN_ERR, phba->shost, "beiscsi_dev_probe -"
-                            "Failed in beiscsi_alloc_memory\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : beiscsi_dev_probe -"
+                           "Failed in beiscsi_alloc_memory\n");
                return ret;
        }
 
        ret = hwi_init_controller(phba);
        if (ret)
                goto free_init;
-       SE_DEBUG(DBG_LVL_8, "Return success from beiscsi_init_controller");
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                   "BM_%d : Return success from beiscsi_init_controller");
+
        return 0;
 
 free_init:
                                                 phba->params.ios_per_ctrl,
                                                 GFP_KERNEL);
                if (!phba->io_sgl_hndl_base) {
-                       shost_printk(KERN_ERR, phba->shost,
-                                    "Mem Alloc Failed. Failing to load\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : Mem Alloc Failed. Failing to load\n");
                        return -ENOMEM;
                }
                phba->eh_sgl_hndl_base = kzalloc(sizeof(struct sgl_handle *) *
                                                 GFP_KERNEL);
                if (!phba->eh_sgl_hndl_base) {
                        kfree(phba->io_sgl_hndl_base);
-                       shost_printk(KERN_ERR, phba->shost,
-                                    "Mem Alloc Failed. Failing to load\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : Mem Alloc Failed. Failing to load\n");
                        return -ENOMEM;
                }
        } else {
-               shost_printk(KERN_ERR, phba->shost,
-                            "HWI_MEM_SGLH is more than one element."
-                            "Failing to load\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : HWI_MEM_SGLH is more than one element."
+                           "Failing to load\n");
                return -ENOMEM;
        }
 
                }
                idx++;
        }
-       SE_DEBUG(DBG_LVL_8,
-                "phba->io_sgl_hndl_avbl=%d"
-                "phba->eh_sgl_hndl_avbl=%d\n",
-                phba->io_sgl_hndl_avbl,
-                phba->eh_sgl_hndl_avbl);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                   "BM_%d : phba->io_sgl_hndl_avbl=%d"
+                   "phba->eh_sgl_hndl_avbl=%d\n",
+                   phba->io_sgl_hndl_avbl,
+                   phba->eh_sgl_hndl_avbl);
+
        mem_descr_sg = phba->init_mem;
        mem_descr_sg += HWI_MEM_SGE;
-       SE_DEBUG(DBG_LVL_8, "\n mem_descr_sg->num_elements=%d\n",
-                mem_descr_sg->num_elements);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                   "\n BM_%d : mem_descr_sg->num_elements=%d\n",
+                   mem_descr_sg->num_elements);
+
        arr_index = 0;
        idx = 0;
        while (idx < mem_descr_sg->num_elements) {
        phba->cid_array = kzalloc(sizeof(void *) * phba->params.cxns_per_ctrl,
                                  GFP_KERNEL);
        if (!phba->cid_array) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "Failed to allocate memory in "
-                            "hba_setup_cid_tbls\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : Failed to allocate memory in "
+                           "hba_setup_cid_tbls\n");
                return -ENOMEM;
        }
        phba->ep_array = kzalloc(sizeof(struct iscsi_endpoint *) *
                                 phba->params.cxns_per_ctrl * 2, GFP_KERNEL);
        if (!phba->ep_array) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "Failed to allocate memory in "
-                            "hba_setup_cid_tbls\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : Failed to allocate memory in "
+                           "hba_setup_cid_tbls\n");
                kfree(phba->cid_array);
                return -ENOMEM;
        }
        enabled = reg & MEMBAR_CTRL_INT_CTRL_HOSTINTR_MASK;
        if (!enabled) {
                reg |= MEMBAR_CTRL_INT_CTRL_HOSTINTR_MASK;
-               SE_DEBUG(DBG_LVL_8, "reg =x%08x addr=%p\n", reg, addr);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BM_%d : reg =x%08x addr=%p\n", reg, addr);
                iowrite32(reg, addr);
        }
 
        if (!phba->msix_enabled) {
                eq = &phwi_context->be_eq[0].q;
-               SE_DEBUG(DBG_LVL_8, "eq->id=%d\n", eq->id);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BM_%d : eq->id=%d\n", eq->id);
+
                hwi_ring_eq_db(phba, eq->id, 0, 0, 1, 1);
        } else {
                for (i = 0; i <= phba->num_cpus; i++) {
                        eq = &phwi_context->be_eq[i].q;
-                       SE_DEBUG(DBG_LVL_8, "eq->id=%d\n", eq->id);
+                       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                                   "BM_%d : eq->id=%d\n", eq->id);
                        hwi_ring_eq_db(phba, eq->id, 0, 0, 1, 1);
                }
        }
                reg &= ~MEMBAR_CTRL_INT_CTRL_HOSTINTR_MASK;
                iowrite32(reg, addr);
        } else
-               shost_printk(KERN_WARNING, phba->shost,
-                            "In hwi_disable_intr, Already Disabled\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_INIT,
+                           "BM_%d : In hwi_disable_intr, Already Disabled\n");
 }
 
 /**
        /* Get the session handle of the boot target */
        ret = be_mgmt_get_boot_shandle(phba, &s_handle);
        if (ret) {
-               SE_DEBUG(DBG_LVL_1, "No boot session\n");
+               beiscsi_log(phba, KERN_ERR,
+                           BEISCSI_LOG_INIT | BEISCSI_LOG_CONFIG,
+                           "BM_%d : No boot session\n");
                return ret;
        }
        nonemb_cmd.va = pci_alloc_consistent(phba->ctrl.pdev,
                                sizeof(*session_resp),
                                &nonemb_cmd.dma);
        if (nonemb_cmd.va == NULL) {
-               SE_DEBUG(DBG_LVL_1,
-                        "Failed to allocate memory for"
-                        "beiscsi_get_session_info\n");
+               beiscsi_log(phba, KERN_ERR,
+                           BEISCSI_LOG_INIT | BEISCSI_LOG_CONFIG,
+                           "BM_%d : Failed to allocate memory for"
+                           "beiscsi_get_session_info\n");
+
                return -ENOMEM;
        }
 
        tag = mgmt_get_session_info(phba, s_handle,
                                    &nonemb_cmd);
        if (!tag) {
-               SE_DEBUG(DBG_LVL_1, "beiscsi_get_session_info"
-                       " Failed\n");
+               beiscsi_log(phba, KERN_ERR,
+                           BEISCSI_LOG_INIT | BEISCSI_LOG_CONFIG,
+                           "BM_%d : beiscsi_get_session_info"
+                           " Failed\n");
+
                goto boot_freemem;
        } else
                wait_event_interruptible(phba->ctrl.mcc_wait[tag],
        extd_status = (phba->ctrl.mcc_numtag[tag] & 0x0000FF00) >> 8;
        status = phba->ctrl.mcc_numtag[tag] & 0x000000FF;
        if (status || extd_status) {
-               SE_DEBUG(DBG_LVL_1, "beiscsi_get_session_info Failed"
-                                   " status = %d extd_status = %d\n",
-                                   status, extd_status);
+               beiscsi_log(phba, KERN_ERR,
+                           BEISCSI_LOG_INIT | BEISCSI_LOG_CONFIG,
+                           "BM_%d : beiscsi_get_session_info Failed"
+                           " status = %d extd_status = %d\n",
+                           status, extd_status);
+
                free_mcc_tag(&phba->ctrl, tag);
                goto boot_freemem;
        }
 
        ret = beiscsi_init_controller(phba);
        if (ret < 0) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "beiscsi_dev_probe - Failed in"
-                            "beiscsi_init_controller\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : beiscsi_dev_probe - Failed in"
+                           "beiscsi_init_controller\n");
                return ret;
        }
        ret = beiscsi_init_sgl_handle(phba);
        if (ret < 0) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "beiscsi_dev_probe - Failed in"
-                            "beiscsi_init_sgl_handle\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : beiscsi_dev_probe - Failed in"
+                           "beiscsi_init_sgl_handle\n");
                goto do_cleanup_ctrlr;
        }
 
        if (hba_setup_cid_tbls(phba)) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "Failed in hba_setup_cid_tbls\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : Failed in hba_setup_cid_tbls\n");
                kfree(phba->io_sgl_hndl_base);
                kfree(phba->eh_sgl_hndl_base);
                goto do_cleanup_ctrlr;
 
        mgmt_status = mgmt_epfw_cleanup(phba, CMD_CONNECTION_CHUTE_0);
        if (mgmt_status)
-               shost_printk(KERN_WARNING, phba->shost,
-                            "mgmt_epfw_cleanup FAILED\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_INIT,
+                           "BM_%d : mgmt_epfw_cleanup FAILED\n");
 
        hwi_purge_eq(phba);
        hwi_cleanup(phba);
        pci_pool_free(beiscsi_sess->bhs_pool, io_task->cmd_bhs,
                      io_task->bhs_pa.u.a64.address);
        io_task->cmd_bhs = NULL;
-       SE_DEBUG(DBG_LVL_1, "Alloc of SGL_ICD Failed\n");
+       beiscsi_log(phba, KERN_ERR,
+                   BEISCSI_LOG_IO | BEISCSI_LOG_CONFIG,
+                   "BM_%d : Alloc of SGL_ICD Failed\n");
        return -ENOMEM;
 }
 
                break;
 
        default:
-               SE_DEBUG(DBG_LVL_1, "opcode =%d Not supported\n",
-                        task->hdr->opcode & ISCSI_OPCODE_MASK);
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BM_%d : opcode =%d Not supported\n",
+                           task->hdr->opcode & ISCSI_OPCODE_MASK);
+
                return -EINVAL;
        }
 
        io_task->scsi_cmnd = sc;
        num_sg = scsi_dma_map(sc);
        if (num_sg < 0) {
-               SE_DEBUG(DBG_LVL_1, " scsi_dma_map Failed\n")
+               struct iscsi_conn *conn = task->conn;
+               struct beiscsi_hba *phba = NULL;
+
+               phba = ((struct beiscsi_conn *)conn->dd_data)->phba;
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_IO,
+                           "BM_%d : scsi_dma_map Failed\n");
+
                return num_sg;
        }
        xferlen = scsi_bufflen(sc);
        sg = scsi_sglist(sc);
-       if (sc->sc_data_direction == DMA_TO_DEVICE) {
+       if (sc->sc_data_direction == DMA_TO_DEVICE)
                writedir = 1;
-               SE_DEBUG(DBG_LVL_4, "task->imm_count=0x%08x\n",
-                        task->imm_count);
-       } else
+        else
                writedir = 0;
+
        return beiscsi_iotask(task, sg, num_sg, xferlen, writedir);
 }
 
                                        job->request_payload.payload_len,
                                        &nonemb_cmd.dma);
                if (nonemb_cmd.va == NULL) {
-                       SE_DEBUG(DBG_LVL_1, "Failed to allocate memory for "
-                                "beiscsi_bsg_request\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                                   "BM_%d : Failed to allocate memory for "
+                                   "beiscsi_bsg_request\n");
                        return -EIO;
                }
                tag = mgmt_vendor_specific_fw_cmd(&phba->ctrl, phba, job,
                                                  &nonemb_cmd);
                if (!tag) {
-                       SE_DEBUG(DBG_LVL_1, "be_cmd_get_mac_addr Failed\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                                   "BM_%d : be_cmd_get_mac_addr Failed\n");
+
                        pci_free_consistent(phba->ctrl.pdev, nonemb_cmd.size,
                                            nonemb_cmd.va, nonemb_cmd.dma);
                        return -EAGAIN;
                pci_free_consistent(phba->ctrl.pdev, nonemb_cmd.size,
                                    nonemb_cmd.va, nonemb_cmd.dma);
                if (status || extd_status) {
-                       SE_DEBUG(DBG_LVL_1, "be_cmd_get_mac_addr Failed"
-                                " status = %d extd_status = %d\n",
-                                status, extd_status);
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                                   "BM_%d : be_cmd_get_mac_addr Failed"
+                                   " status = %d extd_status = %d\n",
+                                   status, extd_status);
+
                        return -EIO;
                }
                break;
 
        default:
-               SE_DEBUG(DBG_LVL_1, "Unsupported bsg command: 0x%x\n",
-                        bsg_req->msgcode);
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                               "BM_%d : Unsupported bsg command: 0x%x\n",
+                               bsg_req->msgcode);
                break;
        }
 
        return rc;
 }
 
+void beiscsi_hba_attrs_init(struct beiscsi_hba *phba)
+{
+       /* Set the logging parameter */
+       beiscsi_log_enable_init(phba, beiscsi_log_enable);
+}
+
 static void beiscsi_quiesce(struct beiscsi_hba *phba)
 {
        struct hwi_controller *phwi_ctrlr;
 
        ret = beiscsi_enable_pci(pcidev);
        if (ret < 0) {
-               dev_err(&pcidev->dev, "beiscsi_dev_probe-"
-                       " Failed to enable pci device\n");
+               dev_err(&pcidev->dev,
+                       "beiscsi_dev_probe - Failed to enable pci device\n");
                return ret;
        }
 
        phba = beiscsi_hba_alloc(pcidev);
        if (!phba) {
-               dev_err(&pcidev->dev, "beiscsi_dev_probe-"
-                       " Failed in beiscsi_hba_alloc\n");
+               dev_err(&pcidev->dev,
+                       "beiscsi_dev_probe - Failed in beiscsi_hba_alloc\n");
                goto disable_pci;
        }
 
+       /* Initialize Driver configuration Paramters */
+       beiscsi_hba_attrs_init(phba);
+
        switch (pcidev->device) {
        case BE_DEVICE_ID1:
        case OC_DEVICE_ID1:
        else
                num_cpus = 1;
        phba->num_cpus = num_cpus;
-       SE_DEBUG(DBG_LVL_8, "num_cpus = %d\n", phba->num_cpus);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                   "BM_%d : num_cpus = %d\n",
+                   phba->num_cpus);
 
        if (enable_msix) {
                beiscsi_msix_enable(phba);
        }
        ret = be_ctrl_init(phba, pcidev);
        if (ret) {
-               shost_printk(KERN_ERR, phba->shost, "beiscsi_dev_probe-"
-                               "Failed in be_ctrl_init\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : beiscsi_dev_probe-"
+                           "Failed in be_ctrl_init\n");
                goto hba_free;
        }
 
                value = readl((void *)real_offset);
                if (value & 0x00010000) {
                        gcrashmode++;
-                       shost_printk(KERN_ERR, phba->shost,
-                               "Loading Driver in crashdump mode\n");
+                       beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                   "BM_%d : Loading Driver in crashdump mode\n");
                        ret = beiscsi_cmd_reset_function(phba);
                        if (ret) {
-                               shost_printk(KERN_ERR, phba->shost,
-                                       "Reset Failed. Aborting Crashdump\n");
+                               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                           "BM_%d : Reset Failed. Aborting Crashdump\n");
                                goto hba_free;
                        }
                        ret = be_chk_reset_complete(phba);
                        if (ret) {
-                               shost_printk(KERN_ERR, phba->shost,
-                                       "Failed to get out of reset."
-                                       "Aborting Crashdump\n");
+                               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                                           "BM_%d : Failed to get out of reset."
+                                           "Aborting Crashdump\n");
                                goto hba_free;
                        }
                } else {
        spin_lock_init(&phba->isr_lock);
        ret = mgmt_get_fw_config(&phba->ctrl, phba);
        if (ret != 0) {
-               shost_printk(KERN_ERR, phba->shost,
-                            "Error getting fw config\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : Error getting fw config\n");
                goto free_port;
        }
        phba->shost->max_id = phba->fw_config.iscsi_cid_count;
        phba->shost->can_queue = phba->params.ios_per_ctrl;
        ret = beiscsi_init_port(phba);
        if (ret < 0) {
-               shost_printk(KERN_ERR, phba->shost, "beiscsi_dev_probe-"
-                            "Failed in beiscsi_init_port\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : beiscsi_dev_probe-"
+                           "Failed in beiscsi_init_port\n");
                goto free_port;
        }
 
                 phba->shost->host_no);
        phba->wq = alloc_workqueue(phba->wq_name, WQ_MEM_RECLAIM, 1);
        if (!phba->wq) {
-               shost_printk(KERN_ERR, phba->shost, "beiscsi_dev_probe-"
-                               "Failed to allocate work queue\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : beiscsi_dev_probe-"
+                           "Failed to allocate work queue\n");
                goto free_twq;
        }
 
        }
        ret = beiscsi_init_irqs(phba);
        if (ret < 0) {
-               shost_printk(KERN_ERR, phba->shost, "beiscsi_dev_probe-"
-                            "Failed to beiscsi_init_irqs\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : beiscsi_dev_probe-"
+                           "Failed to beiscsi_init_irqs\n");
                goto free_blkenbld;
        }
        hwi_enable_intr(phba);
                 * log error but continue, because we may not be using
                 * iscsi boot.
                 */
-               shost_printk(KERN_ERR, phba->shost, "Could not set up "
-                            "iSCSI boot info.\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BM_%d : Could not set up "
+                           "iSCSI boot info.\n");
 
        beiscsi_create_def_ifaces(phba);
-       SE_DEBUG(DBG_LVL_8, "\n\n\n SUCCESS - DRIVER LOADED\n\n\n");
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                   "\n\n\n BM_%d : SUCCESS - DRIVER LOADED\n\n\n");
        return 0;
 
 free_blkenbld:
        beiscsi_scsi_transport =
                        iscsi_register_transport(&beiscsi_iscsi_transport);
        if (!beiscsi_scsi_transport) {
-               SE_DEBUG(DBG_LVL_1,
-                        "beiscsi_module_init - Unable to  register beiscsi"
-                        "transport.\n");
+               printk(KERN_ERR
+                      "beiscsi_module_init - Unable to  register beiscsi transport.\n");
                return -ENOMEM;
        }
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_module_init, tt=%p\n",
-                &beiscsi_iscsi_transport);
+       printk(KERN_INFO "In beiscsi_module_init, tt=%p\n",
+              &beiscsi_iscsi_transport);
 
        ret = pci_register_driver(&beiscsi_pci_driver);
        if (ret) {
-               SE_DEBUG(DBG_LVL_1,
-                        "beiscsi_module_init - Unable to  register"
-                        "beiscsi pci driver.\n");
+               printk(KERN_ERR
+                      "beiscsi_module_init - Unable to  register beiscsi pci driver.\n");
                goto unregister_iscsi_transport;
        }
        return 0;
 
        struct be_cmd_reopen_session_req *req;
        unsigned int tag = 0;
 
-       SE_DEBUG(DBG_LVL_8, "In bescsi_get_boot_target\n");
+       beiscsi_log(phba, KERN_INFO,
+                   BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
+                   "BG_%d : In bescsi_get_boot_target\n");
+
        spin_lock(&ctrl->mbox_lock);
        tag = alloc_mcc_tag(phba);
        if (!tag) {
        struct be_cmd_get_boot_target_req *req;
        unsigned int tag = 0;
 
-       SE_DEBUG(DBG_LVL_8, "In bescsi_get_boot_target\n");
+       beiscsi_log(phba, KERN_INFO,
+                   BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
+                   "BG_%d : In bescsi_get_boot_target\n");
+
        spin_lock(&ctrl->mbox_lock);
        tag = alloc_mcc_tag(phba);
        if (!tag) {
        struct be_cmd_get_session_resp *resp;
        struct be_sge *sge;
 
-       SE_DEBUG(DBG_LVL_8, "In beiscsi_get_session_info\n");
+       beiscsi_log(phba, KERN_INFO,
+                   BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
+                   "BG_%d : In beiscsi_get_session_info\n");
+
        spin_lock(&ctrl->mbox_lock);
        tag = alloc_mcc_tag(phba);
        if (!tag) {
                phba->fw_config.iscsi_cid_count =
                                        pfw_cfg->ulp[0].sq_count;
                if (phba->fw_config.iscsi_cid_count > (BE2_MAX_SESSIONS / 2)) {
-                       SE_DEBUG(DBG_LVL_8,
-                               "FW reported MAX CXNS as %d\t"
-                               "Max Supported = %d.\n",
-                               phba->fw_config.iscsi_cid_count,
-                               BE2_MAX_SESSIONS);
+                       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                                   "BG_%d : FW reported MAX CXNS as %d\t"
+                                   "Max Supported = %d.\n",
+                                   phba->fw_config.iscsi_cid_count,
+                                   BE2_MAX_SESSIONS);
                        phba->fw_config.iscsi_cid_count = BE2_MAX_SESSIONS / 2;
                }
        } else {
-               shost_printk(KERN_WARNING, phba->shost,
-                            "Failed in mgmt_get_fw_config\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_INIT,
+                           "BG_%d : Failed in mgmt_get_fw_config\n");
        }
 
        spin_unlock(&ctrl->mbox_lock);
                                sizeof(struct be_mgmt_controller_attributes),
                                &nonemb_cmd.dma);
        if (nonemb_cmd.va == NULL) {
-               SE_DEBUG(DBG_LVL_1,
-                        "Failed to allocate memory for mgmt_check_supported_fw"
-                        "\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BG_%d : Failed to allocate memory for "
+                           "mgmt_check_supported_fw\n");
                return -ENOMEM;
        }
        nonemb_cmd.size = sizeof(struct be_mgmt_controller_attributes);
        status = be_mbox_notify(ctrl);
        if (!status) {
                struct be_mgmt_controller_attributes_resp *resp = nonemb_cmd.va;
-               SE_DEBUG(DBG_LVL_8, "Firmware version of CMD: %s\n",
-                       resp->params.hba_attribs.flashrom_version_string);
-               SE_DEBUG(DBG_LVL_8, "Firmware version is : %s\n",
-                       resp->params.hba_attribs.firmware_version_string);
-               SE_DEBUG(DBG_LVL_8,
-                       "Developer Build, not performing version check...\n");
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BG_%d : Firmware Version of CMD : %s\n"
+                           "Firmware Version is : %s\n"
+                           "Developer Build, not performing version check...\n",
+                           resp->params.hba_attribs
+                           .flashrom_version_string,
+                           resp->params.hba_attribs.
+                           firmware_version_string);
+
                phba->fw_config.iscsi_features =
                                resp->params.hba_attribs.iscsi_features;
-               SE_DEBUG(DBG_LVL_8, " phba->fw_config.iscsi_features = %d\n",
-                                     phba->fw_config.iscsi_features);
+               beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
+                           "BM_%d : phba->fw_config.iscsi_features = %d\n",
+                           phba->fw_config.iscsi_features);
        } else
-               SE_DEBUG(DBG_LVL_1, " Failed in mgmt_check_supported_fw\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_INIT,
+                           "BG_%d :  Failed in mgmt_check_supported_fw\n");
        spin_unlock(&ctrl->mbox_lock);
        if (nonemb_cmd.va)
                pci_free_consistent(ctrl->pdev, nonemb_cmd.size,
                           OPCODE_COMMON_READ_FLASH, sizeof(*req));
                break;
        default:
-               shost_printk(KERN_WARNING, phba->shost,
-                            "Unsupported cmd = 0x%x\n\n", bsg_req->rqst_data.
-                            h_vendor.vendor_cmd[0]);
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_CONFIG,
+                           "BG_%d : Unsupported cmd = 0x%x\n\n",
+                           bsg_req->rqst_data.h_vendor.vendor_cmd[0]);
+
                spin_unlock(&ctrl->mbox_lock);
                return -ENOSYS;
        }
 
        status =  be_mcc_notify_wait(phba);
        if (status)
-               shost_printk(KERN_WARNING, phba->shost,
-                            " mgmt_epfw_cleanup , FAILED\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_INIT,
+                           "BG_%d : mgmt_epfw_cleanup , FAILED\n");
        spin_unlock(&ctrl->mbox_lock);
        return status;
 }
                       &daddr_in6->sin6_addr.in6_u.u6_addr8, 16);
                beiscsi_ep->ip_type = BE2_IPV6;
        } else{
-               shost_printk(KERN_ERR, phba->shost, "unknown addr family %d\n",
-                            dst_addr->sa_family);
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BG_%d : unknown addr family %d\n",
+                           dst_addr->sa_family);
                spin_unlock(&ctrl->mbox_lock);
                free_mcc_tag(&phba->ctrl, tag);
                return -EINVAL;
        if (phba->nxt_cqid == phba->num_cpus)
                phba->nxt_cqid = 0;
        req->cq_id = phwi_context->be_cq[i].id;
-       SE_DEBUG(DBG_LVL_8, "i=%d cq_id=%d\n", i, req->cq_id);
+       beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_CONFIG,
+                   "BG_%d : i=%d cq_id=%d\n", i, req->cq_id);
        req->defq_id = def_hdr_id;
        req->hdr_ring_id = def_hdr_id;
        req->data_ring_id = def_data_id;
        if (!status)
                phba->interface_handle = pbe_allid->if_hndl_list[0];
        else {
-               shost_printk(KERN_WARNING, phba->shost,
-                            "Failed in mgmt_get_all_if_id\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_CONFIG,
+                           "BG_%d : Failed in mgmt_get_all_if_id\n");
        }
        spin_unlock(&ctrl->mbox_lock);
 
        extd_status = (phba->ctrl.mcc_numtag[tag] & 0x0000FF00) >> 8;
        status = phba->ctrl.mcc_numtag[tag] & 0x000000FF;
        if (status || extd_status) {
-               SE_DEBUG(DBG_LVL_1,
-                        "mgmt_exec_nonemb_cmd Failed status = %d"
-                        "extd_status = %d\n", status, extd_status);
+               beiscsi_log(phba, KERN_ERR,
+                           BEISCSI_LOG_CONFIG | BEISCSI_LOG_MBOX,
+                           "BG_%d : mgmt_exec_nonemb_cmd Failed status = %d"
+                           "extd_status = %d\n", status, extd_status);
                rc = -EIO;
                goto free_tag;
        }
 {
        cmd->va = pci_alloc_consistent(phba->ctrl.pdev, size, &cmd->dma);
        if (!cmd->va) {
-               SE_DEBUG(DBG_LVL_1, "Failed to allocate memory for if info\n");
+               beiscsi_log(phba, KERN_ERR, BEISCSI_LOG_CONFIG,
+                           "BG_%d : Failed to allocate memory for if info\n");
                return -ENOMEM;
        }
        memset(cmd->va, 0, size);
 
        rc = mgmt_exec_nonemb_cmd(phba, &nonemb_cmd, NULL, 0);
        if (rc < 0)
-               shost_printk(KERN_WARNING, phba->shost,
-                            "Failed to Modify existing IP Address\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_CONFIG,
+                           "BG_%d : Failed to Modify existing IP Address\n");
        return rc;
 }
 
 
        if (boot_proto == ISCSI_BOOTPROTO_DHCP) {
                if (if_info.dhcp_state) {
-                       shost_printk(KERN_WARNING, phba->shost,
-                                    "DHCP Already Enabled\n");
+                       beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_CONFIG,
+                                   "BG_%d : DHCP Already Enabled\n");
                        return 0;
                }
                /* The ip_param->len is 1 in DHCP case. Setting
 
                        rc = mgmt_exec_nonemb_cmd(phba, &nonemb_cmd, NULL, 0);
                        if (rc < 0) {
-                               shost_printk(KERN_WARNING, phba->shost,
-                                            "Failed to Delete existing dhcp\n");
+                               beiscsi_log(phba, KERN_WARNING,
+                                           BEISCSI_LOG_CONFIG,
+                                           "BG_%d : Failed to Delete existing dhcp\n");
                                return rc;
                        }
                }
                memset(>way_addr_set, 0, sizeof(gtway_addr_set));
                rc = mgmt_get_gateway(phba, BE2_IPV4, >way_addr_set);
                if (rc) {
-                       shost_printk(KERN_WARNING, phba->shost,
-                                    "Failed to Get Gateway Addr\n");
+                       beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_CONFIG,
+                                   "BG_%d : Failed to Get Gateway Addr\n");
                        return rc;
                }
 
                                                 IP_ACTION_DEL, IP_V4_LEN);
 
                        if (rc) {
-                               shost_printk(KERN_WARNING, phba->shost,
-                                            "Failed to clear Gateway Addr Set\n");
+                               beiscsi_log(phba, KERN_WARNING,
+                                           BEISCSI_LOG_CONFIG,
+                                           "BG_%d : Failed to clear Gateway Addr Set\n");
                                return rc;
                        }
                }
        memset(>way_addr_set, 0, sizeof(gtway_addr_set));
        rt_val = mgmt_get_gateway(phba, BE2_IPV4, >way_addr_set);
        if (rt_val) {
-               shost_printk(KERN_WARNING, phba->shost,
-                            "Failed to Get Gateway Addr\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_CONFIG,
+                           "BG_%d : Failed to Get Gateway Addr\n");
                return rt_val;
        }
 
                rt_val = mgmt_modify_gateway(phba, gtway_addr, IP_ACTION_DEL,
                                             gateway_param->len);
                if (rt_val) {
-                       shost_printk(KERN_WARNING, phba->shost,
-                                    "Failed to clear Gateway Addr Set\n");
+                       beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_CONFIG,
+                                   "BG_%d : Failed to clear Gateway Addr Set\n");
                        return rt_val;
                }
        }
                                     gateway_param->len);
 
        if (rt_val)
-               shost_printk(KERN_WARNING, phba->shost,
-                            "Failed to Set Gateway Addr\n");
+               beiscsi_log(phba, KERN_WARNING, BEISCSI_LOG_CONFIG,
+                           "BG_%d : Failed to Set Gateway Addr\n");
 
        return rt_val;
 }
                /* Get the Boot Target Session Handle and Count*/
                tag = mgmt_get_boot_target(phba);
                if (!tag) {
-                       SE_DEBUG(DBG_LVL_1, "mgmt_get_boot_target Failed\n");
+                       beiscsi_log(phba, KERN_ERR,
+                                   BEISCSI_LOG_CONFIG | BEISCSI_LOG_INIT,
+                                   "BG_%d : Getting Boot Target Info Failed\n");
                        return -EAGAIN;
                } else
                        wait_event_interruptible(phba->ctrl.mcc_wait[tag],
                extd_status = (phba->ctrl.mcc_numtag[tag] & 0x0000FF00) >> 8;
                status = phba->ctrl.mcc_numtag[tag] & 0x000000FF;
                if (status || extd_status) {
-                       SE_DEBUG(DBG_LVL_1, "mgmt_get_boot_target Failed"
-                                           " status = %d extd_status = %d\n",
-                                           status, extd_status);
+                       beiscsi_log(phba, KERN_ERR,
+                                   BEISCSI_LOG_INIT | BEISCSI_LOG_CONFIG,
+                                   "BG_%d : mgmt_get_boot_target Failed"
+                                   " status = %d extd_status = %d\n",
+                                   status, extd_status);
                        free_mcc_tag(&phba->ctrl, tag);
                        return -EBUSY;
                }
 
                /* Check if the there are any Boot targets configured */
                if (!boot_resp->boot_session_count) {
-                       SE_DEBUG(DBG_LVL_8, "No boot targets configured\n");
+                       beiscsi_log(phba, KERN_INFO,
+                                   BEISCSI_LOG_INIT | BEISCSI_LOG_CONFIG,
+                                   "BG_%d  ;No boot targets configured\n");
                        return -ENXIO;
                }
 
                tag = mgmt_reopen_session(phba, BE_REOPEN_BOOT_SESSIONS,
                                          INVALID_SESS_HANDLE);
                if (!tag) {
-                       SE_DEBUG(DBG_LVL_1, "mgmt_reopen_session Failed\n");
+                       beiscsi_log(phba, KERN_ERR,
+                                   BEISCSI_LOG_INIT | BEISCSI_LOG_CONFIG,
+                                   "BG_%d : mgmt_reopen_session Failed\n");
                        return -EAGAIN;
                } else
                        wait_event_interruptible(phba->ctrl.mcc_wait[tag],
                extd_status = (phba->ctrl.mcc_numtag[tag] & 0x0000FF00) >> 8;
                status = phba->ctrl.mcc_numtag[tag] & 0x000000FF;
                if (status || extd_status) {
-                       SE_DEBUG(DBG_LVL_1, "mgmt_reopen_session Failed"
-                                           " status = %d extd_status = %d\n",
-                                           status, extd_status);
+                       beiscsi_log(phba, KERN_ERR,
+                                   BEISCSI_LOG_INIT | BEISCSI_LOG_CONFIG,
+                                   "BG_%d : mgmt_reopen_session Failed"
+                                   " status = %d extd_status = %d\n",
+                                   status, extd_status);
                        free_mcc_tag(&phba->ctrl, tag);
                        return -EBUSY;
                }
        } while (--boot_retry);
 
        /* Couldn't log into the boot target */
-       SE_DEBUG(DBG_LVL_1, "Login to Boot Target Failed\n");
+       beiscsi_log(phba, KERN_ERR,
+                   BEISCSI_LOG_INIT | BEISCSI_LOG_CONFIG,
+                   "BG_%d : Login to Boot Target Failed\n");
        return -ENXIO;
 }