X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fwayland.hpp;h=f7f9ce5248bfd0da7ae680328ebe06515f70c234;hb=224a49e95723b74640ac9f99f9d33be6ee3686d2;hp=da01eb3ce6acb3474d0cbf922e1181830bbd8993;hpb=fdc1e4622d8aae5bf380e4b197ab616fed7efd34;p=staging%2Fwindowmanager.git diff --git a/src/wayland.hpp b/src/wayland.hpp index da01eb3..f7f9ce5 100644 --- a/src/wayland.hpp +++ b/src/wayland.hpp @@ -6,7 +6,7 @@ #include "util.h" #include -#include +#include #include #include @@ -27,7 +27,7 @@ struct wayland_proxy { // custom wayland dtor if (this->proxy) { logdebug("%s %p @ %p", __func__, this, this->proxy); - wl_proxy_destroy(reinterpret_cast(proxy)); + wl_proxy_destroy(reinterpret_cast(this->proxy)); } } }; @@ -39,26 +39,6 @@ struct wayland_proxy { // |_| |_|\__,_|_| |_| |_|\___||___/ .__/ \__,_|\___\___| \_/\_/ |_| // |_| namespace wl { -struct registry; - -// _ _ _ -// __| (_)___ _ __ | | __ _ _ _ -// / _` | / __| '_ \| |/ _` | | | | -// | (_| | \__ \ |_) | | (_| | |_| | -// \__,_|_|___/ .__/|_|\__,_|\__, | -// |_| |___/ -struct display { - std::unique_ptr> - d; - std::unique_ptr r; - - display(); - ~display(); - bool ok() const; - void roundtrip(); - int dispatch(); -}; - // _ _ // _ __ ___ __ _(_)___| |_ _ __ _ _ // | '__/ _ \/ _` | / __| __| '__| | | | @@ -67,7 +47,7 @@ struct display { // |___/ |___/ struct registry : public wayland_proxy { typedef std::function binder; - std::map bindings; + std::unordered_map bindings; registry(struct wl_display *d); ~registry(); @@ -79,6 +59,25 @@ struct registry : public wayland_proxy { void global_remove(uint32_t name); }; +// _ _ _ +// __| (_)___ _ __ | | __ _ _ _ +// / _` | / __| '_ \| |/ _` | | | | +// | (_| | \__ \ |_) | | (_| | |_| | +// \__,_|_|___/ .__/|_|\__,_|\__, | +// |_| |___/ +struct display { + std::unique_ptr d; + struct registry r; + + display(); + ~display(); + bool ok() const; + void roundtrip(); + int dispatch(); + void flush(); + int get_fd() const; +}; + // _ _ // ___ _ _| |_ _ __ _ _| |_ // / _ \| | | | __| '_ \| | | | __| @@ -86,7 +85,11 @@ struct registry : public wayland_proxy { // \___/ \__,_|\__| .__/ \__,_|\__| // |_| struct output : wayland_proxy { - output(struct wl_registry *registry, uint32_t name, uint32_t version); + int width{}; + int height{}; + int refresh{}; + + output(struct wl_registry *r, uint32_t name, uint32_t v); // Events void geometry(int32_t x, int32_t y, int32_t pw, int32_t ph, int32_t subpel, @@ -110,45 +113,24 @@ struct output : wayland_proxy { // |___/ namespace genivi { -// -// _ __ __ _ _ __ ___ ___ ___ _ __ __ _ ___ ___ -// | '_ \ / _` | '_ ` _ \ / _ \/ __| '_ \ / _` |/ __/ _ \ -// | | | | (_| | | | | | | __/\__ \ |_) | (_| | (_| __/ -// |_| |_|\__,_|_| |_| |_|\___||___/ .__/ \__,_|\___\___| -// |_| -// _ _ __ -// _ __ ___ | |_(_)/ _|_ _ -// | '_ \ / _ \| __| | |_| | | | -// | | | | (_) | |_| | _| |_| | -// |_| |_|\___/ \__|_|_| \__, | -// |___/ -namespace notify { -enum property { - Dimensions, // i.e. configure - DestRect, - SrcRect, - ZOrder, - Vibility, - Opacity, - Layer, - Surface, - Content, - Orientation, - Screen, +struct size { + uint32_t w, h; }; -template -struct notifier { - typedef std::function ReceiverT; +struct rect { + uint32_t w, h; + int32_t x, y; +}; - std::vector receivers; +struct controller; - virtual ~notifier() {} +struct controller_child { + struct controller *parent; + uint32_t id; - void add_receiver(ReceiverT); - void notify(enum property) const; + controller_child(struct controller *c, uint32_t i) : parent(c), id(i) {} + virtual ~controller_child() {} }; -} // __ // ___ _ _ _ __ / _| __ _ ___ ___ @@ -157,27 +139,17 @@ struct notifier { // |___/\__,_|_| |_| \__,_|\___\___| // struct surface : public wayland_proxy, - notify::notifier { - uint32_t id; - - surface(uint32_t i, struct ivi_controller *c); + controller_child { + struct rect dst_rect; + struct rect src_rect; + struct size size; + int32_t orientation; + int32_t visibility; + float opacity; + + surface(uint32_t i, struct controller *c); ~surface() override; - // Events - void visibility(int32_t visibility); - void opacity(float opacity); - void source_rectangle(int32_t x, int32_t y, int32_t width, int32_t height); - void destination_rectangle(int32_t x, int32_t y, int32_t width, - int32_t height); - void configuration(int32_t width, int32_t height); - void orientation(int32_t orientation); - void pixelformat(int32_t pixelformat); - void layer(struct ivi_controller_layer *layer); - void stats(uint32_t redraw_count, uint32_t frame_count, - uint32_t update_count, uint32_t pid, const char *process_name); - void destroyed(); - void content(int32_t content_state); - // Requests inline void set_visibility(uint32_t visibility) { ivi_controller_surface_set_visibility(this->proxy, visibility); @@ -225,23 +197,18 @@ struct surface : public wayland_proxy, // |_|\__,_|\__, |\___|_| // |___/ struct layer : public wayland_proxy, - notify::notifier { - uint32_t id; - - layer(uint32_t i, struct ivi_controller *c); + controller_child { + struct rect dst_rect; + struct rect src_rect; + struct size size; + int32_t orientation; + int32_t visibility; + float opacity; + + layer(uint32_t i, struct controller *c); + layer(uint32_t i, int32_t w, int32_t h, struct controller *c); ~layer() override; - // Events - void visibility(int32_t visibility); - void opacity(float opacity); - void source_rectangle(int32_t x, int32_t y, int32_t width, int32_t height); - void destination_rectangle(int32_t x, int32_t y, int32_t width, - int32_t height); - void configuration(int32_t width, int32_t height); - void orientation(int32_t orientation); - void screen(struct wl_output *screen); - void destroyed(); - // Requests inline void set_visibility(uint32_t visibility) { ivi_controller_layer_set_visibility(this->proxy, visibility); @@ -287,8 +254,13 @@ struct layer : public wayland_proxy, ivi_controller_layer_remove_surface(this->proxy, surface->proxy); } - inline void set_render_order(struct wl_array *surfaces) { - ivi_controller_layer_set_render_order(this->proxy, surfaces); + void set_render_order(std::vector const &ro) { + struct wl_array wlro { + .size = ro.size() * sizeof(ro[0]), + .alloc = ro.capacity() * sizeof(ro[0]), + .data = const_cast(static_cast(ro.data())) + }; + ivi_controller_layer_set_render_order(this->proxy, &wlro); } }; @@ -298,10 +270,22 @@ struct layer : public wayland_proxy, // \__ \ (__| | | __/ __/ | | | // |___/\___|_| \___|\___|_| |_| // -struct screen : public wayland_proxy { - uint32_t id; +struct screen : public wayland_proxy, + controller_child { + screen(uint32_t i, struct controller *c, struct ivi_controller_screen *p); - screen(uint32_t i, struct ivi_controller_screen *p); + void clear() { ivi_controller_screen_clear(this->proxy); } + void add_layer(layer *l) { + ivi_controller_screen_add_layer(this->proxy, l->proxy); + } + void set_render_order(std::vector const &ro) { + struct wl_array wlro { + .size = ro.size() * sizeof(ro[0]), + .alloc = ro.capacity() * sizeof(ro[0]), + .data = const_cast(static_cast(ro.data())) + }; + ivi_controller_screen_set_render_order(this->proxy, &wlro); + } }; // _ _ _ @@ -311,18 +295,110 @@ struct screen : public wayland_proxy { // \___\___/|_| |_|\__|_| \___/|_|_|\___|_| // struct controller : public wayland_proxy { - std::map> surfaces; - std::map> layers; - std::map> screens; + std::unordered_map surface_proxy_to_id; + std::unordered_map> surfaces; + std::unordered_map layer_proxy_to_id; + std::unordered_map> layers; + std::unordered_map screen_proxy_to_id; + std::unordered_map> screens; + + typedef std::pair> + name_task_pair; + std::vector pending; + + size output_size; + + void add_proxy_to_id_mapping(struct ivi_controller_surface *p, uint32_t id) { + this->surface_proxy_to_id[uintptr_t(p)] = id; + logdebug("Add surface proxy mapping for %p (%u)", p, id); + } + + void remove_proxy_to_id_mapping(struct ivi_controller_surface *p) { + logdebug("Remove surface proxy mapping for %p", p); + this->surface_proxy_to_id.erase(uintptr_t(p)); + } + + void add_proxy_to_id_mapping(struct ivi_controller_layer *p, uint32_t id) { + logdebug("Add layer proxy mapping for %p (%u)", p, id); + this->layer_proxy_to_id[uintptr_t(p)] = id; + } + + void remove_proxy_to_id_mapping(struct ivi_controller_layer *p) { + logdebug("Remove layer proxy mapping for %p", p); + this->layer_proxy_to_id.erase(uintptr_t(p)); + } + + void add_proxy_to_id_mapping(struct wl_output *p, uint32_t id) { + logdebug("Add screen proxy mapping for %p (%u)", p, id); + this->screen_proxy_to_id[uintptr_t(p)] = id; + } + + void remove_proxy_to_id_mapping(struct wl_output *p) { + logdebug("Remove screen proxy mapping for %p", p); + this->screen_proxy_to_id.erase(uintptr_t(p)); + } + + void add_task(char const *name, + std::function &&f) { + this->pending.emplace_back(std::make_pair(name, f)); + } + + void execute_pending() { + if (!this->pending.empty()) { + for (auto &t : this->pending) { + logdebug("executing task '%s'", t.first); + t.second(this); + } + this->pending.clear(); + ivi_controller_commit_changes(this->proxy); + // XXX: No flush here... + } + } controller(struct wl_registry *r, uint32_t name, uint32_t version); ~controller() override; + // Requests + void commit_changes() const { ivi_controller_commit_changes(this->proxy); } + void layer_create(uint32_t id, int32_t w, int32_t h); + void surface_create(uint32_t id); + // Events - void screen(uint32_t id, struct ivi_controller_screen *screen); - void layer(uint32_t id); - void surface(uint32_t id); - void error(int32_t oid, int32_t otype, int32_t code, char const *text); + // controller + void controller_screen(uint32_t id, struct ivi_controller_screen *screen); + void controller_layer(uint32_t id); + void controller_surface(uint32_t id); + void controller_error(int32_t object_id, int32_t object_type, + int32_t error_code, char const *error_text); + + // surface + void surface_visibility(uint32_t id, int32_t visibility); + void surface_opacity(uint32_t id, float opacity); + void surface_source_rectangle(uint32_t id, int32_t x, int32_t y, + int32_t width, int32_t height); + void surface_destination_rectangle(uint32_t id, int32_t x, int32_t y, + int32_t width, int32_t height); + void surface_configuration(uint32_t id, int32_t width, int32_t height); + void surface_orientation(uint32_t id, int32_t orientation); + void surface_pixelformat(uint32_t id, int32_t pixelformat); + void surface_layer(uint32_t id, struct ivi_controller_layer *layer); + void surface_stats(uint32_t id, uint32_t redraw_count, uint32_t frame_count, + uint32_t update_count, uint32_t pid, + const char *process_name); + void surface_destroyed(uint32_t id); + void surface_content(uint32_t id, int32_t content_state); + + // layer + void layer_visibility(uint32_t id, int32_t visibility); + void layer_opacity(uint32_t id, float opacity); + void layer_source_rectangle(uint32_t id, int32_t x, int32_t y, int32_t width, + int32_t height); + void layer_destination_rectangle(uint32_t id, int32_t x, int32_t y, + int32_t width, int32_t height); + void layer_configuration(uint32_t id, int32_t width, int32_t height); + void layer_orientation(uint32_t id, int32_t orientation); + void layer_screen(uint32_t id, struct wl_output *screen); + void layer_destroyed(uint32_t id); }; }