Changeset 28208 in vbox
- Timestamp:
- Apr 12, 2010 2:07:33 PM (15 years ago)
- Location:
- trunk
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/include/VBox/intnet.h
r28120 r28208 353 353 /** @} */ 354 354 355 /** 356 * Switch decisions returned by INTNETTRUNKSWPORT::pfnPreRecv. 357 */ 358 typedef enum INTNETSWDECISION 359 { 360 /** The usual invalid zero value. */ 361 INTNETSWDECISION_INVALID = 0, 362 /** Everywhere. */ 363 INTNETSWDECISION_BROADCAST, 364 /** Only to the internal network. */ 365 INTNETSWDECISION_INTNET, 366 /** Only for the trunk (host/wire). */ 367 INTNETSWDECISION_TRUNK, 368 /** The usual 32-bit type expansion. */ 369 INTNETSWDECISION_32BIT_HACK = 0x7fffffff 370 } INTNETSWDECISION; 371 355 372 356 373 /** Pointer to the switch side of a trunk port. */ … … 366 383 /** Structure version number. (INTNETTRUNKSWPORT_VERSION) */ 367 384 uint32_t u32Version; 385 386 /** 387 * Examine the packet and figure out where it is going. 388 * 389 * This method is for making packet switching decisions in contexts where 390 * pfnRecv cannot be called or is no longer applicable. This method can be 391 * called from any context. 392 * 393 * @returns INTNETSWDECISION_BROADCAST, INTNETSWDECISION_INTNET or 394 * INTNETSWDECISION_TRUNK. The source is excluded from broadcast & 395 * trunk, of course. 396 * 397 * @param pSwitchPort Pointer to this structure. 398 * @param pvHdrs Pointer to the packet headers. 399 * @param cbHdrs Size of the packet headers. This must be at least 6 400 * bytes (the destination MAC address), but should if 401 * possibly also include any VLAN tag and network layer 402 * header (wireless mac address sharing). 403 * @param fSrc Where this frame comes from. Only one bit should be 404 * set! 405 * 406 * @remarks Will only grab the switch table spinlock (interrupt safe). 407 */ 408 DECLR0CALLBACKMEMBER(INTNETSWDECISION, pfnPreRecv,(PINTNETTRUNKSWPORT pSwitchPort, 409 void const *pvHdrs, size_t cbHdrs, uint32_t fSrc)); 368 410 369 411 /** … … 376 418 * 377 419 * @returns true if we've handled it and it should be dropped. 378 * false if it should hit the wire .420 * false if it should hit the wire/host. 379 421 * 380 422 * @param pSwitchPort Pointer to this structure. … … 679 721 680 722 /** The UUID for the (current) trunk factory. (case sensitive) */ 681 #define INTNETTRUNKFACTORY_UUID_STR " 1d3810bc-0899-42b0-8ae1-346a08bffff7"723 #define INTNETTRUNKFACTORY_UUID_STR "b010afb2-cb4c-44b7-9da9-1e113cfcd47c" 682 724 683 725 /** @name INTNETTRUNKFACTORY::pfnCreateAndConnect flags. -
trunk/src/VBox/Devices/Network/DrvIntNet.cpp
r28134 r28208 135 135 #ifdef IN_RING3 136 136 137 /* -=-=-=-=- PDMINETWORKUP -=-=-=-=- */138 139 137 140 138 /** … … 192 190 } 193 191 192 /* -=-=-=-=- PDMINETWORKUP -=-=-=-=- */ 194 193 195 194 /** -
trunk/src/VBox/Devices/Network/SrvIntNetR0.cpp
r28156 r28208 3329 3329 3330 3330 3331 /** @copydoc INTNETTRUNKSWPORT::pfnPreRecv */ 3332 static DECLCALLBACK(INTNETSWDECISION) intnetR0TrunkIfPortPreRecv(PINTNETTRUNKSWPORT pSwitchPort, 3333 void const *pvSrc, size_t cbSrc, uint32_t fSrc) 3334 { 3335 PINTNETTRUNKIF pThis = INTNET_SWITCHPORT_2_TRUNKIF(pSwitchPort); 3336 PINTNETNETWORK pNetwork = pThis->pNetwork; 3337 3338 /* assert some sanity */ 3339 AssertPtrReturn(pNetwork, INTNETSWDECISION_TRUNK); 3340 AssertReturn(pNetwork->FastMutex != NIL_RTSEMFASTMUTEX, INTNETSWDECISION_TRUNK); 3341 AssertPtr(pvSrc); 3342 AssertPtr(cbSrc >= 6); 3343 Assert(fSrc); 3344 3345 /** @todo implement the switch table. */ 3346 3347 return INTNETSWDECISION_BROADCAST; 3348 } 3349 3350 3331 3351 /** @copydoc INTNETTRUNKSWPORT::pfnRecv */ 3332 3352 static DECLCALLBACK(bool) intnetR0TrunkIfPortRecv(PINTNETTRUNKSWPORT pSwitchPort, PINTNETSG pSG, uint32_t fSrc) … … 3612 3632 return VERR_NO_MEMORY; 3613 3633 pTrunkIF->SwitchPort.u32Version = INTNETTRUNKSWPORT_VERSION; 3634 pTrunkIF->SwitchPort.pfnPreRecv = intnetR0TrunkIfPortPreRecv; 3614 3635 pTrunkIF->SwitchPort.pfnRecv = intnetR0TrunkIfPortRecv; 3615 3636 pTrunkIF->SwitchPort.pfnSGRetain = intnetR0TrunkIfPortSGRetain; -
trunk/src/VBox/HostDrivers/VBoxNetFlt/linux/VBoxNetFlt-linux.c
r28202 r28208 250 250 /** Our overridden ops. */ 251 251 struct net_device_ops Ops; 252 /** Magic word. */ 253 uint32_t u32Magic; 252 254 /** Pointer to the original ops. */ 253 255 struct net_device_ops const *pOrgOps; 254 /** Magic word. */255 uint32_t u32Magic;256 /** Pointer to the net filter instance. */ 257 PVBOXNETFLTINS pVBoxNetFlt; 256 258 /** The number of filtered packages. */ 257 259 uint64_t cFiltered; … … 273 275 { 274 276 PVBOXNETDEVICEOPSOVERRIDE pOverride = (PVBOXNETDEVICEOPSOVERRIDE)pDev->netdev_ops; 275 RTNETETHERHDR EtherHdrBuf;277 uint8_t abHdrBuf[sizeof(RTNETETHERHDR) + sizeof(uint32_t) + RTNETIPV4_MIN_LEN]; 276 278 PCRTNETETHERHDR pEtherHdr; 279 PINTNETTRUNKSWPORT pSwitchPort; 280 277 281 278 282 /* … … 300 304 * drop it. 301 305 */ 302 pEtherHdr = (PCRTNETETHERHDR)skb_header_pointer(pSkb, 0, sizeof( EtherHdrBuf), &EtherHdrBuf);303 if ( 304 && pEtherHdr->DstMac.au8[0] == 0x08305 && pEtherHdr->DstMac.au8[1] == 0x00306 && pEtherHdr->DstMac.au8[2] == 0x27306 pEtherHdr = (PCRTNETETHERHDR)skb_header_pointer(pSkb, 0, sizeof(abHdrBuf), &abHdrBuf[0]); 307 if ( pEtherHdr 308 && VALID_PTR(pOverride->pVBoxNetFlt) 309 && (pSwitchPort = pOverride->pVBoxNetFlt->pSwitchPort) != NULL 310 && VALID_PTR(pSwitchPort) 307 311 ) 308 312 { 309 dev_kfree_skb(pSkb); 310 pOverride->cFiltered++; 311 return NETDEV_TX_OK; 313 INTNETSWDECISION enmDecision; 314 uint32_t cbHdrs = skb_headlen(pSkb); 315 cbHdrs = RT_MAX(cbHdrs, sizeof(abHdrBuf)); 316 317 /** @todo consider reference counting, etc. */ 318 enmDecision = pSwitchPort->pfnPreRecv(pSwitchPort, pEtherHdr, cbHdrs, INTNETTRUNKDIR_HOST); 319 if (enmDecision == INTNETSWDECISION_INTNET) 320 { 321 dev_kfree_skb(pSkb); 322 pOverride->cFiltered++; 323 return NETDEV_TX_OK; 324 } 312 325 } 313 326 … … 333 346 pOverride->Ops.ndo_start_xmit = vboxNetFltLinuxStartXmitFilter; 334 347 pOverride->u32Magic = VBOXNETDEVICEOPSOVERRIDE_MAGIC; 348 pOverride->cTotal = 0; 349 pOverride->cFiltered = 0; 350 pOverride->pVBoxNetFlt = pThis; 335 351 336 352 RTSpinlockAcquire(pThis->hSpinlock, &Tmp); /* (this isn't necessary, but so what) */
Note:
See TracChangeset
for help on using the changeset viewer.