From owner-freebsd-current@freebsd.org Tue Aug 7 11:56:56 2018 Return-Path: Delivered-To: freebsd-current@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 42985105AB4C for ; Tue, 7 Aug 2018 11:56:56 +0000 (UTC) (envelope-from kostikbel@gmail.com) Received: from kib.kiev.ua (kib.kiev.ua [IPv6:2001:470:d5e7:1::1]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 9A7798BC56 for ; Tue, 7 Aug 2018 11:56:55 +0000 (UTC) (envelope-from kostikbel@gmail.com) Received: from tom.home (kib@localhost [127.0.0.1]) by kib.kiev.ua (8.15.2/8.15.2) with ESMTPS id w77BuiXa097870 (version=TLSv1.2 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=NO); Tue, 7 Aug 2018 14:56:48 +0300 (EEST) (envelope-from kostikbel@gmail.com) DKIM-Filter: OpenDKIM Filter v2.10.3 kib.kiev.ua w77BuiXa097870 Received: (from kostik@localhost) by tom.home (8.15.2/8.15.2/Submit) id w77BuiwB097869; Tue, 7 Aug 2018 14:56:44 +0300 (EEST) (envelope-from kostikbel@gmail.com) X-Authentication-Warning: tom.home: kostik set sender to kostikbel@gmail.com using -f Date: Tue, 7 Aug 2018 14:56:44 +0300 From: Konstantin Belousov To: Johannes Lundberg Cc: freebsd-current Subject: Re: Need to reserve Intel graphics memory in early boot Message-ID: <20180807115644.GB1884@kib.kiev.ua> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.10.1 (2018-07-13) X-Spam-Status: No, score=-2.0 required=5.0 tests=ALL_TRUSTED,BAYES_00, DKIM_ADSP_CUSTOM_MED,FREEMAIL_FROM,NML_ADSP_CUSTOM_MED autolearn=no autolearn_force=no version=3.4.1 X-Spam-Checker-Version: SpamAssassin 3.4.1 (2015-04-28) on tom.home X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.27 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 07 Aug 2018 11:56:56 -0000 On Tue, Aug 07, 2018 at 09:04:57AM +0100, Johannes Lundberg wrote: > Hi > > I'm working on getting the graphics drivers up to Linux 4.16 version and > there has been a patch for Intel gpus that require some code in early boot. > > The problem is that no all bios report the memory allocated for the gpu, > called stolen memory, correctly so on some configurations the OS can > reclaim this memory during boot that thus it's not accessible to the gpu > driver (at least that is my understanding). Drivers need the stolen memory > for frame buffer compression (fbc) to work (maybe more features as well > depend on stolen memory). The purpose of fbc is to reduce power consumption. > > So, what we need to do is get the base and size of the stolen memory and > reserve it before the OS have a chance to claim it. This information will > be stored in a global variable that the drm i915 driver can later read. > > The Linux implementation can be found here: > https://elixir.bootlin.com/linux/v4.16/source/arch/x86/kernel/early-quirks.c#L539 > > The drm and i915 driver code are dual licensed but I'm not sure about the > code in the file above, it might be GPL only. > > Anyone feeling up to doing this? Or if you have any pointers as to where > would be a good place to implement this in FreeBSD, I can give it a shot. Most likely what you need is to exclude the range from the phys_avail[] array. Look at the amd64/machdep.c how this array is handled by early startup. Another option might be to not exclude the pages from phys_avail[], but instead use vm_page_blacklist_add() function to reserve some pages. The difference with phys_avail[] approach is that blacklist_add can be done somewhat later, after VM subsystem consumed phys_avail[] and initialized the structures to describe the page frames. Depending on the fbc code, it might be more convenient to have vm_page_t describing the stolen memory, but the drawback is that it can be done later in boot process, and depending on the location of the stolen mem, other kernel subsystem might already carved some pages from it.