From: Denis Oliver Kropp <dok-iGvX3keArt1g9hUCZPvPmw@public.gmane.org>
To: "Brian G. Rhodes" <bgr-3mWahjwryh5BDgjK7y7TUQ@public.gmane.org>
Cc: directfb-users-iGvX3keArt1g9hUCZPvPmw@public.gmane.org,
linux-fbdev-devel-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org,
directfb-dev-iGvX3keArt1g9hUCZPvPmw@public.gmane.org,
Geert Uytterhoeven
<geert-Td1EMuHUCqxL1ZNQvxDV9g@public.gmane.org>
Subject: Re: [Linux-fbdev-devel] DirectFB without FBDev
Date: Wed, 28 May 2008 21:11:20 +0200 [thread overview]
Message-ID: <483DAE58.4020300@directfb.org> (raw)
In-Reply-To: <483DAAB7.6080208-3mWahjwryh5BDgjK7y7TUQ@public.gmane.org>
Brian G. Rhodes wrote:
>
>
> Denis Oliver Kropp wrote:
>> Brian G. Rhodes wrote:
>>> I don't think the solution to abstracting access to multiple hardware
>>> planes which can be located in at dynamic memory addresses to be
>>> implemented by adding complexity to the framebuffer driver. It is
>>> supposed to be just a dumb chunk of memory and storage for hardware
>>> timings.
>>>
>>
>> Adding the byte offset and pitch fits into this as well and would save
>> it from being removed from DirectFB.
>>
>>
>
> Seems like an end-run around supporting windows in framebuffer memory
> and using pan to jump back and forth. This obviously was not the
> original intention of panning. I have seen it used quite a bit for
Yep, panning wasn't meant for buffer swapping initially :)
> buffering and it seems like a pretty inelegant method for accessing the
> memory. So you add a byte offset and a pitch so that you can pull out
> your next screen buffer. Now you also need to add flags for the fb
> driver to tell the user-space implementation that it supports this
> functionality. Pretty soon it's not a framebuffer driver. Not that
> it's terribly atrocious what you suggest... I didn't mean to come off
> as such. I would just prefer that there is an intermediary interface to
> the fb driver which understands the hardware better and can manage these
> line-width writes better.
You want to put something between fb driver and user space?
>>> It is too inefficient and in cases with hardware-assist (other than
>>> coprocessors), likely unnecessary. The answer probably isn't using
>>> Video4Linux directly either. Perhaps a DirectFB kernel component
>>> which can standardize an interface and provide a better architecture
>>> than v4l2 does. An application where, as mentioned above, you are
>>> using video memory for multiple buffers as a implementation for
>>> queuing seems too specialized to me to ever be done in a linuxfb driver.
>>>
>>
>> It's not special regarding the hardware. Every driver with an interrupt
>> handler could support it.
>>
>>
> No, it's not special with respect to the hardware. It's special because
> you're turning your framebuffer into a fifo.
No, it's just a FIFO between kernel and user space to set display offsets
within the frame buffer.
>>> Has any thought been given to designing a DirectFB kernel-space
>>> component which abstracts that access at the kernel level? Seems to
>>> me that it would make direct interaction from directfb with
>>> specialized hardware much easier.
>>>
>>
>> I don't think a new kernel graphics interface should be added, instead
>> using
>> UIO to access MMIO, DMA and IRQs would be enough and implement most of
>> the
>> graphics driver in user space. Downside is to loose the kernel console
>> which
>> you usually don't need on an embedded device...
>> For acceleration and DMA/IRQ based programming, I still need to check
>> if a
>> user space approach would be enough. So far I always handled IRQs in
>> kernel
>> space for timing/performance reasons...
>>
>>
> I wouldn't want to signal userspace from an ISR to handle work. All the
> unnecessary context switches just seem wasteful. Or is there a better
> method now for waking up userspace from the kernel now?
I agree. It would be nice to have some cheap context switch from kernel to user
space, or some way to create a less privileged kernel thread with less overhead
during switching, but the ability to execute non-root user's code. I don't care
about the overhead from user to kernel (system call), but kernel to user (real time
thread for IRQs) should be optimized. Just dropping some privileges only sounds
simple in that case though :)
--
Best regards,
Denis Oliver Kropp
.------------------------------------------.
| DirectFB - Hardware accelerated graphics |
| http://www.directfb.org/ |
"------------------------------------------"
next prev parent reply other threads:[~2008-05-28 19:11 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-05-28 14:59 DirectFB without FBDev Denis Oliver Kropp
2008-05-28 17:04 ` Geert Uytterhoeven
2008-05-28 17:20 ` Denis Oliver Kropp
[not found] ` <483D9453.1080700-iGvX3keArt1g9hUCZPvPmw@public.gmane.org>
2008-05-28 17:53 ` [Linux-fbdev-devel] " Brian G. Rhodes
2008-05-28 18:07 ` [directfb-users] " Denis Oliver Kropp
2008-05-28 18:24 ` Alex Deucher
[not found] ` <a728f9f90805281124y53df86e7n7ae1918ac97907fc-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2008-05-28 18:57 ` [Linux-fbdev-devel] " Denis Oliver Kropp
2008-05-28 19:33 ` [directfb-users] " Alex Deucher
2008-05-28 18:55 ` Brian G. Rhodes
[not found] ` <483DAAB7.6080208-3mWahjwryh5BDgjK7y7TUQ@public.gmane.org>
2008-05-28 19:11 ` Denis Oliver Kropp [this message]
2008-05-28 19:38 ` Brian G. Rhodes
[not found] ` <483D9F4E.4000707-iGvX3keArt1g9hUCZPvPmw@public.gmane.org>
2008-05-29 16:54 ` [directfb-dev] [Linux-fbdev-devel] " Sven Luther
2008-05-31 6:08 ` [directfb-dev] [directfb-users] " Denis Oliver Kropp
2008-05-31 6:21 ` Sven Luther
2008-05-31 6:29 ` Denis Oliver Kropp
2008-05-31 6:45 ` Sven Luther
[not found] ` <20080531064501.GA7526-XkLrfMvk983aVgXGlvhGPA@public.gmane.org>
2008-05-31 20:32 ` George Tsalikis
2008-06-01 7:10 ` [directfb-dev] " Denis Oliver Kropp
[not found] ` <48424B49.8080202-iGvX3keArt1g9hUCZPvPmw@public.gmane.org>
2008-06-01 9:20 ` [directfb-dev] " George Tsalikis
2008-06-01 9:38 ` Denis Oliver Kropp
2008-05-28 17:55 ` Geert Uytterhoeven
2008-05-28 18:33 ` Denis Oliver Kropp
[not found] ` <483D7344.6030503-iGvX3keArt1g9hUCZPvPmw@public.gmane.org>
2008-06-01 9:31 ` [directfb-dev] " Denis Oliver Kropp
[not found] ` <48426C76.5080606-iGvX3keArt1g9hUCZPvPmw@public.gmane.org>
2008-06-01 11:57 ` Denis Oliver Kropp
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=483DAE58.4020300@directfb.org \
--to=dok-igvx3keart1g9huczpvpmw@public.gmane.org \
--cc=bgr-3mWahjwryh5BDgjK7y7TUQ@public.gmane.org \
--cc=directfb-dev-iGvX3keArt1g9hUCZPvPmw@public.gmane.org \
--cc=directfb-users-iGvX3keArt1g9hUCZPvPmw@public.gmane.org \
--cc=geert-Td1EMuHUCqxL1ZNQvxDV9g@public.gmane.org \
--cc=linux-fbdev-devel-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).