aboutsummaryrefslogtreecommitdiffstats
path: root/src/pru/internal.h
blob: 8556eed779df54f1baabba2c25d3780be2667c4f (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
#ifndef __PRU_INTERNAL_H
#define __PRU_INTERNAL_H
// Local definitions for PRU code

#include <stdint.h> // uint32_t

#define IEP_EVENT                 7
#define KICK_ARM_EVENT            16
#define KICK_PRU0_FROM_ARM_EVENT  17
#define KICK_PRU0_EVENT           18
#define KICK_PRU1_EVENT           19

#define WAKE_PRU0_IRQ  0
#define WAKE_PRU1_IRQ  1
#define WAKE_ARM_IRQ   2

#define R31_IRQ_OFFSET 30

#define R31_WRITE_IRQ_SELECT (1<<5)
#define R31_WRITE_IRQ_OFFSET 16

// Layout of shared memory
struct shared_mem {
    uint32_t signal;
    uint32_t read_pos, read_count;
    char read_data[512];
    uint32_t send_push_pos, send_pop_pos;
    struct {
        uint32_t count;
        char data[64];
    } send_data[4];
};

#define SIGNAL_PRU0_WAITING 0xefefefef
#define SIGNAL_PRU1_READY   0xabababab

static struct shared_mem *SHARED_MEM = (void*)0x10000;

#endif // internal.h