delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2009/06/18/03:57:55

X-Recipient: archive-cygwin AT delorie DOT com
X-SWARE-Spam-Status: No, hits=-1.2 required=5.0 tests=AWL,BAYES_00,J_CHICKENPOX_54,J_CHICKENPOX_66,RCVD_IN_NJABL_PROXY,SPF_PASS
X-Spam-Check-By: sourceware.org
Date: Thu, 18 Jun 2009 09:57:30 +0200
To: =?utf-8?Q?Fr=C3=A9d=C3=A9ric_Bron?= <frederic DOT bron AT m4x DOT org>,
cygwin <cygwin AT cygwin DOT com>
Subject: Re: ioctl(sock, SIOCGIFHWADDR, &ifr) fails with 1.7
From: "Matthias Andree" <matthias DOT andree AT gmx DOT de>
MIME-Version: 1.0
References: <a9a39a210906120530j7892c00eu526489b97feff150 AT mail DOT gmail DOT com> <20090612142631 DOT GA14587 AT calimero DOT vinschen DOT de> <a9a39a210906150222k5aa69cddg22118d889328c004 AT mail DOT gmail DOT com>
Message-ID: <op.uvpm14t31e62zd@merlin.emma.line.org>
In-Reply-To: <a9a39a210906150222k5aa69cddg22118d889328c004@mail.gmail.com>
User-Agent: Opera Mail/9.64 (Linux)
X-IsSubscribed: yes
Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Id: <cygwin.cygwin.com>
List-Unsubscribe: <mailto:cygwin-unsubscribe-archive-cygwin=delorie DOT com AT cygwin DOT com>
List-Subscribe: <mailto:cygwin-subscribe AT cygwin DOT com>
List-Archive: <http://sourceware.org/ml/cygwin/>
List-Post: <mailto:cygwin AT cygwin DOT com>
List-Help: <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/ml/#faqs>
Sender: cygwin-owner AT cygwin DOT com
Mail-Followup-To: cygwin AT cygwin DOT com
Delivered-To: mailing list cygwin AT cygwin DOT com

Am 15.06.2009, 11:22 Uhr, schrieb Frédéric Bron <frederic DOT bron AT m4x DOT org>:

>> To fix your application, call either
>>
>>  struct ifconf ifc;
>>  ifc.ifc_len = sizeof (struct ifreq) * 32;
>>  ifc.ifc_buf = malloc (ifc.ifc_len);
>>  if (ioctl (fd, SIOCGIFCONF, &ifc))
>>    /* Resize ifc_buf and retry */
>>  else
>>    {
>>      struct ifreq *ifr = ifc.ifc_req;
>>      struct ifreq ifr2;
>>      for (int i = 0; i < ifc.ifc_len; i += sizeof (struct ifreq), ++ifr)
>>        if (!ioctl (fd, SIOCGIFADDR, &ifr2))
>>          /* Print result for that interface */
>>    }
>
> Thanks, this works half! No need of ifr2, ifr is enough.
> I saw the name change: 1.5 gives eth0, eth1, eth2, lo and 1.7 gives
> {821C54BE-...}...

Careful - this isn't portable to newer BSDs, as there ifc_len may exceed  
sizeof(struct ifreq).

getifaddrs() is probably the more portable solution here.

-- 
Matthias Andree

--
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple
Problem reports:       http://cygwin.com/problems.html
Documentation:         http://cygwin.com/docs.html
FAQ:                   http://cygwin.com/faq/

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019