tight2: Extract header
parent
c908c713a6
commit
ec3610221c
|
@ -0,0 +1,45 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <zlib.h>
|
||||||
|
#include <pthread.h>
|
||||||
|
|
||||||
|
struct tight_tile;
|
||||||
|
struct pixman_region16;
|
||||||
|
|
||||||
|
struct tight_encoder_v2 {
|
||||||
|
uint32_t width;
|
||||||
|
uint32_t height;
|
||||||
|
uint32_t grid_width;
|
||||||
|
uint32_t grid_height;
|
||||||
|
|
||||||
|
struct tight_tile* grid;
|
||||||
|
|
||||||
|
z_stream zs[4];
|
||||||
|
uint8_t zs_mask;
|
||||||
|
pthread_mutex_t zs_mutex;
|
||||||
|
pthread_cond_t zs_cond;
|
||||||
|
|
||||||
|
const struct rfb_pixel_format* dfmt;
|
||||||
|
const struct rfb_pixel_format* sfmt;
|
||||||
|
const struct nvnc_fb* fb;
|
||||||
|
|
||||||
|
uint32_t n_rects;
|
||||||
|
uint32_t n_jobs;
|
||||||
|
|
||||||
|
struct vec* dst;
|
||||||
|
|
||||||
|
pthread_mutex_t wait_mutex;
|
||||||
|
pthread_cond_t wait_cond;
|
||||||
|
};
|
||||||
|
|
||||||
|
int tight_encoder_v2_init(struct tight_encoder_v2* self, uint32_t width,
|
||||||
|
uint32_t height);
|
||||||
|
void tight_encoder_v2_destroy(struct tight_encoder_v2* self);
|
||||||
|
|
||||||
|
int tight_encode_frame_v2(struct tight_encoder_v2* self, struct vec* dst,
|
||||||
|
const struct rfb_pixel_format* dfmt,
|
||||||
|
const struct nvnc_fb* src,
|
||||||
|
const struct rfb_pixel_format* sfmt,
|
||||||
|
struct pixman_region16* damage);
|
|
@ -3,6 +3,7 @@
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "pixels.h"
|
#include "pixels.h"
|
||||||
#include "vec.h"
|
#include "vec.h"
|
||||||
|
#include "tight-encoder-v2.h"
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
@ -28,8 +29,6 @@
|
||||||
|
|
||||||
#define MAX_TILE_SIZE (2 * (TSL * TSL * 4 + sizeof(struct rfb_server_fb_rect)))
|
#define MAX_TILE_SIZE (2 * (TSL * TSL * 4 + sizeof(struct rfb_server_fb_rect)))
|
||||||
|
|
||||||
struct tight_encoder_v2;
|
|
||||||
|
|
||||||
enum tight_tile_state {
|
enum tight_tile_state {
|
||||||
TIGHT_TILE_READY = 0,
|
TIGHT_TILE_READY = 0,
|
||||||
TIGHT_TILE_DAMAGED,
|
TIGHT_TILE_DAMAGED,
|
||||||
|
@ -43,29 +42,6 @@ struct tight_tile {
|
||||||
char buffer[MAX_TILE_SIZE];
|
char buffer[MAX_TILE_SIZE];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct tight_encoder_v2 {
|
|
||||||
uint32_t width;
|
|
||||||
uint32_t height;
|
|
||||||
uint32_t grid_width;
|
|
||||||
uint32_t grid_height;
|
|
||||||
|
|
||||||
struct tight_tile* grid;
|
|
||||||
|
|
||||||
z_stream zs[4];
|
|
||||||
uint8_t zs_mask;
|
|
||||||
pthread_mutex_t zs_mutex;
|
|
||||||
pthread_cond_t zs_cond;
|
|
||||||
|
|
||||||
const struct rfb_pixel_format* dfmt;
|
|
||||||
const struct rfb_pixel_format* sfmt;
|
|
||||||
const struct nvnc_fb* fb;
|
|
||||||
|
|
||||||
uint32_t n_rects;
|
|
||||||
uint32_t n_jobs;
|
|
||||||
|
|
||||||
struct vec* dst;
|
|
||||||
};
|
|
||||||
|
|
||||||
static int tight_encoder_v2_init_stream(z_stream* zs)
|
static int tight_encoder_v2_init_stream(z_stream* zs)
|
||||||
{
|
{
|
||||||
int rc = deflateInit2(zs,
|
int rc = deflateInit2(zs,
|
||||||
|
@ -111,9 +87,28 @@ int tight_encoder_v2_init(struct tight_encoder_v2* self, uint32_t width,
|
||||||
pthread_mutex_init(&self->zs_mutex, NULL);
|
pthread_mutex_init(&self->zs_mutex, NULL);
|
||||||
pthread_cond_init(&self->zs_cond, NULL);
|
pthread_cond_init(&self->zs_cond, NULL);
|
||||||
|
|
||||||
|
pthread_mutex_init(&self->wait_mutex, NULL);
|
||||||
|
pthread_cond_init(&self->wait_cond, NULL);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void tight_encoder_v2_destroy(struct tight_encoder_v2* self)
|
||||||
|
{
|
||||||
|
pthread_cond_destroy(&self->wait_cond);
|
||||||
|
pthread_mutex_destroy(&self->wait_mutex);
|
||||||
|
|
||||||
|
pthread_cond_destroy(&self->zs_cond);
|
||||||
|
pthread_mutex_destroy(&self->zs_mutex);
|
||||||
|
|
||||||
|
deflateEnd(&self->zs[3]);
|
||||||
|
deflateEnd(&self->zs[2]);
|
||||||
|
deflateEnd(&self->zs[1]);
|
||||||
|
deflateEnd(&self->zs[0]);
|
||||||
|
|
||||||
|
free(self->grid);
|
||||||
|
}
|
||||||
|
|
||||||
static int tight_apply_damage(struct tight_encoder_v2* self,
|
static int tight_apply_damage(struct tight_encoder_v2* self,
|
||||||
struct pixman_region16* damage)
|
struct pixman_region16* damage)
|
||||||
{
|
{
|
||||||
|
@ -306,8 +301,6 @@ static void tight_finish_frame(struct tight_encoder_v2* self)
|
||||||
for (uint32_t x = 0; x < self->grid_height; ++x)
|
for (uint32_t x = 0; x < self->grid_height; ++x)
|
||||||
if (tight_tile(self, x, y)->state == TIGHT_TILE_ENCODED)
|
if (tight_tile(self, x, y)->state == TIGHT_TILE_ENCODED)
|
||||||
tight_finish_tile(self, x, y);
|
tight_finish_tile(self, x, y);
|
||||||
|
|
||||||
// TODO Notify that encoding is done
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void do_encode_tile(void* obj)
|
static void do_encode_tile(void* obj)
|
||||||
|
@ -324,8 +317,12 @@ static void on_encode_tile_done(void* obj)
|
||||||
|
|
||||||
tile->state = TIGHT_TILE_ENCODED;
|
tile->state = TIGHT_TILE_ENCODED;
|
||||||
|
|
||||||
if (--self->n_jobs == 0)
|
pthread_mutex_lock(&self->wait_mutex);
|
||||||
|
if (--self->n_jobs == 0) {
|
||||||
tight_finish_frame(self);
|
tight_finish_frame(self);
|
||||||
|
pthread_cond_signal(&self->wait_cond);
|
||||||
|
}
|
||||||
|
pthread_mutex_unlock(&self->wait_mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int tight_schedule_encode_tile(struct tight_encoder_v2* self,
|
static int tight_schedule_encode_tile(struct tight_encoder_v2* self,
|
||||||
|
@ -367,6 +364,8 @@ int tight_encode_frame_v2(struct tight_encoder_v2* self, struct vec* dst,
|
||||||
self->fb = src;
|
self->fb = src;
|
||||||
self->dst = dst;
|
self->dst = dst;
|
||||||
|
|
||||||
|
vec_clear(dst);
|
||||||
|
|
||||||
self->n_rects = tight_apply_damage(self, damage);
|
self->n_rects = tight_apply_damage(self, damage);
|
||||||
if (self->n_rects == 0)
|
if (self->n_rects == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -374,7 +373,11 @@ int tight_encode_frame_v2(struct tight_encoder_v2* self, struct vec* dst,
|
||||||
if (tight_schedule_encoding_jobs(self) < 0)
|
if (tight_schedule_encoding_jobs(self) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
// TODO Wait for encoding to finish or change architecture of caller
|
// TODO Change architecture so we don't have to wait here
|
||||||
|
pthread_mutex_lock(&self->wait_mutex);
|
||||||
|
while (self->n_jobs != 0)
|
||||||
|
pthread_cond_wait(&self->wait_cond, &self->wait_mutex);
|
||||||
|
pthread_mutex_unlock(&self->wait_mutex);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue