rx_cmd_b);
 
                                skb_trim(skb, skb->len - 4); /* remove fcs */
-                               skb->truesize = size + sizeof(struct sk_buff);
 
                                return 1;
                        }
 
-                       ax_skb = skb_clone(skb, GFP_ATOMIC);
+                       /* Use "size - 4" to remove fcs */
+                       ax_skb = netdev_alloc_skb_ip_align(dev->net, size - 4);
                        if (unlikely(!ax_skb)) {
                                netdev_warn(dev->net, "Error allocating skb\n");
                                return 0;
                        }
 
-                       ax_skb->len = size;
-                       ax_skb->data = packet;
-                       skb_set_tail_pointer(ax_skb, size);
+                       skb_put(ax_skb, size - 4);
+                       memcpy(ax_skb->data, packet, size - 4);
 
                        smsc75xx_rx_csum_offload(dev, ax_skb, rx_cmd_a,
                                rx_cmd_b);
 
-                       skb_trim(ax_skb, ax_skb->len - 4); /* remove fcs */
-                       ax_skb->truesize = size + sizeof(struct sk_buff);
-
                        usbnet_skb_return(dev, ax_skb);
                }