]> git.ipfire.org Git - people/teissler/ipfire-2.x.git/commitdiff
Namen der Netzwerkkarten können jetzt geändert werden.
authorcasemaster <casemaster@ea5c0bd1-69bd-2848-81d8-4f18e57aeed8>
Sat, 14 Jul 2007 17:22:40 +0000 (17:22 +0000)
committercasemaster <casemaster@ea5c0bd1-69bd-2848-81d8-4f18e57aeed8>
Sat, 14 Jul 2007 17:22:40 +0000 (17:22 +0000)
git-svn-id: http://svn.ipfire.org/svn/ipfire/trunk@685 ea5c0bd1-69bd-2848-81d8-4f18e57aeed8

src/install+setup/libsmooth/libsmooth.h
src/install+setup/libsmooth/netstuff.c
src/install+setup/setup/networking.c

index 88ec00561a22798a5d50fad0055a0dd8277f02d4..54d702926befd789ea7088e2e978358435779d8d 100644 (file)
@@ -44,6 +44,7 @@
 #define NETCHANGE_TOTAL 4
 
 #define SCANNED_NICS "/var/ipfire/ethernet/scanned_nics"
+#define SYSDIR "/sys/class/net"
 
 #define _GREEN_CARD_ 0
 #define _RED_CARD_ 1
@@ -94,6 +95,7 @@ int gettype(char *type);
 int setnetaddress(struct keyvalue *kv, char *colour);
 void networkdialogcallbacktype(newtComponent cm, void *data);
 int interfacecheck(struct keyvalue *kv, char *colour);
+int rename_nics(void);
 int init_knics(void);
 int create_udev(void);
 int scan_network_cards(void);
index 54143745149c93b13015db9167de93a5dc0b2692..3f488774700421aca2b581bedf9b7a95d5648caa 100644 (file)
@@ -412,6 +412,142 @@ int init_knics(void)
        return found;
 }
 
+int fmt_exists(const char *fname) {    /* Check it's any File or Directory */
+       struct stat st;
+       if (stat(fname, &st) == -1) return 0;
+       else return 1;
+}
+
+int is_interface_up(char *card) {      /* Check is interface UP */
+       char temp[STRING_SIZE];
+
+       sprintf(temp,"ip link show dev %s | grep -q UP", card);
+       if (mysystem(temp)) return 0; else return 1;
+}
+
+int rename_device(char *old_name, char *new_name) {
+       char temp[STRING_SIZE];
+
+       sprintf(temp,SYSDIR "/%s", old_name);
+       if (!(fmt_exists(temp))) {
+               fprintf(flog,"Device not found: %s\n",old_name);
+               return 0;
+       }
+//     fprintf(flog,"NIC: %s wurde in %s umbenannt.\n", old_name, new_name);   // #### Debug ####
+       sprintf(temp,"/sbin/ip link set dev %s name %s",old_name ,new_name );
+       mysystem(temp);
+
+       return 1;
+}
+
+char g_temp[STRING_SIZE]="";
+char* readmac(char *card) {
+//     fprintf(flog,"Enter readmac... NIC: %s\n", card);       // #### Debug ####
+       FILE *fp;
+       char temp[STRING_SIZE], mac[20];
+
+       sprintf(temp,"/sys/class/net/%s/address",card);
+       if( (fp = fopen(temp, "r")) == NULL ) {
+               fprintf(flog,"Couldn't open: %s\n",temp);
+               return NULL;
+       }
+       fgets(mac, 18, fp);
+       strtok(mac,"\n");
+       fclose(fp);
+       strcpy(g_temp, mac);
+       return g_temp;
+}
+
+char* find_nic4mac(char *findmac) {
+       fprintf(flog,"Enter find_name4nic... Search for %s\n", findmac);        // #### Debug ####
+
+       DIR *dir;
+       struct dirent *dirzeiger;
+       char temp[STRING_SIZE], temp2[STRING_SIZE];
+        
+       if((dir=opendir(SYSDIR)) == NULL) {
+               fprintf(flog,"Fehler bei opendir (find_name4nic) ...\n");
+               return NULL;
+       }
+
+       sprintf(temp, "");
+       while((dirzeiger=readdir(dir)) != NULL) {
+               if(*((*dirzeiger).d_name) != '.' & strcmp(((*dirzeiger).d_name), "lo") != 0) {
+                       sprintf(temp2, "%s", readmac((*dirzeiger).d_name) );
+                       if (strcmp(findmac, temp2) == 0) {
+                               sprintf(temp,"%s", (*dirzeiger).d_name);
+//                             fprintf(flog,"MAC: %s is NIC: %s\n", findmac, temp);    // #### Debug ####
+                               break;
+                       }
+               }
+       }
+
+       if(closedir(dir) == -1) fprintf(flog,"Fehler beim schliessen von %s\n", SYSDIR);
+       strcpy(g_temp, temp);
+       return g_temp;
+}
+
+int nic_shutdown(char *nic) {
+       char temp[STRING_SIZE];
+       
+       sprintf(temp,"ip link set %s down", nic);
+       mysystem(temp);
+}
+
+int nic_startup(char *nic) {
+       char temp[STRING_SIZE];
+       
+       sprintf(temp,"ip link set %s up", nic);
+       mysystem(temp);
+
+}
+
+int rename_nics(void) {
+       int i, j, k;
+       int fnics = scan_network_cards();
+       char nic2find[STRING_SIZE], temp[STRING_SIZE];
+
+       fprintf(flog,"Renaming Nics\n");        // #### Debug ####
+
+       for(i=0; i<4; i++)
+               if (strcmp(knics[i].macaddr, ""))                                                                       // Wird das Interface benutzt ?
+                       for(j=0; j<fnics; j++)
+                               if(strcmp(knics[i].macaddr, nics[j].macaddr) == 0) {                                    // suche den aktuellen Namen
+                                       sprintf(nic2find,"%s0",lcolourcard[i]);
+//                                     fprintf(flog,"search4: %s\n", nic2find);        // #### Debug ####
+                                       if(strcmp(nic2find, nics[j].nic)) {                                             // hat das Interface nicht den Namen ?
+//                                             fprintf(flog,"cmp nic2find false\n");   // #### Debug ####
+//                                             fprintf(flog,"is nic( %s ) up ?\n",nics[j].nic);        // #### Debug ####
+
+                                               if(is_interface_up(nics[j].nic)) {                                      // wurde das Interface gestartet ?
+//                                                     fprintf(flog,"%s is UP, shutting down...\n",nics[j].nic);       // #### Debug ####
+                                                       nic_shutdown(nics[j].nic);
+                                               }
+                                               sprintf(temp,SYSDIR "/%s", nic2find);
+//                                             fprintf(flog,"exists ?--> %s\n", temp); // #### Debug ####
+                                               if(fmt_exists(temp)) {                                                  // Ist der Name schon in Benutzung ?
+//                                                     fprintf(flog,"is exists %s\n", nic2find);       // #### Debug ####
+                                                       for(k=0; k<fnics; k++)                          // Suche das Interface
+                                                               if (strcmp(nics[k].nic, nic2find) == 0 ) {
+                                                                       if(is_interface_up(nics[k].nic)) {              // wurde das Interface gestartet ?
+//                                                                             fprintf(flog,"%s is UP, shutting down...\n",nics[k].nic);       // #### Debug ####
+                                                                               nic_shutdown(nics[k].nic);
+                                                                       }
+                                                                       sprintf(temp,"dummy%i",k);                      // Benenne NIC nach "dummy[k]" um.
+//                                                                     fprintf(flog,"set dummy%i\n", k);       // #### Debug ####
+                                                                       if (rename_device(nics[k].nic, temp)) strcpy(nics[k].nic, temp);
+                                                               }
+                                               }
+                                               if (rename_device(nics[j].nic, nic2find)) strcpy(nics[j].nic, nic2find);        // Benenne NIC um.
+
+//                                             if(strncmp(nics[j].nic,"dummy",5)) {
+//                                                     fprintf(flog,"%s is down, start up...\n",nics[j].nic);  // #### Debug ####
+//                                                     nic_startup(nics[j].nic);
+//                                             }
+                                       }
+                               }
+}
+
 int create_udev(void)
 {
        #define UDEV_NET_CONF "/etc/udev/rules.d/30-persistent-network.rules"
@@ -470,54 +606,6 @@ int write_configs_netudev(int card , int colour)
        return 0;
 }
 
-char g_temp[STRING_SIZE]="";
-char* readmac(char *card) {
-       fprintf(flog,"Enter readmac... NIC: %s\n", card);       // #### Debug ####
-       FILE *fp;
-       char temp[STRING_SIZE], mac[20];
-
-       sprintf(temp,"/sys/class/net/%s/address",card);
-       if( (fp = fopen(temp, "r")) == NULL ) {
-               fprintf(flog,"Couldn't open: %s\n",temp);
-               return NULL;
-       }
-       fgets(mac, 18, fp);
-       strtok(mac,"\n");
-       fclose(fp);
-       strcpy(g_temp, mac);
-       return g_temp;
-}
-
-char* find_nic4mac(char *findmac) {
-       fprintf(flog,"Enter find_name4nic... Search for %s\n", findmac);        // #### Debug ####
-       #define SYSDIR "/sys/class/net"
-
-       DIR *dir;
-       struct dirent *dirzeiger;
-       char temp[STRING_SIZE], temp2[STRING_SIZE];
-        
-       if((dir=opendir(SYSDIR)) == NULL) {
-               fprintf(flog,"Fehler bei opendir (find_name4nic) ...\n");
-               return NULL;
-       }
-
-       sprintf(temp, "");
-       while((dirzeiger=readdir(dir)) != NULL) {
-               if(*((*dirzeiger).d_name) != '.' & strcmp(((*dirzeiger).d_name), "lo") != 0) {
-                       sprintf(temp2, "%s", readmac((*dirzeiger).d_name) );
-                       if (strcmp(findmac, temp2) == 0) {
-                               sprintf(temp,"%s", (*dirzeiger).d_name);
-                               fprintf(flog,"MAC: %s is NIC: %s\n", findmac, temp);    // #### Debug ####
-                               break;
-                       }
-               }
-       }
-
-       if(closedir(dir) == -1) fprintf(flog,"Fehler beim schliessen von %s\n", SYSDIR);
-       strcpy(g_temp, temp);
-       return g_temp;
-}
-
 int scan_network_cards(void)
 {
        FILE *fp;
index e08fa11192240ad4b8dc533176174e5f0df94136..29c00cba1c899f5a17c59421bc1a68ea920b90b9 100644 (file)
@@ -134,6 +134,9 @@ int handlenetworking(void)
                {
                        runcommandwithstatus("/etc/rc.d/init.d/network stop",
                                ctr[TR_PUSHING_NETWORK_DOWN]);
+
+                       rename_nics();
+
                        runcommandwithstatus("/etc/rc.d/init.d/network start",
                                ctr[TR_PULLING_NETWORK_UP]);
                }
@@ -540,11 +543,13 @@ int changedrivers(void)
                        if ((red) && ( choise == NicEntry[1])) nicmenu(_RED_CARD_);
                        if ((orange) && ( choise == NicEntry[2])) nicmenu(_ORANGE_CARD_);
                        if ((blue) && ( choise == NicEntry[3])) nicmenu(_BLUE_CARD_);
+                       netaddresschange = 1;
                } else if (rc == 2) {
                        if ((green) && ( choise == NicEntry[0])) ask_clear_card_entry(_GREEN_CARD_);
                        if ((red) && ( choise == NicEntry[1])) ask_clear_card_entry(_RED_CARD_);
                        if ((orange) && ( choise == NicEntry[2])) ask_clear_card_entry(_ORANGE_CARD_);
                        if ((blue) && ( choise == NicEntry[3])) ask_clear_card_entry(_BLUE_CARD_);
+                       netaddresschange = 1;
                } 
 //             else {
 //                     errorbox("Sie haben keine Netzwerkkarte ausgewaehlt.\n");