abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:33 | Bezpečnostní upozornění

    V terminálovém multiplexoru GNU Screen byly nalezeny a v upstreamu ve verzi 5.0.1 už opraveny bezpečnostních chyby CVE-2025-23395, CVE-2025-46802, CVE-2025-46803, CVE-2025-46804 a CVE-2025-46805. Podrobnosti na blogu SUSE Security Teamu.

    Ladislav Hagara | Komentářů: 2
    včera 19:33 | Bezpečnostní upozornění

    Training Solo (Paper, GitHub) je nejnovější bezpečnostní problém procesorů Intel s eIBRS a některých procesorů ARM. Intel vydal opravnou verzi 20250512 mikrokódů pro své procesory.

    Ladislav Hagara | Komentářů: 0
    včera 11:44 | Nová verze

    Byla vydána nová verze 25.05.11 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Nejnovější Shotcut je již vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

    Ladislav Hagara | Komentářů: 0
    včera 11:11 | Nová verze

    Svobodný elektronický platební systém GNU Taler (Wikipedie, cgit) byl vydán ve verzi 1.0. GNU Taler chrání soukromí plátců a zároveň zajišťuje, aby byl příjem viditelný pro úřady. S vydáním verze 1.0 byl systém spuštěn ve Švýcarsku.

    Ladislav Hagara | Komentářů: 10
    včera 00:55 | Pozvánky

    Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 209. brněnský sraz, který proběhne tento pátek 16. května od 18:00 ve studentském klubu U Kachničky na Fakultě informačních technologií Vysokého učení technického na adrese Božetěchova 2/1. Jelikož se Brno stalo jedním z hlavních míst, kde se vyvíjí open source knihovna OpenSSL, tentokrát se OpenAlt komunita potká s komunitou OpenSSL. V rámci srazu Anton Arapov z OpenSSL

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 00:22 | Komunita

    GNOME Foundation má nového výkonného ředitele. Po deseti měsících skončil dočasný výkonný ředitel Richard Littauer. Vedení nadace převzal Steven Deobald.

    Ladislav Hagara | Komentářů: 4
    10.5. 15:00 | Zajímavý článek

    Byl publikován přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie) za uplynulé dva měsíce. Servo zvládne už i Gmail. Zakázány jsou příspěvky generované pomocí AI.

    Ladislav Hagara | Komentářů: 24
    9.5. 17:22 | Nová verze

    Raspberry Pi Connect, tj. oficiální služba Raspberry Pi pro vzdálený přístup k jednodeskovým počítačům Raspberry Pi z webového prohlížeče, byla vydána v nové verzi 2.5. Nejedná se už o beta verzi.

    Ladislav Hagara | Komentářů: 6
    9.5. 15:22 | Komunita

    Google zveřejnil seznam 1272 projektů (vývojářů) od 185 organizací přijatých do letošního, již jednadvacátého, Google Summer of Code. Plánovaným vylepšením v grafických a multimediálních aplikacích se věnuje článek na Libre Arts.

    Ladislav Hagara | Komentářů: 0
    8.5. 19:22 | Nová verze

    Byla vydána (𝕏) dubnová aktualizace aneb nová verze 1.100 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.100 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    Jaký filesystém primárně používáte?
     (57%)
     (1%)
     (8%)
     (22%)
     (4%)
     (2%)
     (3%)
     (1%)
     (1%)
     (3%)
    Celkem 596 hlasů
     Komentářů: 26, poslední 8.5. 09:58
    Rozcestník

    Administrace komentářů

    Jste na stránce určené pro řešení chyb a problémů týkajících se diskusí a komentářů. Můžete zde našim administrátorům reportovat špatně zařazenou či duplicitní diskusi, vulgární či osočující příspěvek a podobně. Děkujeme vám za vaši pomoc, více očí více vidí, společně můžeme udržet vysokou kvalitu AbcLinuxu.cz.

    Příspěvek
    24.4.2010 22:31 Rogue | skóre: 4
    Rozbalit Rozbalit vše Re: Prace se soubory
    Ok tak tady je kompletni minimalni zkompilovatelny kod. Potřebuji poradit jak opravit problém uvedený v prvním příspěvku. Děkuji za Vaš čas a vaše napady.
    #define jmeno 1234
    #define SEM_NAMEa "/mysema"
    typedef struct counter
    {
      int count; 
    } COUNTER;
    
    int processedEvent(sem_t *semId, FILE* soubor, int shmid, COUNTER *sharedStuff);
    int main()
    { 
      pid_t pid;
      pid_t children[3];
      sem_t *semIdA;
      
      int retCode = 0;
      int shmid = 0;
      int i = 0;
      int stepsNumber = 0;
      void *sharedMemory = (void *) 0;
      struct counter *sharedStuff;
    
      // Zpracovani parametru programu;
      stepsNumber = 3;
      if (stepsNumber == -1)
      {
        fprintf(stderr, "Failed...\n");
        exit(EXIT_FAILURE);
      } 
      // Prace se souborem
      FILE *fw;
      fw = fopen("out.txt", "w");
      if (fw == NULL)
      {
        fprintf(stderr, "Failed...\n");
        exit(EXIT_FAILURE);
      }
      // Vytvoreni sdilene pameti;
      shmid = shmget((key_t)jmeno, 3 *sizeof(int), 0666 | IPC_CREAT);
      if (shmid == -1)
      {
        fprintf(stderr, "Failed...\n");
        exit(EXIT_FAILURE);
      }
      // Zpristupneni sdilene pameti programu;
      sharedMemory = shmat(shmid, (void *) 0, 0);
      if (sharedMemory == (void *) -1)
      {
        fprintf(stderr, "Failed...\n");
        exit(EXIT_FAILURE);
      }
      
      sharedStuff = (struct counter *) sharedMemory;
      sharedStuff->count=0;
      printf("Pocet: %d\n", sharedStuff->count);
      
      // Odpojeni sdilene pameti;
      retCode = shmdt(sharedMemory);
      if (retCode == -1)
      {
        fprintf(stderr, "Failed...\n");
        exit(EXIT_FAILURE);
      }
      // Vytvoreni semaforu;
      semIdA = sem_open(SEM_NAMEa, O_CREAT, 0666, 0);
      if (semIdA == SEM_FAILED)
      {
        fprintf(stderr, "Failed...\n");
        exit(EXIT_FAILURE);
      }
      // Vytvoreni podprocesu;
      for (; i<3; i++)
      {
        pid = fork();
        switch (pid)
        {
          case -1:
    	// Uvolneni prostredku;
    	fprintf(stderr, "Failed...\n");
            exit(EXIT_FAILURE);
    	break;
          case 0:
    	while (stepsNumber != 0)
    	{
    	  processedEvent(semIdA, fw, shmid, sharedStuff);
    	  stepsNumber--;
    	}
    	// Uzavreni souboru
    	retCode = fclose(fw);
    	if (retCode == EOF)
    	{
    	  fprintf(stderr, "Failed...\n");
    	  exit(EXIT_FAILURE);
    	}
    	exit(EXIT_SUCCESS);
    	break;
          default:
    	children[i] = pid;
    	break;
        }
      } 
      // Ukonceni potomknu;
      for (i = 0; i<3; i++)
      {
        retCode = waitpid(children[i], NULL, 0);
        if (retCode < 0)
        {
          retCode = kill(children[i], SIGTERM);
          if (retCode == -1)
          {
    	fprintf(stderr, "Failed...\n");
    	exit(EXIT_FAILURE);
          }
        }
      }
      // Zavreni semaforu;
      retCode = sem_close(semIdA);
      if (retCode == -1)
      {
        fprintf(stderr, "Failed...\n");
        exit(EXIT_FAILURE);
      }
      // Uvolneni porstredku semaforu;
      retCode = sem_unlink(SEM_NAMEa);
      if (retCode == -1)
      {
        fprintf(stderr, "Failed...\n");
        exit(EXIT_FAILURE);
      }
      // Zpristupneni sdilene pameti programu;
      sharedMemory = shmat(shmid, (void *) 0, 0);
      if (sharedMemory == (void *) -1)
      {
        fprintf(stderr, "Failed...\n");
        exit(EXIT_FAILURE);
      }
      
      printf("Pocet: %d\n", sharedStuff->count);
      
      // Odpojeni sdilene pameti;
      retCode = shmdt(sharedMemory);
      if (retCode == -1)
      {
        fprintf(stderr, "Failed...\n");
        exit(EXIT_FAILURE);
      }
      // Smazani sdilene pameti;
      retCode = shmctl(shmid, IPC_RMID, 0);
      if (retCode == -1)
      {
        fprintf(stderr, "Failed...\n");
        exit(EXIT_FAILURE);
      } 
      
      exit(EXIT_SUCCESS);
    }
    
    int processedEvent(sem_t *semId, FILE* soubor, int shmid, COUNTER *sharedStuff)
    {
      int retCode = 0;
      void *sharedMemory = (void *) 0;
      // Zpristupneni sdilene pameti programu
      sharedMemory = shmat(shmid, (void *) 0, 0);
      if (sharedMemory == (void *) -1)
      {
        return -1;
      }
      // Zablokovani semaforu
      retCode = sem_wait(semId);
      if (retCode == -1)
      {
        return -1;
      }
      //*****KS*****
      sharedStuff = (struct counter *) sharedMemory;
      sharedStuff->count ++;
      fprintf(soubor, "%d\n", sharedStuff->count);
      //*****KS*****
      // Odblokovani semaforu
      retCode = sem_post(semId);
      if (retCode == -1)
      {
        return -1;
      }
      // Zavreni semaforu
      retCode = sem_close(semId);
      if (retCode == -1)
      {
        return -1;
      }
      // Odpojeni sdilene pameti
      retCode = shmdt(sharedMemory);
      if (retCode == -1)
      {
        return -1;
      }
      return 0;
    }
    

    V tomto formuláři můžete formulovat svou stížnost ohledně příspěvku. Nejprve vyberte typ akce, kterou navrhujete provést s diskusí či příspěvkem. Potom do textového pole napište důvody, proč by měli admini provést vaši žádost, problém nemusí být patrný na první pohled. Odkaz na příspěvek bude přidán automaticky.

    Vaše jméno
    Váš email
    Typ požadavku
    Slovní popis
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.