163b236504
resource_var.h. In kern_ndis.c:ndis_convert_res(), fill in the cprd_flags and cprd_sharedisp fields as best we can. In if_ndis.c:ndis_setmulti(), don't bother updating the multicast filter if our multicast address list is empty. Add some missing updates to ndis_var.h and ntoskrnl_var.h that I forgot to check in when I added the KeDpc stuff.
162 lines
4.7 KiB
C
162 lines
4.7 KiB
C
|
|
/*
|
|
* $FreeBSD$
|
|
*/
|
|
|
|
typedef int cm_resource_type;
|
|
|
|
struct physaddr {
|
|
uint64_t np_quad;
|
|
};
|
|
|
|
typedef struct physaddr physaddr;
|
|
|
|
enum interface_type {
|
|
InterfaceTypeUndefined = -1,
|
|
Internal,
|
|
Isa,
|
|
Eisa,
|
|
MicroChannel,
|
|
TurboChannel,
|
|
PCIBus,
|
|
VMEBus,
|
|
NuBus,
|
|
PCMCIABus,
|
|
CBus,
|
|
MPIBus,
|
|
MPSABus,
|
|
ProcessorInternal,
|
|
InternalPowerBus,
|
|
PNPISABus,
|
|
PNPBus,
|
|
MaximumInterfaceType
|
|
};
|
|
|
|
typedef enum interface_type interface_type;
|
|
|
|
#define CmResourceTypeNull 0 /* ResType_All or ResType_None (0x0000) */
|
|
#define CmResourceTypePort 1 /* ResType_IO (0x0002) */
|
|
#define CmResourceTypeInterrupt 2 /* ResType_IRQ (0x0004) */
|
|
#define CmResourceTypeMemory 3 /* ResType_Mem (0x0001) */
|
|
#define CmResourceTypeDma 4 /* ResType_DMA (0x0003) */
|
|
#define CmResourceTypeDeviceSpecific 5 /* ResType_ClassSpecific (0xFFFF) */
|
|
#define CmResourceTypeBusNumber 6 /* ResType_BusNumber (0x0006) */
|
|
#define CmResourceTypeMaximum 7
|
|
#define CmResourceTypeNonArbitrated 128 /* Not arbitrated if 0x80 bit set */
|
|
#define CmResourceTypeConfigData 128 /* ResType_Reserved (0x8000) */
|
|
#define CmResourceTypeDevicePrivate 129 /* ResType_DevicePrivate (0x8001) */
|
|
#define CmResourceTypePcCardConfig 130 /* ResType_PcCardConfig (0x8002) */
|
|
|
|
enum cm_share_disposition {
|
|
CmResourceShareUndetermined = 0, /* Reserved */
|
|
CmResourceShareDeviceExclusive,
|
|
CmResourceShareDriverExclusive,
|
|
CmResourceShareShared
|
|
};
|
|
|
|
typedef enum cm_share_disposition cm_share_disposition;
|
|
|
|
/* Define the bit masks for Flags when type is CmResourceTypeInterrupt */
|
|
|
|
#define CM_RESOURCE_INTERRUPT_LEVEL_SENSITIVE 0
|
|
#define CM_RESOURCE_INTERRUPT_LATCHED 1
|
|
|
|
/* Define the bit masks for Flags when type is CmResourceTypeMemory */
|
|
|
|
#define CM_RESOURCE_MEMORY_READ_WRITE 0x0000
|
|
#define CM_RESOURCE_MEMORY_READ_ONLY 0x0001
|
|
#define CM_RESOURCE_MEMORY_WRITE_ONLY 0x0002
|
|
#define CM_RESOURCE_MEMORY_PREFETCHABLE 0x0004
|
|
|
|
#define CM_RESOURCE_MEMORY_COMBINEDWRITE 0x0008
|
|
#define CM_RESOURCE_MEMORY_24 0x0010
|
|
#define CM_RESOURCE_MEMORY_CACHEABLE 0x0020
|
|
|
|
/* Define the bit masks for Flags when type is CmResourceTypePort */
|
|
|
|
#define CM_RESOURCE_PORT_MEMORY 0x0000
|
|
#define CM_RESOURCE_PORT_IO 0x0001
|
|
#define CM_RESOURCE_PORT_10_BIT_DECODE 0x0004
|
|
#define CM_RESOURCE_PORT_12_BIT_DECODE 0x0008
|
|
#define CM_RESOURCE_PORT_16_BIT_DECODE 0x0010
|
|
#define CM_RESOURCE_PORT_POSITIVE_DECODE 0x0020
|
|
#define CM_RESOURCE_PORT_PASSIVE_DECODE 0x0040
|
|
#define CM_RESOURCE_PORT_WINDOW_DECODE 0x0080
|
|
|
|
/* Define the bit masks for Flags when type is CmResourceTypeDma */
|
|
|
|
#define CM_RESOURCE_DMA_8 0x0000
|
|
#define CM_RESOURCE_DMA_16 0x0001
|
|
#define CM_RESOURCE_DMA_32 0x0002
|
|
#define CM_RESOURCE_DMA_8_AND_16 0x0004
|
|
#define CM_RESOURCE_DMA_BUS_MASTER 0x0008
|
|
#define CM_RESOURCE_DMA_TYPE_A 0x0010
|
|
#define CM_RESOURCE_DMA_TYPE_B 0x0020
|
|
#define CM_RESOURCE_DMA_TYPE_F 0x0040
|
|
|
|
struct cm_partial_resource_desc {
|
|
uint8_t cprd_type;
|
|
uint8_t cprd_sharedisp;
|
|
uint16_t cprd_flags;
|
|
union {
|
|
struct {
|
|
physaddr cprd_start;
|
|
uint32_t cprd_len;
|
|
} cprd_generic;
|
|
struct {
|
|
physaddr cprd_start;
|
|
uint32_t cprd_len;
|
|
} cprd_port;
|
|
struct {
|
|
uint32_t cprd_level;
|
|
uint32_t cprd_vector;
|
|
uint32_t cprd_affinity;
|
|
} cprd_intr;
|
|
struct {
|
|
physaddr cprd_start;
|
|
uint32_t cprd_len;
|
|
} cprd_mem;
|
|
struct {
|
|
uint32_t cprd_chan;
|
|
uint32_t cprd_port;
|
|
uint32_t cprd_rsvd;
|
|
} cprd_dmachan;
|
|
struct {
|
|
uint32_t cprd_data[3];
|
|
} cprd_devpriv;
|
|
struct {
|
|
uint32_t cprd_datasize;
|
|
uint32_t cprd_rsvd1;
|
|
uint32_t cprd_rsvd2;
|
|
} cprd_devspec;
|
|
} u;
|
|
};
|
|
|
|
typedef struct cm_partial_resource_desc cm_partial_resource_desc;
|
|
|
|
struct cm_partial_resource_list {
|
|
uint16_t cprl_version;
|
|
uint16_t cprl_revision;
|
|
uint32_t cprl_count;
|
|
cm_partial_resource_desc cprl_partial_descs[1];
|
|
};
|
|
|
|
typedef struct cm_partial_resource_list cm_partial_resource_list;
|
|
|
|
struct cm_full_resource_list {
|
|
interface_type cfrl_type;
|
|
uint32_t cfrl_busnum;
|
|
cm_partial_resource_desc cfrl_partiallist;
|
|
};
|
|
|
|
typedef struct cm_full_resource_list cm_full_resource_list;
|
|
|
|
struct cm_resource_list {
|
|
uint32_t crl_count;
|
|
cm_full_resource_list crl_rlist;
|
|
};
|
|
|
|
typedef struct cm_resource_list cm_resource_list;
|
|
|
|
typedef cm_partial_resource_list ndis_resource_list;
|