⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 diag_l1.h

📁 Freediag contains various drivers (ISO9141, ISO14230, SAEJ1850-VPW, SAEJ1850-PWM) for different adap
💻 H
字号:
/*
 *	freediag - Vehicle Diagnostic Utility
 *
 * CVSID $Id: diag_l1.h,v 1.4 2002/06/17 20:56:02 rpalmeida Exp $
 *
 * Copyright (C) 2001 Richard Almeida & Ibex Ltd (rpa@ibex.co.uk)
 *
 * 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., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 *************************************************************************
 *
 * Diagnostic Software
 *
 * - Layer 1 interface definitions
 */

#ifndef _DIAG_L0_H_
#define _DIAG_L0_H_

/*
 * Layer 1/0 device flags
 *
 * Each potential Layer 0 logical interface has a number of flags that show
 * what it supports
 *
 * Some of these (like SLOW start) will be needed by certain ECUs , and
 * so the flags are also used in the ECU definitions
 *
 * Most L1 drivers will prefer fast start, hopefully support both
 * fast and slow start
 *
 * Can be read by higher layers using ..._ioctl(GET_L1_FLAGS)
 */

#define DIAG_L1_SLOW		0x01	/* Supports SLOW (5 baud) Start */
#define DIAG_L1_FAST		0x02	/* Supports FAST Start */
#define DIAG_L1_PREFSLOW	0x04	/* Prefers SLOW (5 baud) Start */
#define DIAG_L1_PREFFAST	0x08	/* Prefers FAST Start */

#define	DIAG_L1_HALFDUPLEX	0x10	/* Physical interface is half duplex, need to remove echos */

/* following flags are for semi-intelligent interfaces */

/*
 * DOESL2SEND
 *	L1 is intelligent and does L2 stuff, this means it will
 *	- Return a complete L3 frame of data as one recv()
 *	- Expect complete L3 data to be sent to it, with the address header
 *	in one write, interface does the P4 interbyte delay
 */
#define	DIAG_L1_DOESL2FRAME		0x20
/*
 * DOESSLOWINIT
 *	L1 interface does the slowinit stuff, so L2 doesn't need to do complex
 *	handshake. L1 will send the keybytes on the first recv(). (All L1's
 *	read the 0x55 and do the right thing, L2 never sees that)
 */
#define	DIAG_L1_DOESSLOWINIT		0x40
/*
 * DOESL2CKSUM
 *	L1 interface does the L2 checksum/CRC on send
 */
#define	DIAG_L1_DOESL2CKSUM		0x80
/*
 * STRIPSL2CKSUM
 *	L1 strips/checks L2 checksum before sending frame upward
 */
#define DIAG_L1_STRIPSL2CKSUM		0x100
/*
 * DOESP4WAIT
 *
 * interface is semi-intelligent and does the interbyte delay P4 for ISO
 */
#define DIAG_L1_DOESP4WAIT		0x200


/*
 * Layer 0 device types
 *
 * Types of L1 Interface supported
 * Each "device" has up to 16 interfaces, and many sub-interfaces
 *
 * This is a bitmask of what is supported
 */
#define	DIAG_L1_SPARE		0x00	/* Not used */
#define	DIAG_L1_ISO9141		0x01	/* K line */
#define	DIAG_L1_ISO14230	0x02	/* K line */
#define DIAG_L1_J1850_VPW	0x04	/* J1850 interface, 10400 baud, VPW */
#define DIAG_L1_J1850_PWM	0x08	/* J1850 interface 41600 baud, PWM */
#define	DIAG_L1_CAN		0x10	/* CAN bus */

#define	DIAG_L1_RAW		0x80	/* Raw data interface */

/*
 * Number of concurrently supported logical interfaces
 * remember a single physical interface may be many logical interfaces
 * if it has K, CAN, etc in one device
 *
 * For interfaces with muxes (such as to talk to a MB 33 way diagnostic port)
 * the subinterface flag is used for read and write purposes
 *
 * XXX - this makes "un-duplexing" a half duplex interface hard work...
 *  and not yet supported in this code
 */
#define DIAG_L1_MAXINTF		16


/* Parity settings for diag_11_setspeed parflag */
#define DIAG_L1_PAR_E		1	/* Even parity */
#define DIAG_L1_PAR_O		2	/* Odd parity */
#define DIAG_L1_PAR_N		3	/* No parity */

/*
 * L2 -> L1 interface
 *
 * L1 public interface
 */

/* Argument to diag_l1_initbus */
struct diag_l1_init
{
	u_int8_t	type;	/* Init type */
	u_int8_t	addr;	/* Address for 5 baud init */
};
#define DIAG_L1_INITBUS_NONE	0	/* Not needed */
#define DIAG_L1_INITBUS_FAST	1	/* Fast init (25ms low, 25ms high) */
#define DIAG_L1_INITBUS_5BAUD	2	/* 5 baud init */
#define DIAG_L1_INITBUS_2SLOW	3	/* 2 second low on bus */

/*
 * init(), returns 0 on success (always succeeds)
 * open(), returns a fd on success, < 0 on failure
 * close(), always succeeds and returns 0
 * send() Send data, same args as Unix write() + the sub interface,
 * 	returns 0 on OK, -1 on success
 * recv() - get data, same args as Unix read() + the sub interface
 * setspeed(), returns 0 on success,  speed = speed, bits = data bits (5,6,7,8)
 *	 stopbits (1, 2), parflag as above
 * getflags(), return the flags as above
 * gettype(), return the type as above
 */ 
int diag_l1_init();
int diag_l1_initbus(int fd, struct diag_l1_init *in);
int diag_l1_open(char *name, int id, int L1protocol);
int diag_l1_close(int fd);
int diag_l1_send(int fd, int subinterface, char *data, int len, int p4);
int diag_l1_recv(int fd, int subinterface, char *data, int len, int timeout);
int diag_l1_setspeed(int fd, int speed, int bits, int stop_bits, int parflag );
int diag_l1_getflags(int fd);
int diag_l1_gettype(int fd);

/*
 * L0 device structure
 * This is the structure to interface between the L1 code and the interface-manufacturer
 * dependent code (which is in diag_l0_if.c)
 */
#define DIAG_L0_NAMELEN	256

typedef struct diag_l0
{
	char	diag_l0_textname[DIAG_L0_NAMELEN];	/* Useful textual name */
	char	diag_l0_name[DIAG_L0_NAMELEN];	/* Short, unique text name for user interface */

	int 	diag_l0_type;			/* See type description above */
	
	/* function pointers to L0 code */
	int	(*diag_l0_init)(void);
	int	(*diag_l0_open)(int iInterface, int iProtocol);
	int	(*diag_l0_close)(int fd);
	int	(*diag_l0_initbus)(int fd, struct diag_l1_init *in);
	int	(*diag_l0_send)(int fd, int subinterface, char *data, int len);
	int	(*diag_l0_recv)(int fd, int subinterface, char *data, int len, int timeout);
	int	(*diag_l0_setspeed)(int fd, int speed, int bits, int stop_bits, int parflag );
	int	(*diag_l0_getflags)(int fd);
} diag_l0_t;


#endif /* _DIAG_L0_H_ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -