summaryrefslogtreecommitdiff
path: root/src/hal/utils/scope_shm.h
blob: 5aa4c041beaa72aee6e30882cc77f15d7b3850a2 (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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#ifndef HALSC_SHM_H
#define HALSC_SHM_H
/** This file, 'halsc_shm.h', contains declarations used by both
    'halscope.c' and 'halscope_rt.c' to implement an oscilloscope.
    The declarations in this file are used by both the realtime
    and user space components of the scope.  Those used only in
    realtime are in 'halsc_rt.h', and those used only in user
    space are in 'halsc_usr.h'.
*/

/** Copyright (C) 2003 John Kasunich
                       <jmkasunich AT users DOT sourceforge DOT net>
*/

/** This program is free software; you can redistribute it and/or
    modify it under the terms of version 2 of the GNU General
    Public License as published by the Free Software Foundation.
    This library is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public
    License along with this library; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111 USA

    THE AUTHORS OF THIS LIBRARY ACCEPT ABSOLUTELY NO LIABILITY FOR
    ANY HARM OR LOSS RESULTING FROM ITS USE.  IT IS _EXTREMELY_ UNWISE
    TO RELY ON SOFTWARE ALONE FOR SAFETY.  Any machinery capable of
    harming persons must have provisions for completely removing power
    from all motors, etc, before persons enter any danger area.  All
    machinery must be designed to comply with local and national safety
    codes, and the authors of this software can not, and do not, take
    any responsibility for such compliance.

    This code was written as part of the EMC HAL project.  For more
    information, go to www.linuxcnc.org.
*/

/***********************************************************************
*                         TYPEDEFS AND DEFINES                         *
************************************************************************/

#define SCOPE_SHM_KEY  0x130CF406
#define SCOPE_NUM_SAMPLES_DEFAULT 16000

typedef enum {
    IDLE = 0,			/* waiting for run command */
    INIT,			/* run command received */
    PRE_TRIG,			/* acquiring pre-trigger data */
    TRIG_WAIT,			/* waiting for trigger */
    POST_TRIG,			/* acquiring post-trigger data */
    DONE,			/* data acquisition complete */
    RESET			/* data acquisition interrupted */
} scope_state_t;

/* this struct holds a single value - one sample of one channel */

typedef union {
    unsigned char d_u8;		/* variable for bit */
    __u32 d_u32;		/* variable for u32 */
    __s32 d_s32;		/* variable for s32 */
    real_t d_real;		/* variable for float */
    ireal_t d_ireal;		/* intlike variable for float */
} scope_data_t;

/** This struct holds control data needed by both realtime and GUI code.
    It lives in shared memory.  The codes for each field identify which
    module(s) set the field.  "I" set at init only, "R" set by realtime
    code, "U" set by user code, "RU" set/modified by both.
*/

typedef struct {
    unsigned long shm_size;	/* Actual size of SHM area */
    int buf_len;		/* I length of buffer */
    int watchdog;		/* RU rt sets to zero, user incs */
    char thread_name[HAL_NAME_LEN + 1];	/* U thread used for sampling */
    int mult;			/* U sample period multiplier */
    int rec_len;		/* U total samples in record */
    int sample_len;		/* U max channels in each sample */
    int pre_trig;		/* U number of samples before trigger */
    int trig_chan;		/* U trigger channel number */
    scope_data_t trig_level;	/* U trigger level */
    int trig_edge;		/* U 0 = falling edge, 1 = rising edge */
    int force_trig;		/* RU U sets non-zero to force trigger */
    int auto_trig;		/* U enables auto triggering */
    int start;			/* R first sample in record */
    int curr;			/* R next sample to be acquired */
    int samples;		/* R number of valid samples */
    scope_state_t state;	/* RU current state */
    int data_offset[16];	/* U data addr in shmem for each channel */
    hal_type_t data_type[16];	/* U data type for each channel */
    char data_len[16];		/* U data size, 0 if not to be acquired */
} scope_shm_control_t;

#endif /* HALSC_SHM_H */