aboutsummaryrefslogtreecommitdiffstats
path: root/tmk_core/ring_buffer.h
blob: 005d1be61334496a405b087c2daffe332cc39b7f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#ifndef RING_BUFFER_H
#define RING_BUFFER_H
/*--------------------------------------------------------------------
 * Ring buffer to store scan codes from keyboard
 *------------------------------------------------------------------*/
#define RBUF_SIZE 32
#include <util/atomic.h>
static uint8_t rbuf[RBUF_SIZE];
static uint8_t rbuf_head = 0;
static uint8_t rbuf_tail = 0;
static inline void rbuf_enqueue(uint8_t data)
{
  ATOMIC_BLOCK(ATOMIC_RESTORESTATE) {
    uint8_t next = (rbuf_head + 1) % RBUF_SIZE;
    if (next != rbuf_tail) {
        rbuf[rbuf_head] = data;
        rbuf_head = next;
    } else {
        print("rbuf: full\n");
    }
  }
}
static inline uint8_t rbuf_dequeue(void)
{
    uint8_t val = 0;
  ATOMIC_BLOCK(ATOMIC_RESTORESTATE) {

    if (rbuf_head != rbuf_tail) {
        val = rbuf[rbuf_tail];
        rbuf_tail = (rbuf_tail + 1) % RBUF_SIZE;
    }
  }

    return val;
}
static inline bool rbuf_has_data(void)
{
  bool has_data;
  ATOMIC_BLOCK(ATOMIC_RESTORESTATE) {
    has_data = (rbuf_head != rbuf_tail);
  }
  return has_data;
}
static inline void rbuf_clear(void)
{
  ATOMIC_BLOCK(ATOMIC_RESTORESTATE) {
    rbuf_head = rbuf_tail = 0;
  }
}

#endif  /* RING_BUFFER_H */
s5 = true; --- a/drivers/gpu/drm/vc4/vc4_kms.c +++ b/drivers/gpu/drm/vc4/vc4_kms.c @@ -13,6 +13,7 @@ #include <linux/bitfield.h> #include <linux/bitops.h> +#include <linux/clk.h> #include <drm/drm_atomic.h> #include <drm/drm_atomic_helper.h> @@ -222,6 +223,7 @@ vc4_atomic_complete_commit(struct drm_at { struct drm_device *dev = state->dev; struct vc4_dev *vc4 = to_vc4_dev(dev); + struct vc4_hvs *hvs = vc4->hvs; struct vc4_crtc *vc4_crtc; int i; @@ -237,6 +239,8 @@ vc4_atomic_complete_commit(struct drm_at vc4_hvs_mask_underrun(dev, vc4_crtc_state->assigned_channel); } + clk_set_rate(hvs->core_clk, 500000000); + drm_atomic_helper_wait_for_fences(dev, state, false); drm_atomic_helper_wait_for_dependencies(state); @@ -262,6 +266,8 @@ vc4_atomic_complete_commit(struct drm_at drm_atomic_helper_commit_cleanup_done(state); + clk_set_rate(hvs->core_clk, 200000000); + drm_atomic_state_put(state); up(&vc4->async_modeset);