struct net_device_stats stats;
        struct iw_statistics iwstats;
        int pid; /*process id from UI*/
+       _workitem wkFilterRxFF0;
+       u8 blnEnableRxFF0Filter;
+       spinlock_t lockRxFF0Filter;
 };
 
 static inline u8 *myid(struct eeprom_priv *peepriv)
 
                pxmitbuf++;
        }
        pxmitpriv->free_xmitbuf_cnt = NR_XMITBUFF;
+       _init_workitem(&padapter->wkFilterRxFF0, r8712_SetFilter, padapter);
        alloc_hwxmits(padapter);
        init_hwxmits(pxmitpriv->hwxmits, pxmitpriv->hwxmit_entry);
        tasklet_init(&pxmitpriv->xmit_tasklet,
-            (void(*)(addr_t))r8712_xmit_bh,
-            (addr_t)padapter);
+               (void(*)(unsigned long))r8712_xmit_bh,
+               (unsigned long)padapter);
        return _SUCCESS;
 }
 
        if (make_wlanhdr(padapter, mem_start, pattrib) == _FAIL)
                return _FAIL;
        _r8712_open_pktfile(pkt, &pktfile);
-       _r8712_pktfile_read(&pktfile, NULL, pattrib->pkt_hdrlen);
+       _r8712_pktfile_read(&pktfile, NULL, (uint) pattrib->pkt_hdrlen);
        if (check_fwstate(pmlmepriv, WIFI_MP_STATE) == true) {
                /* truncate TXDESC_SIZE bytes txcmd if at mp mode for 871x */
                if (pattrib->ether_type == 0x8712) {
        unsigned long irqL;
        struct  __queue *pfree_xmit_queue = &pxmitpriv->free_xmit_queue;
        struct _adapter *padapter = pxmitpriv->adapter;
+       struct sk_buff *pndis_pkt = NULL;
 
        if (pxmitframe == NULL)
                return;
-       if (pxmitframe->pkt)
-               r8712_xmit_complete(padapter, pxmitframe);
        spin_lock_irqsave(&pfree_xmit_queue->lock, irqL);
        list_delete(&pxmitframe->list);
+       if (pxmitframe->pkt) {
+               pndis_pkt = pxmitframe->pkt;
+               pxmitframe->pkt = NULL;
+       }
        list_insert_tail(&pxmitframe->list, get_list_head(pfree_xmit_queue));
        pxmitpriv->free_xmitframe_cnt++;
        spin_unlock_irqrestore(&pfree_xmit_queue->lock, irqL);
 
 
 static uint remainder_len(struct pkt_file *pfile)
 {
-       /* Kovich: Need to extend the buf_len to 64 bit ?(unsigned long long) */
        return (uint)(pfile->buf_len - ((addr_t)(pfile->cur_addr) -
               (addr_t)(pfile->buf_start)));
 }
        pattrib->subtype = WIFI_QOS_DATA_TYPE;
 }
 
+void r8712_SetFilter(struct work_struct *work)
+{
+       struct _adapter *padapter = container_of(work, struct _adapter,
+                                               wkFilterRxFF0);
+       u8  oldvalue = 0x00, newvalue = 0x00;
+       unsigned long irqL;
+
+       oldvalue = r8712_read8(padapter, 0x117);
+       newvalue = oldvalue & 0xfe;
+       r8712_write8(padapter, 0x117, newvalue);
+
+       spin_lock_irqsave(&padapter->lockRxFF0Filter, irqL);
+       padapter->blnEnableRxFF0Filter = 1;
+       spin_unlock_irqrestore(&padapter->lockRxFF0Filter, irqL);
+       do {
+               msleep(100);
+       } while (padapter->blnEnableRxFF0Filter == 1);
+       r8712_write8(padapter, 0x117, oldvalue);
+}
+
 int r8712_xmit_resource_alloc(struct _adapter *padapter,
                              struct xmit_buf *pxmitbuf)
 {
 
 struct xmit_buf;
 
 int r8712_xmit_entry(_pkt *pkt, struct  net_device *pnetdev);
+void r8712_SetFilter(struct work_struct *work);
 int r8712_xmit_resource_alloc(struct _adapter *padapter,
                           struct xmit_buf *pxmitbuf);
 void r8712_xmit_resource_free(struct _adapter *padapter,