mirror of
https://codeberg.org/dnkl/foot.git
synced 2026-02-05 04:06:08 -05:00
Our home rolled clip-to-cell code was, obviously, not correct. The original problem was that we couldn't use pixman clipping since we have multiple threads writing to the same pixman image, and thus there would be races between the threads setting clipping. The fix is actually simple - just instantiate one pixman image (referencing the same backing image data) for each rendering thread.
52 lines
1.6 KiB
C
52 lines
1.6 KiB
C
#pragma once
|
|
|
|
#include <stdbool.h>
|
|
#include <stddef.h>
|
|
#include <sys/types.h>
|
|
|
|
#include <pixman.h>
|
|
#include <wayland-client.h>
|
|
|
|
struct buffer {
|
|
unsigned long cookie;
|
|
|
|
int width;
|
|
int height;
|
|
int stride;
|
|
|
|
bool busy;
|
|
size_t size; /* Buffer size */
|
|
void *mmapped; /* Raw data (TODO: rename) */
|
|
|
|
struct wl_buffer *wl_buf;
|
|
pixman_image_t **pix;
|
|
size_t pix_instances;
|
|
|
|
/* Internal */
|
|
int fd; /* memfd */
|
|
struct wl_shm_pool *pool;
|
|
|
|
void *real_mmapped; /* Address returned from mmap */
|
|
size_t mmap_size; /* Size of mmap (>= size) */
|
|
off_t offset; /* Offset into memfd where data begins */
|
|
|
|
bool scrollable;
|
|
bool purge; /* True if this buffer should be destroyed */
|
|
};
|
|
|
|
struct buffer *shm_get_buffer(
|
|
struct wl_shm *shm, int width, int height, unsigned long cookie, bool scrollable, size_t pix_instances);
|
|
void shm_fini(void);
|
|
|
|
void shm_set_max_pool_size(off_t max_pool_size);
|
|
bool shm_can_scroll(const struct buffer *buf);
|
|
bool shm_scroll(struct wl_shm *shm, struct buffer *buf, int rows,
|
|
int top_margin, int top_keep_rows,
|
|
int bottom_margin, int bottom_keep_rows);
|
|
|
|
void shm_purge(struct wl_shm *shm, unsigned long cookie);
|
|
|
|
struct terminal;
|
|
static inline unsigned long shm_cookie_grid(const struct terminal *term) { return (unsigned long)((uintptr_t)term + 0); }
|
|
static inline unsigned long shm_cookie_search(const struct terminal *term) { return (unsigned long)((uintptr_t)term + 1); }
|
|
static inline unsigned long shm_cookie_csd(const struct terminal *term, int n) { return (unsigned long)((uintptr_t)term + 2 + (n)); }
|