Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2984312imu; Sun, 9 Dec 2018 14:17:30 -0800 (PST) X-Google-Smtp-Source: AFSGD/WjyP79UtTsSEoctgVU2gu8RaUmiVDhp5l/own+6YhEz/Uk/nBI1UlNTSZ6f33iAqpq9U2n X-Received: by 2002:a63:bf0b:: with SMTP id v11mr9071592pgf.302.1544393850871; Sun, 09 Dec 2018 14:17:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544393850; cv=none; d=google.com; s=arc-20160816; b=GBAgH3VnUkuloh5Z8o5YK64m3YT0RYYRP/xRzUNsKP2iqJ9oaF3jBdR6H3JPNJ+Re/ r9qGsY467byJfCU4gsibt2tMsbJ07HqJP5s4Kna056MXVeqbOUNa5gi1g38HhPxbdfYD IRf8XC5dCZ3YngR1D7SdOifA32i/L9ApEK4esRYUmwu+/vnijpG49eVoyDJuak89HksP i5XOf+TSMOQVzaxPg2NsiezQq7Vw9UIddDMInfdRe08PENcEsrfxwGc/Ntf4Ts0NdP0H vYTLBwNFqNiyDc+N6Dq2rHf07HwjTnWnImrpHj1SK/HjSkJHFQ8P5LA6FntsYu4Gglap soGw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:subject:message-id:date:cc:to :from:mime-version:content-transfer-encoding:content-disposition; bh=RuRO2GaKJ4jgxvnC084LQ/bBkt1LeULJ+zGno7K9WBU=; b=FQX7Osq6sMAbGunvQM6TEDLVGOPaEvYNVGi97zwiDwn+gLhmod5IHhZqsY8EZHSYvZ yqZjZM8vPEBHqoJp4qwQeD5E/mKpJ8maZx1w7pEIk4oDzhp2Sw2rUNZzs9vzNXm45MLV 3KwHdy75jW5jPpw+bod5xyzIMEh6eA07wm40tX6l/Ur/ItPLzuzNdI7DjV7jPVi3cDWl KWjhG/JQrRYYq/Pq+YMKEib8UxiGCS5DlQNFIFAJ/8qqq7wWmfD73GR4OIbo2y7F8TuE JFzOXHJwAMXCqbfyspTzL4XWMJ2ZCw7TGtdYTdmFfHt+PD6uoTI+e/tDC0+RvRZM4IXj o0vw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g6si8031794pgr.472.2018.12.09.14.17.15; Sun, 09 Dec 2018 14:17:30 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728538AbeLIWOq (ORCPT + 99 others); Sun, 9 Dec 2018 17:14:46 -0500 Received: from shadbolt.e.decadent.org.uk ([88.96.1.126]:38104 "EHLO shadbolt.e.decadent.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727019AbeLIWOp (ORCPT ); Sun, 9 Dec 2018 17:14:45 -0500 Received: from pub.yeoldevic.com ([81.174.156.145] helo=deadeye) by shadbolt.decadent.org.uk with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.89) (envelope-from ) id 1gW73M-0002ib-5j; Sun, 09 Dec 2018 21:55:56 +0000 Received: from ben by deadeye with local (Exim 4.91) (envelope-from ) id 1gW72a-0003HA-B5; Sun, 09 Dec 2018 21:55:08 +0000 Content-Type: text/plain; charset="UTF-8" Content-Disposition: inline Content-Transfer-Encoding: 8bit MIME-Version: 1.0 From: Ben Hutchings To: linux-kernel@vger.kernel.org, stable@vger.kernel.org CC: akpm@linux-foundation.org, "Mikulas Patocka" , "Bartlomiej Zolnierkiewicz" Date: Sun, 09 Dec 2018 21:50:33 +0000 Message-ID: X-Mailer: LinuxStableQueue (scripts by bwh) X-Patchwork-Hint: ignore Subject: [PATCH 3.16 063/328] udlfb: handle allocation failure In-Reply-To: X-SA-Exim-Connect-IP: 81.174.156.145 X-SA-Exim-Mail-From: ben@decadent.org.uk X-SA-Exim-Scanned: No (on shadbolt.decadent.org.uk); SAEximRunCond expanded to false Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 3.16.62-rc1 review patch. If anyone has any objections, please let me know. ------------------ From: Mikulas Patocka commit 080fb5240bdcabed7387b814139c3ea172d59fc5 upstream. Allocations larger than PAGE_ALLOC_COSTLY_ORDER are unreliable and they may fail anytime. This patch fixes the udlfb driver so that when a large alloactions fails, it tries to do multiple smaller allocations. Signed-off-by: Mikulas Patocka Signed-off-by: Bartlomiej Zolnierkiewicz [bwh: Backported to 3.16: - Pointers to struct dlfb_data are named "dev" rather than "dlfb" - Adjust context] Signed-off-by: Ben Hutchings --- drivers/video/fbdev/udlfb.c | 26 +++++++++++++++++--------- 1 file changed, 17 insertions(+), 9 deletions(-) --- a/drivers/video/fbdev/udlfb.c +++ b/drivers/video/fbdev/udlfb.c @@ -1851,17 +1851,22 @@ static void dlfb_free_urb_list(struct dl static int dlfb_alloc_urb_list(struct dlfb_data *dev, int count, size_t size) { - int i = 0; struct urb *urb; struct urb_node *unode; char *buf; + size_t wanted_size = count * size; spin_lock_init(&dev->urbs.lock); +retry: dev->urbs.size = size; INIT_LIST_HEAD(&dev->urbs.list); - while (i < count) { + sema_init(&dev->urbs.limit_sem, 0); + dev->urbs.count = 0; + dev->urbs.available = 0; + + while (dev->urbs.count * size < wanted_size) { unode = kzalloc(sizeof(struct urb_node), GFP_KERNEL); if (!unode) break; @@ -1874,11 +1879,16 @@ static int dlfb_alloc_urb_list(struct dl } unode->urb = urb; - buf = usb_alloc_coherent(dev->udev, MAX_TRANSFER, GFP_KERNEL, + buf = usb_alloc_coherent(dev->udev, size, GFP_KERNEL, &urb->transfer_dma); if (!buf) { kfree(unode); usb_free_urb(urb); + if (size > PAGE_SIZE) { + size /= 2; + dlfb_free_urb_list(dev); + goto retry; + } break; } @@ -1889,14 +1899,12 @@ static int dlfb_alloc_urb_list(struct dl list_add_tail(&unode->entry, &dev->urbs.list); - i++; + up(&dev->urbs.limit_sem); + dev->urbs.count++; + dev->urbs.available++; } - sema_init(&dev->urbs.limit_sem, i); - dev->urbs.count = i; - dev->urbs.available = i; - - return i; + return dev->urbs.count; } static struct urb *dlfb_get_urb(struct dlfb_data *dev)