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

📄 ni_stc.h

📁 最新rtlinux内核源码
💻 H
📖 第 1 页 / 共 2 页
字号:
/*    module/ni_stc.h    Register descriptions for NI DAQ-STC chip    COMEDI - Linux Control and Measurement Device Interface    Copyright (C) 1998-9 David A. Schleef <ds@schleef.org>    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.*//*	References:	    DAQ-STC Technical Reference Manual*/#ifndef _COMEDI_NI_STC_H#define _COMEDI_NI_STC_H#define _bit15		0x8000#define _bit14		0x4000#define _bit13		0x2000#define _bit12		0x1000#define _bit11		0x0800#define _bit10		0x0400#define _bit9		0x0200#define _bit8		0x0100#define _bit7		0x0080#define _bit6		0x0040#define _bit5		0x0020#define _bit4		0x0010#define _bit3		0x0008#define _bit2		0x0004#define _bit1		0x0002#define _bit0		0x0001/* Registers in the National Instruments DAQ-STC chip */#define Interrupt_A_Ack_Register	2#define G0_Gate_Interrupt_Ack			_bit15#define G0_TC_Interrupt_Ack			_bit14#define AI_Error_Interrupt_Ack			_bit13#define AI_STOP_Interrupt_Ack			_bit12#define AI_START_Interrupt_Ack			_bit11#define AI_START2_Interrupt_Ack			_bit10#define AI_START1_Interrupt_Ack			_bit9#define AI_SC_TC_Interrupt_Ack			_bit8#define AI_SC_TC_Error_Confirm			_bit7#define G0_TC_Error_Confirm			_bit6#define G0_Gate_Error_Confirm			_bit5#define AI_Status_1_Register		2#define Interrupt_A_St				0x8000#define AI_FIFO_Full_St				0x4000#define AI_FIFO_Half_Full_St			0x2000#define AI_FIFO_Empty_St			0x1000#define AI_Overrun_St				0x0800#define AI_Overflow_St				0x0400#define AI_SC_TC_Error_St			0x0200#define AI_START2_St				0x0100#define AI_START1_St				0x0080#define AI_SC_TC_St				0x0040#define AI_START_St				0x0020#define AI_STOP_St				0x0010#define G0_TC_St				0x0008#define G0_Gate_Interrupt_St			0x0004#define AI_FIFO_Request_St			0x0002#define Pass_Thru_0_Interrupt_St		0x0001#define AI_Status_2_Register		5#define Interrupt_B_Ack_Register	3#define AO_BC_TC_Interrupt_Ack _bit8#define AO_Status_1_Register		3#define Interrupt_B_St				_bit15#define AO_FIFO_Full_St				_bit14#define AO_FIFO_Half_Full_St			_bit13#define AO_FIFO_Empty_St			_bit12#define AO_BC_TC_Error_St			_bit11#define AO_START_St				_bit10#define AO_Overrun_St				_bit9#define AO_START1_St				_bit8#define AO_BC_TC_St				_bit7#define AO_UC_TC_St				_bit6#define AO_UPDATE_St				_bit5#define AO_UI2_TC_St				_bit4#define G1_TC_St				_bit3#define G1_Gate_Interrupt_St			_bit2#define AO_FIFO_Request_St			_bit1#define Pass_Thru_1_Interrupt_St		_bit0#define AI_Command_2_Register		4#define AI_End_On_SC_TC				_bit15#define AI_End_On_End_Of_Scan			_bit14#define AI_START1_Disable			_bit11#define AI_SC_Save_Trace			_bit10#define AI_SI_Switch_Load_On_SC_TC		_bit9#define AI_SI_Switch_Load_On_STOP		_bit8#define AI_SI_Switch_Load_On_TC			_bit7#define AI_SC_Switch_Load_On_TC			_bit4#define AI_STOP_Pulse				_bit3#define AI_START_Pulse				_bit2#define AI_START2_Pulse				_bit1#define AI_START1_Pulse				_bit0#define AO_Command_2_Register		5#define AO_End_On_BC_TC(x)			((x)<<14)#define AO_Start_Stop_Gate_Enable		_bit13#define AO_UC_Save_Trace			_bit12#define AO_BC_Gate_Enable			_bit11#define AO_BC_Save_Trace			_bit10#define AO_UI_Switch_Load_On_BC_TC		_bit9#define AO_UI_Switch_Load_On_Stop		_bit8#define AO_UI_Switch_Load_On_TC			_bit7#define AO_UC_Switch_Load_On_BC_TC		_bit6#define AO_UC_Switch_Load_On_TC			_bit5#define AO_BC_Switch_Load_On_TC			_bit4#define AO_Mute_B				_bit3#define AO_Mute_A				_bit2#define AO_UPDATE2_Pulse			_bit1#define AO_START1_Pulse				_bit0#define AO_Status_2_Register		6#define DIO_Parallel_Input_Register	7#define DIO_SDIN        			_bit4#define AI_Command_1_Register		8#define AI_Analog_Trigger_Reset			_bit14#define AI_Disarm				_bit13#define AI_SI2_Arm				_bit12#define AI_SI2_Load				_bit11#define AI_SI_Arm				_bit10#define AI_SI_Load				_bit9#define AI_DIV_Arm				_bit8#define AI_DIV_Load				_bit7#define AI_SC_Arm				_bit6#define AI_SC_Load				_bit5#define AI_SCAN_IN_PROG_Pulse			_bit4#define AI_EXTMUX_CLK_Pulse			_bit3#define AI_LOCALMUX_CLK_Pulse			_bit2#define AI_SC_TC_Pulse			 	_bit1#define AI_CONVERT_Pulse			_bit0#define AO_Command_1_Register		9#define AO_Analog_Trigger_Reset			_bit15#define AO_START_Pulse				_bit14#define AO_Disarm				_bit13#define AO_UI2_Arm_Disarm			_bit12#define AO_UI2_Load				_bit11#define AO_UI_Arm				_bit10#define AO_UI_Load				_bit9#define AO_UC_Arm				_bit8#define AO_UC_Load				_bit7#define AO_BC_Arm				_bit6#define AO_BC_Load				_bit5#define AO_DAC1_Update_Mode			_bit4#define AO_LDAC1_Source_Select			_bit3#define AO_DAC0_Update_Mode			_bit2#define AO_LDAC0_Source_Select			_bit1#define AO_UPDATE_Pulse				_bit0#define DIO_Output_Register		10#define DIO_Parallel_Data_Out(a)                ((a)&0xff)#define DIO_Parallel_Data_Mask                  0xff#define DIO_SDOUT                               _bit0#define DIO_Serial_Data_Out(a)                  (((a)&0xff)<<8)#define DIO_Serial_Data_Mask                    0xff00#define DIO_Control_Register		11#define DIO_Software_Serial_Control             _bit11#define DIO_HW_Serial_Timebase                  _bit10#define DIO_HW_Serial_Enable                    _bit9#define DIO_HW_Serial_Start                     _bit8#define DIO_Pins_Dir(a)                         ((a)&0xff)#define DIO_Pins_Dir_Mask                       0xff#define AI_Mode_1_Register		12#define AI_CONVERT_Source_Select(a)		((a)<<11)#define AI_SI_Source_select(a)			((a)<<6)#define AI_CONVERT_Source_Polarity		_bit5#define AI_Start_Stop				_bit3#define AI_Mode_1_Reserved			_bit2#define AI_Continuous				_bit1#define AI_Trigger_Once				_bit0#define AI_Mode_2_Register		13#define AI_SC_Gate_Enable			_bit15#define AI_Start_Stop_Gate_Enable		_bit14#define AI_Pre_Trigger				_bit13#define AI_External_MUX_Present			_bit12#define AI_SI2_Initial_Load_Source		_bit9#define AI_SI2_Reload_Mode			_bit8#define AI_SI_Initial_Load_Source		_bit7#define AI_SI_Reload_Mode(a)			((a)<<4)#define AI_SI_Write_Switch			_bit3#define AI_SC_Initial_Load_Source		_bit2#define AI_SC_Reload_Mode			_bit1#define AI_SC_Write_Switch			_bit0#define AI_SI_Load_A_Registers		14#define AI_SI_Load_B_Registers		16#define AI_SC_Load_A_Registers		18#define AI_SC_Load_B_Registers		20#define AI_SI2_Load_A_Register		23#define AI_SI2_Load_B_Register		25#define Joint_Status_1_Register         27#define DIO_Serial_IO_In_Progress_St            _bit12#define DIO_Serial_Input_Register       28#define Joint_Status_2_Register         29#define AO_Mode_1_Register		38#define AO_UPDATE_Source_Select(x)		(((x)&0x1f)<<11)#define AO_UI_Source_Select(x)			(((x)&0x1f)<<6)#define AO_Multiple_Channels			_bit5#define AO_UPDATE_Source_Polarity		_bit4#define AO_UI_Source_Polarity			_bit3#define AO_UC_Switch_Load_Every_TC		_bit2#define AO_Continuous				_bit1#define AO_Trigger_Once				_bit0#define AO_Mode_2_Register		39#define AO_FIFO_Mode_Mask ( 0x3 << 14 )enum AO_FIFO_Mode_Bits{	AO_FIFO_Mode_HF_to_F = (3<<14),	AO_FIFO_Mode_F = (2<<14),	AO_FIFO_Mode_HF = (1<<14),	AO_FIFO_Mode_E = (0<<14),};#define AO_FIFO_Retransmit_Enable		_bit13#define AO_START1_Disable			_bit12#define AO_UC_Initial_Load_Source		_bit11#define AO_UC_Write_Switch			_bit10#define AO_UI2_Initial_Load_Source		_bit9#define AO_UI2_Reload_Mode			_bit8#define AO_UI_Initial_Load_Source		_bit7#define AO_UI_Reload_Mode(x)			((x)<<4)#define AO_UI_Write_Switch			_bit3#define AO_BC_Initial_Load_Source		_bit2#define AO_BC_Reload_Mode			_bit1#define AO_BC_Write_Switch			_bit0#define AO_UI_Load_A_Register		40#define AO_UI_Load_A_Register_High	40#define AO_UI_Load_A_Register_Low	41#define AO_BC_Load_A_Register		44#define AO_BC_Load_A_Register_High	44#define AO_BC_Load_A_Register_Low	45#define AO_BC_Load_B_Register		46#define AO_BC_Load_B_Register_High	46#define AO_BC_Load_B_Register_Low	47#define AO_UC_Load_A_Register		48#define AO_UC_Load_A_Register_High	48#define AO_UC_Load_A_Register_Low	49#define Clock_and_FOUT_Register		56#define FOUT_Enable				_bit15#define FOUT_Timebase_Select			_bit14#define DIO_Serial_Out_Divide_By_2		_bit13#define Slow_Internal_Time_Divide_By_2		_bit12#define Slow_Internal_Timebase			_bit11#define G_Source_Divide_By_2			_bit10#define Clock_To_Board_Divide_By_2		_bit9#define Clock_To_Board				_bit8#define AI_Output_Divide_By_2			_bit7#define AI_Source_Divide_By_2			_bit6#define AO_Output_Divide_By_2			_bit5#define AO_Source_Divide_By_2			_bit4#define FOUT_Divider(x)				((x)<<0)#define IO_Bidirection_Pin_Register	57#define Interrupt_Control_Register	59#define Interrupt_B_Enable			_bit15#define Interrupt_B_Output_Select(x)		((x)<<12)#define Interrupt_A_Enable			_bit11#define Interrupt_A_Output_Select(x)		((x)<<8)#define Pass_Thru_0_Interrupt_Polarity		_bit3#define Pass_Thru_1_Interrupt_Polarity		_bit2#define Interrupt_Output_On_3_Pins		_bit1#define Interrupt_Output_Polarity		_bit0#define AI_Output_Control_Register	60#define AI_START_Output_Select			_bit10#define AI_SCAN_IN_PROG_Output_Select(x)	((x)<<8)#define AI_EXTMUX_CLK_Output_Select(x)		((x)<<6)#define AI_LOCALMUX_CLK_Output_Select(x)	((x)<<4)#define AI_SC_TC_Output_Select(x)		((x)<<2)#define AI_CONVERT_Output_Select(x)		((x)<<0)#define AI_START_STOP_Select_Register	62#define AI_START_Polarity			_bit15#define AI_STOP_Polarity			_bit14#define AI_STOP_Sync				_bit13#define AI_STOP_Edge				_bit12#define AI_STOP_Select(a)			((a)<<7)#define AI_START_Sync				_bit6#define AI_START_Edge				_bit5#define AI_START_Select(a)			(a)#define AI_Trigger_Select_Register	63#define AI_START1_Polarity			_bit15#define AI_START2_Polarity			_bit14#define AI_START2_Sync				_bit13#define AI_START2_Edge				_bit12#define AI_START2_Select(a)			((a)<<7)#define AI_START1_Sync				_bit6#define AI_START1_Edge				_bit5#define AI_START1_Select(a)			(a)#define AO_Start_Select_Register	66#define AO_UI2_Software_Gate			_bit15#define AO_UI2_External_Gate_Polarity		_bit14#define AO_START_Polarity			_bit13#define AO_AOFREQ_Enable			_bit12#define AO_UI2_External_Gate_Select(a)		((a)<<7)#define AO_START_Sync				_bit6#define AO_START_Edge				_bit5#define AO_START_Select(a)			(a)#define AO_Trigger_Select_Register	67#define AO_UI2_External_Gate_Enable		_bit15#define AO_Delayed_START1			_bit14#define AO_START1_Polarity			_bit13#define AO_UI2_Source_Polarity			_bit12#define AO_UI2_Source_Select(x)			(((x)&0x1f)<<7)#define AO_START1_Sync				_bit6#define AO_START1_Edge				_bit5#define AO_START1_Select(x)			(((x)&0x1f)<<0)#define AO_Mode_3_Register		70#define AO_UI2_Switch_Load_Next_TC		_bit13#define AO_UC_Switch_Load_Every_BC_TC		_bit12#define AO_Trigger_Length			_bit11#define AO_Stop_On_Overrun_Error		_bit5#define AO_Stop_On_BC_TC_Trigger_Error		_bit4#define AO_Stop_On_BC_TC_Error			_bit3#define AO_Not_An_UPDATE			_bit2#define AO_Software_Gate			_bit1#define Joint_Reset_Register		72#define AO_Configuration_End			_bit9#define AI_Configuration_End			_bit8#define AO_Configuration_Start			_bit5#define AI_Configuration_Start			_bit4#define G1_Reset				_bit3#define G0_Reset				_bit2#define AO_Reset				_bit1#define AI_Reset				_bit0#define Interrupt_A_Enable_Register	73#define Pass_Thru_0_Interrupt_Enable		_bit9#define G0_Gate_Interrupt_Enable		_bit8#define AI_FIFO_Interrupt_Enable		_bit7#define G0_TC_Interrupt_Enable			_bit6#define AI_Error_Interrupt_Enable		_bit5#define AI_STOP_Interrupt_Enable		_bit4#define AI_START_Interrupt_Enable		_bit3#define AI_START2_Interrupt_Enable		_bit2#define AI_START1_Interrupt_Enable		_bit1#define AI_SC_TC_Interrupt_Enable		_bit0#define Interrupt_B_Enable_Register	75#define Pass_Thru_1_Interrupt_Enable		_bit11#define G1_Gate_Interrupt_Enable		_bit10#define G1_TC_Interrupt_Enable			_bit9#define AO_FIFO_Interrupt_Enable		_bit8#define AO_UI2_TC_Interrupt_Enable		_bit7#define AO_UC_TC_Interrupt_Enable		_bit6#define AO_Error_Interrupt_Enable		_bit5#define AO_STOP_Interrupt_Enable		_bit4#define AO_START_Interrupt_Enable		_bit3#define AO_UPDATE_Interrupt_Enable		_bit2

⌨️ 快捷键说明

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