Add raw binary output format.
Also, rename the "bin" format to "bits" for now to avoid confusion.
This commit is contained in:
parent
afc8e4deb6
commit
1c5b9d302c
|
@ -38,6 +38,7 @@ libsigrok_la_SOURCES = \
|
||||||
hardware/zeroplus-logic-cube/gl_usb.c \
|
hardware/zeroplus-logic-cube/gl_usb.c \
|
||||||
hardware/zeroplus-logic-cube/gl_usb.h \
|
hardware/zeroplus-logic-cube/gl_usb.h \
|
||||||
hardware/zeroplus-logic-cube/zeroplus.c \
|
hardware/zeroplus-logic-cube/zeroplus.c \
|
||||||
|
output/output_binary.c \
|
||||||
output/output_text.c \
|
output/output_text.c \
|
||||||
output/output_vcd.c \
|
output/output_vcd.c \
|
||||||
output/output_gnuplot.c \
|
output/output_gnuplot.c \
|
||||||
|
|
|
@ -21,12 +21,14 @@
|
||||||
|
|
||||||
extern struct output_format output_text_binary;
|
extern struct output_format output_text_binary;
|
||||||
extern struct output_format output_text_hex;
|
extern struct output_format output_text_hex;
|
||||||
|
extern struct output_format output_binary;
|
||||||
extern struct output_format output_vcd;
|
extern struct output_format output_vcd;
|
||||||
extern struct output_format output_gnuplot;
|
extern struct output_format output_gnuplot;
|
||||||
|
|
||||||
struct output_format *output_module_list[] = {
|
struct output_format *output_module_list[] = {
|
||||||
&output_text_binary,
|
&output_text_binary,
|
||||||
&output_text_hex,
|
&output_text_hex,
|
||||||
|
&output_binary,
|
||||||
&output_vcd,
|
&output_vcd,
|
||||||
&output_gnuplot,
|
&output_gnuplot,
|
||||||
NULL,
|
NULL,
|
||||||
|
|
|
@ -0,0 +1,90 @@
|
||||||
|
/*
|
||||||
|
* This file is part of the sigrok project.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2010 Uwe Hermann <uwe@hermann-uwe.de>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program 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 program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <glib.h>
|
||||||
|
#include <sigrok.h>
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
static int init(struct output *o)
|
||||||
|
{
|
||||||
|
/* Prevent compiler warnings. */
|
||||||
|
o = o;
|
||||||
|
|
||||||
|
/* Nothing so far, but we might want to add stuff here later. */
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int event(struct output *o, int event_type, char **data_out,
|
||||||
|
uint64_t *length_out)
|
||||||
|
{
|
||||||
|
char *outbuf;
|
||||||
|
int outlen = 1; /* FIXME */
|
||||||
|
|
||||||
|
/* Prevent compiler warnings. */
|
||||||
|
o = o;
|
||||||
|
event_type = event_type;
|
||||||
|
|
||||||
|
switch(event_type) {
|
||||||
|
case DF_TRIGGER:
|
||||||
|
break;
|
||||||
|
case DF_END:
|
||||||
|
outbuf = calloc(1, outlen); /* FIXME */
|
||||||
|
if (outbuf == NULL)
|
||||||
|
return SIGROK_ERR_MALLOC;
|
||||||
|
*data_out = outbuf;
|
||||||
|
*length_out = outlen;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return SIGROK_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int data(struct output *o, char *data_in, uint64_t length_in,
|
||||||
|
char **data_out, uint64_t *length_out)
|
||||||
|
{
|
||||||
|
uint64_t outsize;
|
||||||
|
char *outbuf;
|
||||||
|
|
||||||
|
/* Prevent compiler warnings. */
|
||||||
|
o = o;
|
||||||
|
|
||||||
|
outsize = length_in;
|
||||||
|
outbuf = calloc(1, outsize);
|
||||||
|
if (outbuf == NULL)
|
||||||
|
return SIGROK_ERR_MALLOC;
|
||||||
|
|
||||||
|
/* TODO: Are disabled probes handled correctly? */
|
||||||
|
memcpy(outbuf, data_in, length_in);
|
||||||
|
|
||||||
|
*data_out = outbuf;
|
||||||
|
*length_out = outsize;
|
||||||
|
|
||||||
|
return SIGROK_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct output_format output_binary = {
|
||||||
|
"binary",
|
||||||
|
"Raw binary",
|
||||||
|
init,
|
||||||
|
data,
|
||||||
|
event,
|
||||||
|
};
|
|
@ -258,8 +258,8 @@ static int data_hex(struct output *o, char *data_in, uint64_t length_in, char **
|
||||||
|
|
||||||
|
|
||||||
struct output_format output_text_binary = {
|
struct output_format output_text_binary = {
|
||||||
"bin",
|
"bits",
|
||||||
"Text (binary)",
|
"Text (bits)",
|
||||||
init_binary,
|
init_binary,
|
||||||
data_binary,
|
data_binary,
|
||||||
event
|
event
|
||||||
|
|
Loading…
Reference in New Issue