compositor: Introduce a weston_renderer object
[profile/ivi/weston.git] / src / compositor.h
index 08dcd77..763decc 100644 (file)
@@ -47,11 +47,13 @@ struct weston_surface;
 struct shell_surface;
 struct weston_seat;
 struct weston_output;
+struct input_method;
 
 enum weston_keyboard_modifier {
        MODIFIER_CTRL = (1 << 0),
        MODIFIER_ALT = (1 << 1),
        MODIFIER_SUPER = (1 << 2),
+       MODIFIER_SHIFT = (1 << 3),
 };
 
 enum weston_led {
@@ -82,7 +84,7 @@ struct weston_shell_interface {
        void (*set_toplevel)(struct shell_surface *shsurf);
 
        void (*set_transient)(struct shell_surface *shsurf,
-                             struct shell_surface *pshsurf,
+                             struct weston_surface *parent,
                              int x, int y, uint32_t flags);
        int (*move)(struct shell_surface *shsurf, struct weston_seat *ws);
        int (*resize)(struct shell_surface *shsurf,
@@ -94,16 +96,46 @@ struct weston_border {
        int32_t left, right, top, bottom;
 };
 
+struct weston_animation {
+       void (*frame)(struct weston_animation *animation,
+                     struct weston_output *output, uint32_t msecs);
+       int frame_counter;
+       struct wl_list link;
+};
+
+struct weston_spring {
+       double k;
+       double friction;
+       double current;
+       double target;
+       double previous;
+       uint32_t timestamp;
+};
+
 enum {
-       ZOOM_POINTER,
-       ZOOM_TEXT_CURSOR
+       ZOOM_FOCUS_POINTER,
+       ZOOM_FOCUS_TEXT
+};
+
+struct weston_fixed_point {
+       wl_fixed_t x, y;
 };
 
 struct weston_output_zoom {
        int active;
+       uint32_t type;
        float increment;
        float level;
+       float max_level;
        float trans_x, trans_y;
+       struct weston_animation animation_z;
+       struct weston_spring spring_z;
+       struct weston_animation animation_xy;
+       struct weston_spring spring_xy;
+       struct weston_fixed_point from;
+       struct weston_fixed_point to;
+       struct weston_fixed_point current;
+       struct weston_fixed_point text_cursor;
 };
 
 /* bit compatible with drm definitions. */
@@ -114,37 +146,32 @@ enum dpms_enum {
        WESTON_DPMS_OFF
 };
 
-struct weston_read_pixels {
-       void *data;
-       int x, y, width, height;
-       void (*done)(struct weston_read_pixels *read_pixels,
-                    struct weston_output *output);
-       struct wl_list link;
-};
-
 struct weston_output {
        uint32_t id;
 
+       EGLSurface egl_surface;
        struct wl_list link;
        struct wl_list resource_list;
        struct wl_global *global;
        struct weston_compositor *compositor;
        struct weston_matrix matrix;
-       struct wl_list frame_callback_list;
-       int32_t x, y, mm_width, mm_height;
+       struct wl_list animation_list;
+       int32_t x, y, width, height;
+       int32_t mm_width, mm_height;
        struct weston_border border;
        pixman_region32_t region;
        pixman_region32_t previous_damage;
-       uint32_t flags;
        int repaint_needed;
        int repaint_scheduled;
        struct weston_output_zoom zoom;
        int dirty;
-       struct wl_list read_pixels_list;
        struct wl_signal frame_signal;
+       uint32_t frame_time;
+       int disable_planes;
 
        char *make, *model;
        uint32_t subpixel;
+       uint32_t transform;
        
        struct weston_mode *current;
        struct weston_mode *origin;
@@ -162,68 +189,66 @@ struct weston_output {
        void (*set_dpms)(struct weston_output *output, enum dpms_enum level);
 };
 
+struct weston_xkb_info {
+       struct xkb_keymap *keymap;
+       int keymap_fd;
+       size_t keymap_size;
+       char *keymap_area;
+       xkb_mod_index_t shift_mod;
+       xkb_mod_index_t caps_mod;
+       xkb_mod_index_t ctrl_mod;
+       xkb_mod_index_t alt_mod;
+       xkb_mod_index_t mod2_mod;
+       xkb_mod_index_t mod3_mod;
+       xkb_mod_index_t super_mod;
+       xkb_mod_index_t mod5_mod;
+       xkb_led_index_t num_led;
+       xkb_led_index_t caps_led;
+       xkb_led_index_t scroll_led;
+};
+
 struct weston_seat {
        struct wl_seat seat;
        struct wl_pointer pointer;
+       int has_pointer;
        struct wl_keyboard keyboard;
+       int has_keyboard;
        struct wl_touch touch;
+       int has_touch;
+
        struct weston_compositor *compositor;
        struct weston_surface *sprite;
+       struct wl_listener sprite_destroy_listener;
        struct weston_surface *drag_surface;
        struct wl_listener drag_surface_destroy_listener;
        int32_t hotspot_x, hotspot_y;
        struct wl_list link;
        enum weston_keyboard_modifier modifier_state;
-       int hw_cursor;
        struct wl_surface *saved_kbd_focus;
        struct wl_listener saved_kbd_focus_listener;
 
        uint32_t num_tp;
-       struct wl_surface *touch_focus;
-       struct wl_listener touch_focus_listener;
-       struct wl_resource *touch_focus_resource;
-       struct wl_listener touch_focus_resource_listener;
 
        struct wl_listener new_drag_icon_listener;
 
        void (*led_update)(struct weston_seat *ws, enum weston_led leds);
 
+       struct weston_xkb_info xkb_info;
        struct {
                struct xkb_state *state;
-               uint32_t mods_depressed;
-               uint32_t mods_latched;
-               uint32_t mods_locked;
-               uint32_t group;
                enum weston_led leds;
        } xkb_state;
+
+       struct input_method *input_method;
 };
 
 struct weston_shader {
        GLuint program;
        GLuint vertex_shader, fragment_shader;
        GLint proj_uniform;
-       GLint tex_uniform;
+       GLint tex_uniforms[3];
        GLint alpha_uniform;
-       GLint brightness_uniform;
-       GLint saturation_uniform;
        GLint color_uniform;
-       GLint texwidth_uniform;
-       GLint opaque_uniform;
-};
-
-struct weston_animation {
-       void (*frame)(struct weston_animation *animation,
-                     struct weston_output *output, uint32_t msecs);
-       struct wl_list link;
-};
-
-struct weston_spring {
-       double k;
-       double friction;
-       double current;
-       double target;
-       double previous;
-       uint32_t timestamp;
 };
 
 enum {
@@ -237,15 +262,32 @@ struct weston_layer {
        struct wl_list link;
 };
 
+struct weston_plane {
+       pixman_region32_t damage;
+       int32_t x, y;
+};
+
+struct weston_renderer {
+       void (*repaint_output)(struct weston_output *output,
+                              pixman_region32_t *output_damage);
+       void (*flush_damage)(struct weston_surface *surface);
+       void (*attach)(struct weston_surface *es, struct wl_buffer *buffer);
+};
+
 struct weston_compositor {
        struct wl_shm *shm;
        struct wl_signal destroy_signal;
 
-       EGLDisplay display;
-       EGLContext context;
-       EGLConfig config;
+       EGLDisplay egl_display;
+       EGLContext egl_context;
+       EGLConfig egl_config;
        GLuint fbo;
-       struct weston_shader texture_shader;
+       struct weston_shader texture_shader_rgba;
+       struct weston_shader texture_shader_rgbx;
+       struct weston_shader texture_shader_egl_external;
+       struct weston_shader texture_shader_y_uv;
+       struct weston_shader texture_shader_y_u_v;
+       struct weston_shader texture_shader_y_xuxv;
        struct weston_shader solid_shader;
        struct weston_shader *current_shader;
        struct wl_display *wl_display;
@@ -255,12 +297,12 @@ struct weston_compositor {
        struct wl_signal lock_signal;
        struct wl_signal unlock_signal;
 
+       struct wl_signal show_input_panel_signal;
+       struct wl_signal hide_input_panel_signal;
+
        struct wl_event_loop *input_loop;
        struct wl_event_source *input_loop_source;
 
-       /* There can be more than one, but not right now... */
-       struct weston_seat *seat;
-
        struct weston_layer fade_layer;
        struct weston_layer cursor_layer;
 
@@ -268,8 +310,9 @@ struct weston_compositor {
        struct wl_list seat_list;
        struct wl_list layer_list;
        struct wl_list surface_list;
-       struct wl_list binding_list;
-       struct wl_list animation_list;
+       struct wl_list key_binding_list;
+       struct wl_list button_binding_list;
+       struct wl_list axis_binding_list;
        struct {
                struct weston_spring spring;
                struct weston_animation animation;
@@ -283,11 +326,16 @@ struct weston_compositor {
        int idle_time;                  /* effective timeout, s */
 
        /* Repaint state. */
-       struct wl_array vertices, indices;
-       pixman_region32_t damage;
+       struct wl_array vertices;
+       struct wl_array indices; /* only used in compositor-wayland */
+       struct wl_array vtxcnt;
+       struct weston_plane primary_plane;
+       int fan_debug;
 
        uint32_t focus;
 
+       struct weston_renderer *renderer;
+
        PFNGLEGLIMAGETARGETRENDERBUFFERSTORAGEOESPROC
                image_target_renderbuffer_storage;
        PFNGLEGLIMAGETARGETTEXTURE2DOESPROC image_target_texture_2d;
@@ -299,9 +347,11 @@ struct weston_compositor {
 
        PFNEGLBINDWAYLANDDISPLAYWL bind_display;
        PFNEGLUNBINDWAYLANDDISPLAYWL unbind_display;
+       PFNEGLQUERYWAYLANDBUFFERWL query_buffer;
        int has_bind_display;
 
        void (*destroy)(struct weston_compositor *ec);
+       void (*restore)(struct weston_compositor *ec);
        int (*authenticate)(struct weston_compositor *c, uint32_t id);
 
        void (*ping_handler)(struct weston_surface *surface, uint32_t serial);
@@ -310,21 +360,9 @@ struct weston_compositor {
 
        uint32_t output_id_pool;
 
-       struct {
-               struct xkb_rule_names names;
-               struct xkb_context *context;
-               struct xkb_keymap *keymap;
-               xkb_mod_index_t ctrl_mod;
-               xkb_mod_index_t alt_mod;
-               xkb_mod_index_t super_mod;
-               xkb_led_index_t num_led;
-               xkb_led_index_t caps_led;
-               xkb_led_index_t scroll_led;
-       } xkb_info;
-};
-
-enum weston_output_flags {
-       WL_OUTPUT_FLIPPED = 0x01
+       struct xkb_rule_names xkb_names;
+       struct xkb_context *xkb_context;
+       struct weston_xkb_info xkb_info;
 };
 
 struct weston_region {
@@ -360,7 +398,8 @@ struct weston_region {
 struct weston_surface {
        struct wl_surface surface;
        struct weston_compositor *compositor;
-       GLuint texture;
+       GLuint textures[3];
+       int num_textures;
        pixman_region32_t clip;
        pixman_region32_t damage;
        pixman_region32_t opaque;
@@ -370,11 +409,8 @@ struct weston_surface {
        struct wl_list layer_link;
        struct weston_shader *shader;
        GLfloat color[4];
-       GLfloat opaque_rect[4];
        GLfloat alpha;
-       GLfloat brightness;
-       GLfloat saturation;
-       int blend;
+       struct weston_plane *plane;
 
        /* Surface geometry state, mutable.
         * If you change anything, set dirty = 1.
@@ -422,7 +458,9 @@ struct weston_surface {
 
        struct wl_list frame_callback_list;
 
-       EGLImageKHR image;
+       EGLImageKHR images[3];
+       GLenum target;
+       int num_images;
 
        struct wl_buffer *buffer;
        struct wl_listener buffer_destroy_listener;
@@ -436,13 +474,15 @@ struct weston_surface {
        void *private;
 };
 
+enum weston_key_state_update {
+       STATE_UPDATE_AUTOMATIC,
+       STATE_UPDATE_NONE,
+};
+
 void
 weston_surface_update_transform(struct weston_surface *surface);
 
 void
-weston_surface_to_global(struct weston_surface *surface,
-                        int32_t sx, int32_t sy, int32_t *x, int32_t *y);
-void
 weston_surface_to_global_fixed(struct weston_surface *surface,
                               wl_fixed_t sx, wl_fixed_t sy,
                               wl_fixed_t *x, wl_fixed_t *y);
@@ -451,6 +491,9 @@ weston_surface_to_global_float(struct weston_surface *surface,
                               GLfloat sx, GLfloat sy, GLfloat *x, GLfloat *y);
 
 void
+weston_surface_from_global_float(struct weston_surface *surface,
+                                GLfloat x, GLfloat y, GLfloat *sx, GLfloat *sy);
+void
 weston_surface_from_global(struct weston_surface *surface,
                           int32_t x, int32_t y, int32_t *sx, int32_t *sy);
 void
@@ -470,44 +513,49 @@ void
 weston_surface_activate(struct weston_surface *surface,
                        struct weston_seat *seat);
 void
-weston_surface_draw(struct weston_surface *es,
-                   struct weston_output *output, pixman_region32_t *damage);
-
-void
-notify_motion(struct wl_seat *seat, uint32_t time,
+notify_motion(struct weston_seat *seat, uint32_t time,
              wl_fixed_t x, wl_fixed_t y);
 void
-notify_button(struct wl_seat *seat, uint32_t time, int32_t button,
-             uint32_t state);
+notify_button(struct weston_seat *seat, uint32_t time, int32_t button,
+             enum wl_pointer_button_state state);
+void
+notify_axis(struct weston_seat *seat, uint32_t time, uint32_t axis,
+           wl_fixed_t value);
 void
-notify_axis(struct wl_seat *seat, uint32_t time, uint32_t axis,
-           int32_t value);
+notify_key(struct weston_seat *seat, uint32_t time, uint32_t key,
+          enum wl_keyboard_key_state state,
+          enum weston_key_state_update update_state);
 void
-notify_key(struct wl_seat *seat, uint32_t time, uint32_t key,
-          uint32_t state);
+notify_modifiers(struct weston_seat *seat, uint32_t serial);
 
 void
-notify_pointer_focus(struct wl_seat *seat, struct weston_output *output,
+notify_pointer_focus(struct weston_seat *seat, struct weston_output *output,
                     wl_fixed_t x, wl_fixed_t y);
 
 void
-notify_keyboard_focus(struct wl_seat *seat, struct wl_array *keys);
+notify_keyboard_focus_in(struct weston_seat *seat, struct wl_array *keys,
+                        enum weston_key_state_update update_state);
+void
+notify_keyboard_focus_out(struct weston_seat *seat);
 
 void
-notify_touch(struct wl_seat *seat, uint32_t time, int touch_id,
+notify_touch(struct weston_seat *seat, uint32_t time, int touch_id,
             wl_fixed_t x, wl_fixed_t y, int touch_type);
 
 void
 weston_layer_init(struct weston_layer *layer, struct wl_list *below);
 
 void
-weston_output_finish_frame(struct weston_output *output, int msecs);
+weston_plane_init(struct weston_plane *plane, int32_t x, int32_t y);
 void
-weston_output_damage(struct weston_output *output);
+weston_plane_release(struct weston_plane *plane);
+
+void
+weston_output_finish_frame(struct weston_output *output, uint32_t msecs);
 void
-weston_output_do_read_pixels(struct weston_output *output);
+weston_output_schedule_repaint(struct weston_output *output);
 void
-weston_compositor_repick(struct weston_compositor *compositor);
+weston_output_damage(struct weston_output *output);
 void
 weston_compositor_schedule_repaint(struct weston_compositor *compositor);
 void
@@ -525,16 +573,35 @@ weston_compositor_update_drag_surfaces(struct weston_compositor *compositor);
 
 
 struct weston_binding;
-typedef void (*weston_binding_handler_t)(struct wl_seat *seat,
-                                        uint32_t time, uint32_t key,
-                                        uint32_t button,
-                                        uint32_t axis,
-                                        int32_t value, void *data);
+typedef void (*weston_key_binding_handler_t)(struct wl_seat *seat,
+                                            uint32_t time, uint32_t key,
+                                            void *data);
+struct weston_binding *
+weston_compositor_add_key_binding(struct weston_compositor *compositor,
+                                 uint32_t key,
+                                 enum weston_keyboard_modifier modifier,
+                                 weston_key_binding_handler_t binding,
+                                 void *data);
+
+typedef void (*weston_button_binding_handler_t)(struct wl_seat *seat,
+                                               uint32_t time, uint32_t button,
+                                               void *data);
+struct weston_binding *
+weston_compositor_add_button_binding(struct weston_compositor *compositor,
+                                    uint32_t button,
+                                    enum weston_keyboard_modifier modifier,
+                                    weston_button_binding_handler_t binding,
+                                    void *data);
+
+typedef void (*weston_axis_binding_handler_t)(struct wl_seat *seat,
+                                             uint32_t time, uint32_t axis,
+                                             wl_fixed_t value, void *data);
 struct weston_binding *
-weston_compositor_add_binding(struct weston_compositor *compositor,
-                             uint32_t key, uint32_t button, uint32_t axis,
-                             enum weston_keyboard_modifier modifier,
-                             weston_binding_handler_t binding, void *data);
+weston_compositor_add_axis_binding(struct weston_compositor *compositor,
+                                  uint32_t axis,
+                                  enum weston_keyboard_modifier modifier,
+                                  weston_axis_binding_handler_t binding,
+                                  void *data);
 void
 weston_binding_destroy(struct weston_binding *binding);
 
@@ -542,11 +609,20 @@ void
 weston_binding_list_destroy_all(struct wl_list *list);
 
 void
-weston_compositor_run_binding(struct weston_compositor *compositor,
-                             struct weston_seat *seat,
-                             uint32_t time,
-                             uint32_t key, uint32_t button, uint32_t axis,
-                             int32_t value);
+weston_compositor_run_key_binding(struct weston_compositor *compositor,
+                                 struct weston_seat *seat, uint32_t time,
+                                 uint32_t key,
+                                 enum wl_keyboard_key_state state);
+void
+weston_compositor_run_button_binding(struct weston_compositor *compositor,
+                                    struct weston_seat *seat, uint32_t time,
+                                    uint32_t button,
+                                    enum wl_pointer_button_state value);
+void
+weston_compositor_run_axis_binding(struct weston_compositor *compositor,
+                                  struct weston_seat *seat, uint32_t time,
+                                  uint32_t axis, int32_t value);
+
 int
 weston_environment_get_fd(const char *env);
 
@@ -574,42 +650,74 @@ void
 weston_surface_assign_output(struct weston_surface *surface);
 
 void
+weston_surface_schedule_repaint(struct weston_surface *surface);
+
+void
 weston_surface_damage(struct weston_surface *surface);
 
 void
 weston_surface_damage_below(struct weston_surface *surface);
 
 void
+weston_surface_move_to_plane(struct weston_surface *surface,
+                            struct weston_plane *plane);
+void
+weston_surface_unmap(struct weston_surface *surface);
+
+void
 weston_buffer_post_release(struct wl_buffer *buffer);
 
 uint32_t
 weston_compositor_get_time(void);
 
 int
-weston_compositor_init(struct weston_compositor *ec, struct wl_display *display);
+weston_compositor_init(struct weston_compositor *ec, struct wl_display *display,
+                      int argc, char *argv[], const char *config_file);
 void
 weston_compositor_shutdown(struct weston_compositor *ec);
 void
-weston_output_update_zoom(struct weston_output *output,
-                                               int x, int y, uint32_t type);
+weston_text_cursor_position_notify(struct weston_surface *surface,
+                                               wl_fixed_t x, wl_fixed_t y);
+void
+weston_output_init_zoom(struct weston_output *output);
 void
-weston_text_cursor_position_notify(struct weston_surface *surface, int x, int y);
+weston_output_update_zoom(struct weston_output *output, uint32_t type);
 void
 weston_output_update_matrix(struct weston_output *output);
 void
 weston_output_move(struct weston_output *output, int x, int y);
 void
 weston_output_init(struct weston_output *output, struct weston_compositor *c,
-                  int x, int y, int width, int height, uint32_t flags);
+                  int x, int y, int width, int height, uint32_t transform);
 void
 weston_output_destroy(struct weston_output *output);
 
 void
 weston_seat_init(struct weston_seat *seat, struct weston_compositor *ec);
+void
+weston_seat_init_pointer(struct weston_seat *seat);
+void
+weston_seat_init_keyboard(struct weston_seat *seat, struct xkb_keymap *keymap);
+void
+weston_seat_init_touch(struct weston_seat *seat);
 
 void
 weston_seat_release(struct weston_seat *seat);
 
+/* String literal of spaces, the same width as the timestamp. */
+#define STAMP_SPACE "               "
+
+void
+weston_log_file_open(const char *filename);
+void
+weston_log_file_close(void);
+int
+weston_log(const char *fmt, ...)
+       __attribute__ ((format (printf, 1, 2)));
+int
+weston_log_continue(const char *fmt, ...)
+       __attribute__ ((format (printf, 1, 2)));
+
 enum {
        TTY_ENTER_VT,
        TTY_LEAVE_VT
@@ -624,15 +732,25 @@ tty_create(struct weston_compositor *compositor,
 void
 tty_destroy(struct tty *tty);
 
+void
+tty_reset(struct tty *tty);
+
 int
 tty_activate_vt(struct tty *tty, int vt);
 
 void
 screenshooter_create(struct weston_compositor *ec);
 
+struct clipboard *
+clipboard_create(struct weston_seat *seat);
+
 void
 text_cursor_position_notifier_create(struct weston_compositor *ec);
 
+void
+input_method_create(struct weston_compositor *ec,
+                   struct weston_seat *seat);
+
 struct weston_process;
 typedef void (*weston_process_cleanup_func_t)(struct weston_process *process,
                                            int status);
@@ -655,20 +773,19 @@ weston_watch_process(struct weston_process *process);
 int
 weston_xserver_init(struct weston_compositor *compositor);
 
-struct weston_zoom;
-typedef        void (*weston_zoom_done_func_t)(struct weston_zoom *zoom, void *data);
+struct weston_surface_animation;
+typedef        void (*weston_surface_animation_done_func_t)(struct weston_surface_animation *animation, void *data);
 
-struct weston_zoom *
+struct weston_surface_animation *
 weston_zoom_run(struct weston_surface *surface, GLfloat start, GLfloat stop,
-               weston_zoom_done_func_t done, void *data);
-
-struct weston_fade;
-typedef        void (*weston_fade_done_func_t)(struct weston_fade *fade, void *data);
+               weston_surface_animation_done_func_t done, void *data);
 
-struct weston_fade *
+struct weston_surface_animation *
 weston_fade_run(struct weston_surface *surface,
-               weston_fade_done_func_t done, void *data);
-
+               weston_surface_animation_done_func_t done, void *data);
+struct weston_surface_animation *
+weston_slide_run(struct weston_surface *surface, GLfloat start, GLfloat stop,
+                weston_surface_animation_done_func_t done, void *data);
 
 void
 weston_surface_set_color(struct weston_surface *surface,
@@ -678,9 +795,13 @@ void
 weston_surface_destroy(struct weston_surface *surface);
 
 struct weston_compositor *
-backend_init(struct wl_display *display, int argc, char *argv[]);
+backend_init(struct wl_display *display, int argc, char *argv[],
+            const char *config_file);
 
 int
 weston_output_switch_mode(struct weston_output *output, struct weston_mode *mode);
 
+int
+gles2_renderer_init(struct weston_compositor *ec);
+
 #endif