123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 |
- /*
- * Copyright (c) 1999 - 2005 NetGroup, Politecnico di Torino (Italy)
- * Copyright (c) 2005 - 2006 CACE Technologies, Davis (California)
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- *
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- * 3. Neither the name of the Politecnico di Torino, CACE Technologies
- * nor the names of its contributors may be used to endorse or promote
- * products derived from this software without specific prior written
- * permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- */
- #include <stdio.h>
- #include <conio.h>
- #include <time.h>
- #include <Packet32.h>
- #define Max_Num_Adapter 10
- #include <tchar.h>
- BOOL LoadNpcapDlls()
- {
- TCHAR npcap_dir[512];
- UINT len;
- len = GetSystemDirectory(npcap_dir, 480);
- if (!len) {
- fprintf(stderr, "Error in GetSystemDirectory: %x", GetLastError());
- return FALSE;
- }
- _tcscat_s(npcap_dir, 512, TEXT("\\Npcap"));
- if (SetDllDirectory(npcap_dir) == 0) {
- fprintf(stderr, "Error in SetDllDirectory: %x", GetLastError());
- return FALSE;
- }
- return TRUE;
- }
- // Prototypes
- void PrintPackets(LPPACKET lpPacket);
- char AdapterList[Max_Num_Adapter][8192];
- int main(int argc, char **argv)
- {
- char packetbuff[5000];
- // define a pointer to a ADAPTER structure
- LPADAPTER lpAdapter = 0;
- // define a pointer to a PACKET structure
- LPPACKET lpPacket;
- int i,npacks,Snaplen;
- DWORD dwErrorCode;
- //ascii strings
- char AdapterName[8192]; // string that contains a list of the network adapters
- char *temp,*temp1;
- int AdapterNum=0,Open;
- ULONG AdapterLength;
- float cpu_time;
-
- /* Load Npcap and its functions. */
- if (!LoadNpcapDlls())
- {
- fprintf(stderr, "Couldn't load Npcap\n");
- exit(1);
- }
- printf("Traffic Generator v 0.9999\nCopyright 1999 Loris Degioanni (loris@netgroup-serv.polito.it)");
- printf("\nSends a set of packets to the network using packet.dll API.\n");
-
- if (argc == 1){
- printf("\n\n Usage: TestpacketSend [-i adapter] -n npacks -s size");
- printf("\n size is between 60 and 1514\n\n");
- return -1;
- }
-
-
- AdapterName[0]=0;
-
- //get the command line parameters
- for(i=1;i<argc;i+=2){
-
- switch (argv[i] [1])
- {
-
- case 'i':
- sscanf_s(argv[i+1],"%s",AdapterName, (unsigned)_countof(AdapterName));
- break;
-
- case 'n':
- sscanf_s(argv[i+1],"%d",&npacks);
- break;
-
- case 's':
- sscanf_s(argv[i+1],"%d",&Snaplen);
- break;
-
- }
-
- }
-
-
-
- if(AdapterName[0]==0){
-
- //
- // Obtain the name of the adapters installed on this machine
- //
- printf("Adapters installed:\n");
- i=0;
-
- AdapterLength = sizeof(AdapterName);
- if(PacketGetAdapterNames(AdapterName,&AdapterLength)==FALSE){
- printf("Unable to retrieve the list of the adapters!\n");
- return -1;
- }
- temp=AdapterName;
- temp1=AdapterName;
-
- while ((*temp!='\0')||(*(temp-1)!='\0'))
- {
- if (*temp=='\0')
- {
- memcpy(AdapterList[i],temp1,temp-temp1);
- temp1=temp+1;
- i++;
- }
- temp++;
- }
-
- AdapterNum=i;
- for (i=0;i<AdapterNum;i++)
- printf("\n%d- %s\n",i+1,AdapterList[i]);
- printf("\n");
-
- do
- {
- printf("Select the number of the adapter to open : ");scanf_s("%d",&Open);
- if (Open>AdapterNum) printf("\nThe number must be smaller than %d",AdapterNum);
- } while (Open>AdapterNum);
-
-
-
-
- lpAdapter = PacketOpenAdapter(AdapterList[Open-1]);
-
- if (!lpAdapter || (lpAdapter->hFile == INVALID_HANDLE_VALUE))
- {
- dwErrorCode=GetLastError();
- printf("Unable to open the driver, Error Code : %lx\n",dwErrorCode);
-
- return(-1);
- }
-
- }
- else{
-
- lpAdapter = PacketOpenAdapter(AdapterName);
-
- if (!lpAdapter || (lpAdapter->hFile == INVALID_HANDLE_VALUE))
- {
- dwErrorCode=GetLastError();
- printf("Unable to open the driver, Error Code : %lx\n",dwErrorCode);
-
- return(-1);
- }
-
- }
-
- if((lpPacket = PacketAllocatePacket())==NULL){
- printf("\nError:failed to allocate the LPPACKET structure.");
- return (-1);
- }
-
- packetbuff[0]=1;
- packetbuff[1]=1;
- packetbuff[2]=1;
- packetbuff[3]=1;
- packetbuff[4]=1;
- packetbuff[5]=1;
-
- packetbuff[6]=2;
- packetbuff[7]=2;
- packetbuff[8]=2;
- packetbuff[9]=2;
- packetbuff[10]=2;
- packetbuff[11]=2;
-
- for(i=12;i<1514;i++){
- packetbuff[i]= (char)i;
- }
-
- PacketInitPacket(lpPacket,packetbuff,Snaplen);
- // capture the packet
-
-
- if(PacketSetNumWrites(lpAdapter,npacks)==FALSE){
- printf("warning: Unable to send more than one packet in a single write!\n");
- }
-
- printf("\n\nGenerating %d packets...",npacks);
-
- cpu_time = (float)clock ();
-
- if(PacketSendPacket(lpAdapter,lpPacket,TRUE)==FALSE){
- printf("Error sending the packets!\n");
- return -1;
- }
-
- cpu_time = (clock() - cpu_time)/CLK_TCK;
-
- printf ("\n\nElapsed time: %5.3f\n", cpu_time);
- printf ("\nTotal packets generated = %d", npacks);
- printf ("\nTotal bytes generated = %d", (Snaplen+24)*npacks);
- printf ("\nTotal bits generated = %d", (Snaplen+24)*npacks*8);
- printf ("\nAverage packets per second = %d", (int)((double)npacks/cpu_time));
- printf ("\nAverage bytes per second = %d", (int)((double)((Snaplen+24)*npacks)/cpu_time));
- printf ("\nAverage bits per second = %d", (int)((double)((Snaplen+24)*npacks*8)/cpu_time));
- printf ("\n");
-
- PacketFreePacket(lpPacket);
-
- // close the adapter and exit
-
- PacketCloseAdapter(lpAdapter);
- return (0);
- }
|