profile/ivi/weston-ivi-shell.git
11 years agonested: Cast away warnings for differing arguments to eglQueryWaylandBufferWL
Kristian Høgsberg [Wed, 9 Oct 2013 20:34:35 +0000 (13:34 -0700)]
nested: Cast away warnings for differing arguments to eglQueryWaylandBufferWL

11 years agonested: Free client struct on launch_client error paths
Kristian Høgsberg [Wed, 9 Oct 2013 20:30:58 +0000 (13:30 -0700)]
nested: Free client struct on launch_client error paths

11 years agonested-client: Exit if we fail to create the nested client struct
Kristian Høgsberg [Wed, 9 Oct 2013 20:25:58 +0000 (13:25 -0700)]
nested-client: Exit if we fail to create the nested client struct

11 years agomulti-resource: Use xzmalloc() instead of malloc+memset and calloc
Kristian Høgsberg [Wed, 9 Oct 2013 20:09:51 +0000 (13:09 -0700)]
multi-resource: Use xzmalloc() instead of malloc+memset and calloc

11 years agolauncher: Remove left-over debug logging
Kristian Høgsberg [Wed, 9 Oct 2013 20:10:42 +0000 (13:10 -0700)]
launcher: Remove left-over debug logging

11 years agotablet-shell: Avoid leaking icon or path strings from invalid launcher section
Kristian Høgsberg [Wed, 9 Oct 2013 20:05:55 +0000 (13:05 -0700)]
tablet-shell: Avoid leaking icon or path strings from invalid launcher section

11 years agowindow.c: Free cursor theme name once we're done with it
Kristian Høgsberg [Wed, 9 Oct 2013 20:02:04 +0000 (13:02 -0700)]
window.c: Free cursor theme name once we're done with it

11 years agoweston-launch: Only store drm fd if we successfully opened and stat'ed it
Kristian Høgsberg [Wed, 9 Oct 2013 18:25:14 +0000 (11:25 -0700)]
weston-launch: Only store drm fd if we successfully opened and stat'ed it

11 years agolauncher: Don't leak tty file descriptor on error
Kristian Høgsberg [Wed, 9 Oct 2013 18:19:11 +0000 (11:19 -0700)]
launcher: Don't leak tty file descriptor on error

11 years agolauncher: Don't leak tty file descriptor on launcher destroy
Kristian Høgsberg [Wed, 9 Oct 2013 18:03:39 +0000 (11:03 -0700)]
launcher: Don't leak tty file descriptor on launcher destroy

11 years agocompositor-fbdev: Fix a fd leak in the fbdev backend
Kristian Høgsberg [Wed, 9 Oct 2013 16:59:06 +0000 (09:59 -0700)]
compositor-fbdev: Fix a fd leak in the fbdev backend

fbdev_frame_buffer_map() closes the fb fd, so we have to close it
manually in case we're using the hybris renderer (ie !pixman).

11 years agoconfigure.ac: Bump version to 1.3
Kristian Høgsberg [Wed, 9 Oct 2013 23:20:50 +0000 (16:20 -0700)]
configure.ac: Bump version to 1.3

11 years agoRevert "Resize the shell when the mode is switched"
Kristian Høgsberg [Wed, 9 Oct 2013 22:17:01 +0000 (15:17 -0700)]
Revert "Resize the shell when the mode is switched"

This breaks panel resizing as it doesn't account for output rotation.

https://bugs.freedesktop.org/show_bug.cgi?id=70249

This reverts commit a356f7b1ef08fd9c2ad69cada89d68841e71a6bb.

11 years agoinput: Don't send modifiers if client doesn't have a pointer resource
Kristian Høgsberg [Wed, 9 Oct 2013 17:54:03 +0000 (10:54 -0700)]
input: Don't send modifiers if client doesn't have a pointer resource

This fixes an uninitialized serial error, were we could send out the
modifier event even if the client didn't have a pointer resource.  We
send out the modifier event to let clients know the modifer mask when
they receive a pointer button event.  Thus, if the client doesn't have
a pointer we don't need to send the modifier event.

Additionally we would send out the modifier event with an
uninitialized serial number.

Finally, this commit restores the order of sending the modifier event
before the enter, like it used to be.  Not likely to be an issue,
since the client will always receive the modifier event before any
button event, but it's a little nicer to give the client the modifier
events before it receives any pointer events.

11 years agorpi: Add support for EGL buffers
Tomeu Vizoso [Mon, 7 Oct 2013 09:02:20 +0000 (11:02 +0200)]
rpi: Add support for EGL buffers

The EGL implementation on the RPi allocates a front and a back
DispmanX resources for each EGLSurface, which we composite along
the others.

11 years agoconfigure.ac: Bump version to 1.2.92
Kristian Høgsberg [Thu, 3 Oct 2013 05:14:23 +0000 (22:14 -0700)]
configure.ac: Bump version to 1.2.92

11 years agolauncher: Print a more descriptive error message when we don't get a VT
Kristian Høgsberg [Wed, 2 Oct 2013 20:06:02 +0000 (13:06 -0700)]
launcher: Print a more descriptive error message when we don't get a VT

weston-launch has two supported use cases now: either launch from
and VT login as a regular user (running within that session) or
from an init script (systemd or such) with the -u option to create
a session for the specified user.  Running from within X or ssh is
not possible.  It's still possible to run weston as root from X or ssh
but that's strictly a development/debug/test feature.

https://bugs.freedesktop.org/show_bug.cgi?id=69727

11 years agolauncher: Add back support for specifying VT to run on
Kristian Høgsberg [Wed, 2 Oct 2013 17:53:33 +0000 (10:53 -0700)]
launcher: Add back support for specifying VT to run on

This is only available when running weston directly as root typically for
ssh logins.  It's a somewhat destructive option, as it will take over any
existing VT completely, unless there's already an display server running
there.

https://bugs.freedesktop.org/show_bug.cgi?id=69731

11 years agolauncher: Bail out if we can't be drm master
Kristian Høgsberg [Wed, 2 Oct 2013 17:49:05 +0000 (10:49 -0700)]
launcher: Bail out if we can't be drm master

If we can't be drm master, we won't be able to do anything useful with
the drm device.

11 years agolauncher: Set make sure we're drm master when opening the drm device
Kristian Høgsberg [Tue, 1 Oct 2013 22:37:09 +0000 (15:37 -0700)]
launcher: Set make sure we're drm master when opening the drm device

In case we try to run on a tty where some other process is already
drm master, back off and exit with an error message.

11 years agolauncher: Fail weston_launcher_create() if tty setup fails
Kristian Høgsberg [Tue, 1 Oct 2013 19:54:55 +0000 (12:54 -0700)]
launcher: Fail weston_launcher_create() if tty setup fails

11 years agoSet new state before emitting wake signal in weston_compsitor_wake
Neil Roberts [Mon, 30 Sep 2013 12:14:47 +0000 (13:14 +0100)]
Set new state before emitting wake signal in weston_compsitor_wake

The wake handler set up by the shell will try to unlock the screen
which works by setting up an animation which fades in the display. The
animation is started by first scheduling a repaint. Subsequent
repaints are scheduled whenever the previous frame is finished.
However in the case of the wake up signal the state is still
WESTON_COMPOSITOR_SLEEPING when the animation is started.
weston_output_schedule_repaint() ignores attempts to schedule a
repaint if the compositor is sleeping which means the animation never
gets run and will never complete.

The animation gets unstuck and continues if anything else schedules a
repaint after the state has been changed so the bug only gets hit in
certain conditions. The first wake up creates the lock surface which
causes a redraw when the first buffer is attached so the first wake up
is always ok. A redraw can be triggered in the subsequent wake ups
just by moving the mouse.

A good way to trigger the bug is to try to wake up the compositor by
pressing the shift key. If you let the compositor go back to sleep
after waking it up without unlocking it, the second press of the shift
key will not cause a redraw so the animation will not run and it won't
fade in.

https://bugs.freedesktop.org/show_bug.cgi?id=69719

11 years agoweston-egl: Update weston-egl-ext.h: s/wl_buffer/wl_resource
Tomeu Vizoso [Tue, 1 Oct 2013 10:27:19 +0000 (12:27 +0200)]
weston-egl: Update weston-egl-ext.h: s/wl_buffer/wl_resource

As struct wl_buffer has been deprecated since 1.2.

11 years agoweston-launch: Only drop privileges if running as root
Tomeu Vizoso [Tue, 1 Oct 2013 10:20:29 +0000 (12:20 +0200)]
weston-launch: Only drop privileges if running as root

11 years agocompositor: fix typo in error message
Aaron Faanes [Tue, 1 Oct 2013 03:06:39 +0000 (22:06 -0500)]
compositor: fix typo in error message

11 years agolauncher-util: pull in drm only for compositor-drm
Adrian Negreanu [Fri, 27 Sep 2013 17:58:45 +0000 (20:58 +0300)]
launcher-util: pull in drm only for compositor-drm

Add drm_set_master and drm_drop_master
as wrappers for drm(Set|Drop)Master, when building compositor-drm
or as empty functions otherwise.

Signed-off-by: Adrian Negreanu <adrian.m.negreanu@intel.com>
11 years agoResize the shell when the mode is switched
Hardening [Mon, 23 Sep 2013 22:45:53 +0000 (00:45 +0200)]
Resize the shell when the mode is switched

Resize the panel and the background when we're notified of a mode
switch.

11 years agoconfig: Don't crash if we don't have a config file
Alexandru DAMIAN [Thu, 26 Sep 2013 09:27:16 +0000 (10:27 +0100)]
config: Don't crash if we don't have a config file

Adding a check in weston_config_full_path so that
we don't crash if we started without a config file.

Signed-off-by: Alexandru DAMIAN <alexandru.damian@intel.com>
11 years agocompositor-fbdev: drop dependency on libdrm
Adrian Negreanu [Thu, 26 Sep 2013 16:31:32 +0000 (19:31 +0300)]
compositor-fbdev: drop dependency on libdrm

Signed-off-by: Adrian Negreanu <adrian.m.negreanu@intel.com>
11 years agocompositor: check if seteuid worked
Alexandru DAMIAN [Wed, 25 Sep 2013 13:47:47 +0000 (14:47 +0100)]
compositor: check if seteuid worked

Checking the return value from seteuid in
order to not launch clients with the wrong effective uid.

Signed-off-by: Alexandru DAMIAN <alexandru.damian@intel.com>
11 years agocompositor-drm: Match the EGLConfig native visual ID if it has one
Kristian Høgsberg [Wed, 25 Sep 2013 22:46:42 +0000 (15:46 -0700)]
compositor-drm: Match the EGLConfig native visual ID if it has one

We'll add the GBM format code as the native visual ID for EGLConfigs
when running on GBM.  This patch lets the drm backend pass in the
format code it's using with KMS and make sure we get a confing that
matches.  In the future, mesa will add support for 10 bpc configs
which will match the "at least 8 color bits" requirement.  By also
matching the native visual ID, we avoid rendering XRGB2101010 into a
XRGB8888 KMS framebuffer.

11 years agoevdev: Process touch up events of single-touch devices
Neil Roberts [Tue, 24 Sep 2013 19:05:07 +0000 (20:05 +0100)]
evdev: Process touch up events of single-touch devices

Previously only the touch up key event was used for single-touch
devices and the touch down event was generated on the first motion
event. This was breaking if the touch up and down events were sent
without a motion in-between because the evdev driver wouldn't generate
a touch down event and Weston would lose track of the number of touch
points that are down. This patch changes it to track the up and down
key events as pending events similar to how it does for multi-touch
devices.

https://bugs.freedesktop.org/show_bug.cgi?id=69759

11 years agoevdev: Only track one pending event
Neil Roberts [Tue, 24 Sep 2013 11:09:03 +0000 (12:09 +0100)]
evdev: Only track one pending event

Instead of having a mask of pending events there is now an enum with a
single value to represent the one pending event. The event gets
flushed explicitly as part of the handling code for each event type
rather than in the outer event reading loop. The pending event is used
so that we can combine multiple motion events into one and to make
sure that we have recieved the latest position before sending a touch
up or down event. This should fix the following problems with the old
approach:

• If you release a finger and press it down again quickly you could
  get the up and down events in the same batch. However the pending
  events were always processed in the order down then up so it would
  end up notifying two down events and then an up. The pending event
  is now always flushed when there is a new up or down event so they
  will always be in the right order.

• When it got a slot event it would immediately change the slot number
  and then set the pending event. Then when it flushed the events it
  would use the new slot number to flush the old pending event so the
  events could have the wrong finger. The pending event is now
  immediately flushed when a slot event is received so it will have
  the right finger.

• If you get more than 32 events in one read then it was resetting the
  pending events before processing the next batch in
  evdev_process_events. If four fingers were pressed down at once then
  it ended up with more than 32 events and the sync message would be
  in the second batch. The pending flag for the last finger was
  getting cleared so it never got emitted. In this patch the pending
  event is no longer reset after reading nor is it explicitly flushed.
  Instead it is flushed when we receive a EV_SYN event or a different
  pending event needs to replace it.

The touchpad handling code was trying to use the pending event
mechanism to notify the relative motion events. I'm not sure why it
was doing this because it looks the event would effectively get
emitted as soon as the touchpad_process function is finished anyway
and it wasn't accumulating the values. Instead I've just changed it to
emit the event directly.

https://bugs.freedesktop.org/show_bug.cgi?id=67563

11 years agoversion.h: Add version check macro
Pier Luigi Fiorini [Mon, 23 Sep 2013 05:26:03 +0000 (07:26 +0200)]
version.h: Add version check macro

Make it easier to check for a Weston version.

11 years agoclients: Include and link against math lib for new multi-resource
Stefan Schmidt [Mon, 23 Sep 2013 10:25:29 +0000 (11:25 +0100)]
clients: Include and link against math lib for new multi-resource

Linking failed with missing ceil() here. Making sure that we include
the header and add the missing -lm.

Signed-off-by: Stefan Schmidt <s.schmidt@samsung.com>
11 years agoinput: check that the new focus surface has a valid resource
Giulio Camuffo [Mon, 23 Sep 2013 10:33:39 +0000 (12:33 +0200)]
input: check that the new focus surface has a valid resource

Here too we must make sure the surface has a valid resource, as
there are some (xwayland, surfaces created by the shell) that
don't have it.
Fix a Weston crash when setting a mpv window fullscreen on drm.

11 years agoUpdate .gitignore
Emilio Pozuelo Monfort [Mon, 23 Sep 2013 10:49:02 +0000 (12:49 +0200)]
Update .gitignore

11 years agoweston.ini: update path for the flower client
Emilio Pozuelo Monfort [Mon, 23 Sep 2013 10:49:01 +0000 (12:49 +0200)]
weston.ini: update path for the flower client

11 years agoconfigure.ac: Update version to 1.2.91
Kristian Høgsberg [Sun, 22 Sep 2013 21:16:11 +0000 (14:16 -0700)]
configure.ac: Update version to 1.2.91

11 years agoAdd vaapi-recorder.h to SOURCES to fix distcheck
Kristian Høgsberg [Sun, 22 Sep 2013 21:28:31 +0000 (14:28 -0700)]
Add vaapi-recorder.h to SOURCES to fix distcheck

11 years agoevdev: Flush motion events when the slot changes, not just after sync
Neil Roberts [Fri, 20 Sep 2013 14:03:29 +0000 (15:03 +0100)]
evdev: Flush motion events when the slot changes, not just after sync

If two fingers are released almost simultaneously then evdev can send
the touch up events in one bunch without sending a sync event
in-between. However, the evdev_device struct only keeps track of one
pending touch up event so in this case the second touch up event would
override the first and it would be lost. This patch changes it to also
flush the events whenever the slot changes so that it will flush the
previous touch up event before trying to queue the next one.

https://bugs.freedesktop.org/show_bug.cgi?id=67563

11 years agocompositor: when unmapping a surface remove it from the compositor's list
Giulio Camuffo [Sat, 21 Sep 2013 16:08:28 +0000 (18:08 +0200)]
compositor: when unmapping a surface remove it from the compositor's list

compositor.surface_list is recreated every redraw with the mapped
surfaces, but if a surface gets unmapped and then in the same frame
weston_compositor_pick_surface() is called we must make sure it
does not pick the unmapped surface, since it traverses the
surface_list to find one.
If after the unmap the surface gets also deleted it's even more
important, as it must not pick a destroyed surface.

11 years agocompositor: Log the full path of the config file we're using
Kristian Høgsberg [Sun, 22 Sep 2013 06:17:35 +0000 (23:17 -0700)]
compositor: Log the full path of the config file we're using

11 years agoconfig-parser: Make weston_config_parse() tkae a file name
Kristian Høgsberg [Sun, 22 Sep 2013 06:02:31 +0000 (23:02 -0700)]
config-parser: Make weston_config_parse() tkae a file name

Take a basename of the config file to parse instead of an fd.

11 years agoshared: Remove no longer used parse_config_file()
Kristian Høgsberg [Sun, 22 Sep 2013 05:36:50 +0000 (22:36 -0700)]
shared: Remove no longer used parse_config_file()

11 years agotablet-shell: Use new weston_config instead of old config parse
Kristian Høgsberg [Sun, 22 Sep 2013 05:35:13 +0000 (22:35 -0700)]
tablet-shell: Use new weston_config instead of old config parse

11 years agowindow.c: Port to use weston_config instead of old parser
Kristian Høgsberg [Sun, 22 Sep 2013 05:26:10 +0000 (22:26 -0700)]
window.c: Port to use weston_config instead of old parser

11 years agoterminal: Port to new weston_config parse
Kristian Høgsberg [Sun, 22 Sep 2013 05:23:08 +0000 (22:23 -0700)]
terminal: Port to new weston_config parse

11 years agocompositor: Unlink unmapped surface instead of rebuilding surface list
Kristian Høgsberg [Sun, 22 Sep 2013 04:26:05 +0000 (21:26 -0700)]
compositor: Unlink unmapped surface instead of rebuilding surface list

When unmap and destroy a surface we need to make sure we don't pick it
before we rebuild the new surface list.  Currently we ensure this
by rebuilding the surface list when destroying a surface, but just
removing the surface should be enough.

11 years agoxwm: remove the destroy listener from the old surface signal
Giulio Camuffo [Fri, 20 Sep 2013 14:16:06 +0000 (16:16 +0200)]
xwm: remove the destroy listener from the old surface signal

11 years agoAdd a test client to test multiple pointer/keyboard resources
Neil Roberts [Thu, 19 Sep 2013 16:32:01 +0000 (17:32 +0100)]
Add a test client to test multiple pointer/keyboard resources

This adds a hacked version of simple-shm which can create multiple
pointer and keyboard resources. The resources are created with the
command line options -p and -k. Both take an integer argument which
specifies the time in seconds after the program is started when the
resource should be created. It can also take a second time with a
colon separator to specify when the resource should be released.

For example:

 weston-multi-resource -p5 -p7 -k9 -p12:14

That would create a pointer after 5 seconds, a second pointer 2
seconds later, a keyboard 2 seconds after that, a third pointer after
a further 3 seconds and finally after 2 more seconds it would release
that final pointer resource.

This can be used along with WAYLAND_DEBUG to check that it gets the
right events for example if the pointer is created while the client's
surface already has focus and so on.

11 years agoinput: Emit events on all resources for a client
Neil Roberts [Thu, 19 Sep 2013 16:32:00 +0000 (17:32 +0100)]
input: Emit events on all resources for a client

The Wayland protocol permits a client to request the pointer, keyboard
and touch multiple times from the seat global. This is very useful in a
component like Clutter-GTK where we are combining two libraries that use
Wayland together.

This change migrates the weston input handling code to emit the
events for all the resources for the client by using the newly added
wl_resource_for_each macro to iterate over the resources that are
associated with the focused surface's client.

We maintain a list of focused resources on the pointer and keyboard
which is updated when the focus changes. However since we can have
resources created after the focus has already been set we must add the
resources to the right list and also update any state.

Additionally when setting the pointer focus it will now send the
keyboard modifiers regardless of whether the focused client has a
pointer resource. This is important because otherwise if the client
gets the pointer later than you getting the keyboard then the
modifiers might not be up-to-date.

Co-author: Neil Roberts <neil@linux.intel.com>

11 years agoNotify clients on mode_switch()
Hardening [Wed, 18 Sep 2013 21:56:36 +0000 (23:56 +0200)]
Notify clients on mode_switch()

This patch implements the notification of clients during mode_switch.
As discussed on IRC, clients are notified of mode_switch only when the
"native" mode is changed and activated. That means that if the native
mode is changed and the compositor had activated a temporary mode for
a fullscreen surface, the clients will be notified only when the native
mode is restored.
The scaling factor is treated the same way as modes.

11 years agoRename current, origin, scale, origin_scale
Hardening [Wed, 18 Sep 2013 21:56:35 +0000 (23:56 +0200)]
Rename current, origin, scale, origin_scale

This patch renames that fields to have consistent names.

11 years agoxwm: set the right cursor when hovering on the decoration borders
Giulio Camuffo [Wed, 18 Sep 2013 13:20:04 +0000 (15:20 +0200)]
xwm: set the right cursor when hovering on the decoration borders

use the alternative cursor names used also in window.c, since the
names it used previously are not guaranteed to exist in all themes.

11 years agoxwm: set the window's shsurf pointer to NULL on unmap handling
Giulio Camuffo [Tue, 17 Sep 2013 14:43:45 +0000 (16:43 +0200)]
xwm: set the window's shsurf pointer to NULL on unmap handling

the unmap event will be followed by the deletion of the weston_surface,
so the shell_surface will also be deleted by the shell. Having removed
the surface_destroy_listener, the surface_destroy callback doesn't
get called, so reset the value of shsurf here.

11 years agoRestoring alpha after the shell effects.
Axel Davy [Tue, 17 Sep 2013 12:55:55 +0000 (14:55 +0200)]
Restoring alpha after the shell effects.

After the fade or zoom effects, alpha could not have been 1.0, preventing
not redrawing behind opaque windows.

This patch add a reset function in weston_surface_animation to reset
some variables the effects affect.

Signed-off-by: Axel Davy <axel.davy@ens.fr>
11 years agoinput: Fix trailing whitspaces and indent.
Stefan Schmidt [Tue, 17 Sep 2013 09:54:09 +0000 (10:54 +0100)]
input: Fix trailing whitspaces and indent.

Just some cosmetics to conform to the wayland coding style.

Signed-off-by: Stefan Schmidt <s.schmidt@samsung.com>
11 years agolauncher: Move rest of tty object into struct weston_launcher
Kristian Høgsberg [Thu, 19 Sep 2013 06:00:17 +0000 (23:00 -0700)]
launcher: Move rest of tty object into struct weston_launcher

The struct weston_launcher object will now either handle tty and vt switching
details in-process (when running weston directly as root) or talk to
the weston-launch process.

11 years agoweston-launch: Use fstat to make sure we stat the right fd
Kristian Høgsberg [Thu, 19 Sep 2013 05:14:09 +0000 (22:14 -0700)]
weston-launch: Use fstat to make sure we stat the right fd

Instead of the racy stat+open, open first and then use fstat.  We want to
make sure we're stating the fd we'll be sending to weston and nothing else.

11 years agolauncher: Handle tty setup and teardown in launcher
Kristian Høgsberg [Wed, 18 Sep 2013 05:43:22 +0000 (22:43 -0700)]
launcher: Handle tty setup and teardown in launcher

11 years agolauncher: Handle drm set/drop master and vt switch signals in launcher
Kristian Høgsberg [Wed, 18 Sep 2013 05:15:37 +0000 (22:15 -0700)]
launcher: Handle drm set/drop master and vt switch signals in launcher

11 years agocompositor: Generalize VT switching as a session_signal
Kristian Høgsberg [Tue, 17 Sep 2013 23:02:57 +0000 (16:02 -0700)]
compositor: Generalize VT switching as a session_signal

Instead of a callback from the tty module, we now have a compositor level
signal that fires when our session is activated or deactivated.

11 years agolauncher: Collect launcher state in new struct weston_launcher
Kristian Høgsberg [Tue, 17 Sep 2013 21:41:03 +0000 (14:41 -0700)]
launcher: Collect launcher state in new struct weston_launcher

We're going to add a bit more launcher state, so start out by creating
a new struct weston_launcher we can track it in.

11 years agoweston-launch: Use SOCK_SEQPACKET for the launcher socket
Kristian Høgsberg [Wed, 18 Sep 2013 18:01:48 +0000 (11:01 -0700)]
weston-launch: Use SOCK_SEQPACKET for the launcher socket

This lets us detect hang-up when weston-launch dies and clean up properly.

11 years agoweston-launch: Pass the right CLOEXEC flag to fcntl
Kristian Høgsberg [Wed, 18 Sep 2013 18:00:56 +0000 (11:00 -0700)]
weston-launch: Pass the right CLOEXEC flag to fcntl

Passing O_CLOEXEC to fcntl is wrong, we need to pass FD_CLOEXEC.

11 years agocompositor: Open drm device through launcher
Kristian Høgsberg [Tue, 17 Sep 2013 21:03:42 +0000 (14:03 -0700)]
compositor: Open drm device through launcher

11 years agoAdded tests for the vertex clipping code.
Sam Spilsbury [Fri, 13 Sep 2013 02:01:22 +0000 (10:01 +0800)]
Added tests for the vertex clipping code.

This tests (via the table-driven testing method) that the correct
number of vertices and also the correct vertices themselves
are generated for an clip box and polygon of up to eight vertices.

Also add a libshared-test.la so that we don't have to build weston-test-runner
all the time

11 years agoSplit vertex clipping code out into vertex-clipping.c
Sam Spilsbury [Fri, 13 Sep 2013 02:01:21 +0000 (10:01 +0800)]
Split vertex clipping code out into vertex-clipping.c

11 years agoMinor improvement of weston-terminal resizing
José Bollo [Fri, 13 Sep 2013 09:28:51 +0000 (11:28 +0200)]
Minor improvement of weston-terminal resizing

11 years agoAdd support for table-driven testing.
Sam Spilsbury [Fri, 13 Sep 2013 02:01:20 +0000 (10:01 +0800)]
Add support for table-driven testing.

The new TEST_P macro takes a function name and a "data" argument to
point to an arbitrary array of known size of test data. This allows
multiple tests to be run with different datasets. The array is stored
as a void * but advanced by a known size on each iteration.

The data for each invocation of the test is provided as a "data" argument,
it is the responsibility of the test to cast it to something sensible.

Also fixed single-test running to only run the tests specified

11 years agoRemove AM_LDFLAGS usage
Sam Spilsbury [Fri, 13 Sep 2013 02:01:19 +0000 (10:01 +0800)]
Remove AM_LDFLAGS usage

We are not building everything here as a module, only the test modules.

11 years agoclients: remove superfluous call
Peter Hutterer [Fri, 13 Sep 2013 01:59:00 +0000 (11:59 +1000)]
clients: remove superfluous call

11 years agoclients: de-duplicate demo clients list
Peter Hutterer [Fri, 13 Sep 2013 01:58:59 +0000 (11:58 +1000)]
clients: de-duplicate demo clients list

11 years agoxwm: set the shell_surface's title
Giulio Camuffo [Wed, 11 Sep 2013 16:20:47 +0000 (18:20 +0200)]
xwm: set the shell_surface's title

add a new function pointer to the weston_shell_interface struct that
shells will set accordingly.

11 years agoxwm: place transient windows at the right position
Giulio Camuffo [Wed, 11 Sep 2013 15:49:13 +0000 (17:49 +0200)]
xwm: place transient windows at the right position

11 years agotests: list available tests if an invalid test name is given
Peter Hutterer [Wed, 11 Sep 2013 06:08:47 +0000 (16:08 +1000)]
tests: list available tests if an invalid test name is given

11 years agotests: support -h/--help for the tests
Peter Hutterer [Wed, 11 Sep 2013 06:08:30 +0000 (16:08 +1000)]
tests: support -h/--help for the tests

Including listing the tests available in that binary

11 years agotests: include config.h in weston-test-runner
Peter Hutterer [Wed, 11 Sep 2013 06:08:04 +0000 (16:08 +1000)]
tests: include config.h in weston-test-runner

11 years agotests: use variable for test name in weston-tests-env
Peter Hutterer [Wed, 11 Sep 2013 05:58:08 +0000 (15:58 +1000)]
tests: use variable for test name in weston-tests-env

Slightly more readable and makes it easier to switch to use $2 for something
in the future (if that's ever needed).

11 years agotests: always build tests
Peter Hutterer [Wed, 11 Sep 2013 05:58:07 +0000 (15:58 +1000)]
tests: always build tests

check_PROGRAMS and friends are only built during make check. Which is a
great way of introducing compiler errors in tests. Always build them, TESTS
defines what's being run during make check.

11 years agoshell: Use wl_resource_for_each() for sending out workspace status
Kristian Høgsberg [Wed, 11 Sep 2013 19:00:47 +0000 (12:00 -0700)]
shell: Use wl_resource_for_each() for sending out workspace status

11 years agoinput: Use new wl_resource_for_each for sending updated seat caps
Rob Bradford [Fri, 6 Sep 2013 16:48:19 +0000 (17:48 +0100)]
input: Use new wl_resource_for_each for sending updated seat caps

11 years agovaapi-recorder: Don't leak drm fd
Ander Conselvan de Oliveira [Fri, 6 Sep 2013 14:49:38 +0000 (17:49 +0300)]
vaapi-recorder: Don't leak drm fd

Make vaapi_recorder take onwership of the fd and close it at destroy
time.

11 years agovaapi-recorder: Encode frames in a separate thread
Ander Conselvan de Oliveira [Fri, 6 Sep 2013 14:49:37 +0000 (17:49 +0300)]
vaapi-recorder: Encode frames in a separate thread

Previously, vaapi_recorder_frame() would wait until the encoded
contents for a frame is written to the output file descriptor. This
delayed the repainting of the next frame, and affected frame rate
when capturing with high resolutions. Instead, wait only if there is
and attempted to encode two frames at the same time.

Increases framerate from 30 to 60 fps when capturing at 1920x1200 on
my SandryBridge system, although there are periodic slowdowns due to
disk writes.

11 years agoadd libhybris support
Adrian Negreanu [Fri, 6 Sep 2013 12:16:09 +0000 (15:16 +0300)]
add libhybris support

it uses the Android fbdev HAL[1] (through libhybris[2])
and the libhybris implementation of wayland-egl.

Configure flags:
 cairo:
   --enable-glesv2=yes  --enable-egl=yes
 weston:
   --with-cairo-glesv2 --enable-fbdev-compositor
 hybris:
   --enable-wayland --enable-arch=x86
   --with-android-headers=<android-headers> --enable-alinker=jb

The android headers are extracted from an AOSP tree,
using hybris/utils/extract-headers.sh

[1]:
https://github.com/android/platform_hardware_libhardware/blob/master/include/hardware/fb.h

[2]: https://github.com/libhybris/libhybris

Signed-off-by: Adrian Negreanu <adrian.m.negreanu@intel.com>
11 years agoterminal: Stop complaining about OSC escape code 7
Kristian Høgsberg [Wed, 11 Sep 2013 18:52:56 +0000 (11:52 -0700)]
terminal: Stop complaining about OSC escape code 7

This is the current working directory of the shell as an URI.  We
don't use that for anythign at the moment, but let's not complain
about it at least.

11 years agocompositor-x11: Copying xkb_info when creating a seat causes problems
Andrew Wedgbury [Fri, 6 Sep 2013 08:29:12 +0000 (08:29 +0000)]
compositor-x11: Copying xkb_info when creating a seat causes problems

Sorry, I missed updating use of xkb_info in compositor-x11.c.
I've updated the patch.

11 years agofbdev: Support of TrueColor and Directcolor of video hardware
Marc Chalain [Tue, 3 Sep 2013 14:47:43 +0000 (16:47 +0200)]
fbdev: Support of TrueColor and Directcolor of video hardware

backend check the type of the framebuffer and accept DirectColor and TrueColor
I use a "switch case" to implement other cases in the future.

11 years agogl_renderer: Use EGL_WAYLAND_Y_INVERTED_WL to query wl_buffer's orientation
Stanislav Vorobiov [Thu, 29 Aug 2013 07:36:44 +0000 (11:36 +0400)]
gl_renderer: Use EGL_WAYLAND_Y_INVERTED_WL to query wl_buffer's orientation

11 years agoCopying xkb_info when creating a seat causes problems
Andrew Wedgbury [Thu, 5 Sep 2013 13:31:40 +0000 (13:31 +0000)]
Copying xkb_info when creating a seat causes problems

Hi Kristian,

Here's a new patch for ref counting weston_xkb_info, as suggested.
So a seat created with a NULL keymap will now point to the global xkb_info.

11 years agoinput: Initialize data source to NULL
Kristian Høgsberg [Wed, 11 Sep 2013 16:45:03 +0000 (09:45 -0700)]
input: Initialize data source to NULL

This way we do the right thing, when we get a NULL wl_resource for self-dnd.

11 years agocompositor: Return 0 on success
Kristian Høgsberg [Wed, 11 Sep 2013 16:42:26 +0000 (09:42 -0700)]
compositor: Return 0 on success

Add missing return statement.

11 years agodnd: Support dropping as text/plain;charset=utf-8
Kristian Høgsberg [Mon, 9 Sep 2013 22:03:27 +0000 (15:03 -0700)]
dnd: Support dropping as text/plain;charset=utf-8

11 years agoxwm: Fix fd leak in weston_wm_send_data()
Kristian Høgsberg [Thu, 5 Sep 2013 05:32:50 +0000 (22:32 -0700)]
xwm: Fix fd leak in weston_wm_send_data()

The call to source->send(source, mime_type, p[1]); dups the fd, and we have
to close p[1] to not leak it.

11 years agoxwm: Try a non-blocking write before setting up an fd watch for property data
Kristian Høgsberg [Thu, 5 Sep 2013 05:12:28 +0000 (22:12 -0700)]
xwm: Try a non-blocking write before setting up an fd watch for property data

Typically we can write it immediately without blocking, so save the overhead
of setting up an fd watch and writing the data in a callback.  For the
case where the immediate write doesn't write all data, we fallback and
set up the fd watch as usual.

This patch also consolidates setting up the async write a bit.

11 years agoxwm: Add support for bridging Xdnd to wayaland DnD
Kristian Høgsberg [Thu, 5 Sep 2013 04:12:26 +0000 (21:12 -0700)]
xwm: Add support for bridging Xdnd to wayaland DnD

11 years agoxwm: Only handle selection notify events for CLIPBOARD in selection code
Kristian Høgsberg [Thu, 5 Sep 2013 04:09:24 +0000 (21:09 -0700)]
xwm: Only handle selection notify events for CLIPBOARD in selection code

11 years agoxwm: Fix fd leak in selection code
Kristian Høgsberg [Thu, 5 Sep 2013 03:48:46 +0000 (20:48 -0700)]
xwm: Fix fd leak in selection code

The file descriptors we receive in the wayland protocol callbacks are
already O_CLOEXEC, so don't dup them to set O_CLOEXEC.`

11 years agocompositor: Split dnd setup up into weston_seat_start_drag()
Kristian Høgsberg [Thu, 5 Sep 2013 03:44:26 +0000 (20:44 -0700)]
compositor: Split dnd setup up into weston_seat_start_drag()

This makes the drag-and-drop code available to in-weston data sources,
similar to how we can set a selection data source internally.  The
wl_data_device.start_drag entry point now calls this function after
validating protocol arguments.