]> sigrok.org Git - libsigrok.git/blame - hardware/fx2lafw/fx2lafw.h
sr: fx2lafw: Only check for correct major FW version.
[libsigrok.git] / hardware / fx2lafw / fx2lafw.h
CommitLineData
f302a082
JH
1/*
2 * This file is part of the sigrok project.
3 *
4 * Copyright (C) 2012 Joel Holdsworth <joel@airwebreathe.org.uk>
5 *
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 */
19
897c1a2e
JH
20#include <glib.h>
21
6c39d99a
UH
22#ifndef LIBSIGROK_HARDWARE_FX2LAFW_FX2LAFW_H
23#define LIBSIGROK_HARDWARE_FX2LAFW_FX2LAFW_H
f302a082 24
b1eeb67e
JH
25#define USB_INTERFACE 0
26#define USB_CONFIGURATION 1
6c6781b6
JH
27#define NUM_TRIGGER_STAGES 4
28#define TRIGGER_TYPES "01"
8b35f474 29
f60fdf6e 30#define MAX_RENUM_DELAY_MS 3000
ecc16ed0 31#define NUM_SIMUL_TRANSFERS 32
610dbb70 32#define MAX_EMPTY_TRANSFERS (NUM_SIMUL_TRANSFERS * 2)
43125c69 33
0a8c0c32 34#define FX2LAFW_REQUIRED_VERSION_MAJOR 1
13bf7ecc 35
37dc0b16
UH
36/* 6 delay states of up to 256 clock ticks */
37#define MAX_SAMPLE_DELAY (6 * 256)
13bf7ecc 38
6c6781b6
JH
39/* Software trigger implementation: positive values indicate trigger stage. */
40#define TRIGGER_FIRED -1
41
187b3582
JH
42struct fx2lafw_profile {
43 uint16_t vid;
44 uint16_t pid;
45
6ccfadaf
JH
46 const char *vendor;
47 const char *model;
48 const char *model_version;
187b3582 49
f8b07fc6
JH
50 const char *firmware;
51
187b3582
JH
52 int num_probes;
53};
54
772a0e61 55struct context {
4679d14d 56 const struct fx2lafw_profile *profile;
187b3582 57
b1eeb67e
JH
58 /*
59 * Since we can't keep track of an fx2lafw device after upgrading
60 * the firmware (it re-enumerates into a different device address
61 * after the upgrade) this is like a global lock. No device will open
62 * until a proper delay after the last device was upgraded.
63 */
e8bd58ff 64 int64_t fw_updated;
b1eeb67e 65
921634ec 66 /* Device/capture settings */
e3186647 67 uint64_t cur_samplerate;
7cb621d4
JH
68 uint64_t limit_samples;
69
6c6781b6
JH
70 uint8_t trigger_mask[NUM_TRIGGER_STAGES];
71 uint8_t trigger_value[NUM_TRIGGER_STAGES];
72 int trigger_stage;
73 uint8_t trigger_buffer[NUM_TRIGGER_STAGES];
74
2e526f4a 75 int num_samples;
cb61e9f7 76 int submitted_transfers;
2e526f4a 77
3cd3a20b 78 void *session_dev_id;
187b3582 79
b1eeb67e 80 struct sr_usb_dev_inst *usb;
187b3582
JH
81};
82
f302a082 83#endif