delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2001/06/03/20:32:22

Mailing-List: contact cygwin-help AT sourceware DOT cygnus DOT com; run by ezmlm
List-Subscribe: <mailto:cygwin-subscribe AT sources DOT redhat DOT com>
List-Archive: <http://sources.redhat.com/ml/cygwin/>
List-Post: <mailto:cygwin AT sources DOT redhat DOT com>
List-Help: <mailto:cygwin-help AT sources DOT redhat DOT com>, <http://sources.redhat.com/ml/#faqs>
Sender: cygwin-owner AT sources DOT redhat DOT com
Delivered-To: mailing list cygwin AT sources DOT redhat DOT com
Message-ID: <20010604003132.12969.qmail@web14503.mail.yahoo.com>
Date: Mon, 4 Jun 2001 10:31:32 +1000 (EST)
From: =?iso-8859-1?q?Danny=20Smith?= <danny_r_smith_2001 AT yahoo DOT co DOT nz>
Subject: Re: CreateFiber() : number of fibers limited
To: cygwin AT cygwin DOT com
In-Reply-To: <20010603234114.A3655@systematik.co.nz>
MIME-Version: 1.0

--- Dan Plimak <danp AT systematik DOT co DOT nz> wrote: > On Sun, Jun 03, 2001 at
12:16:07PM +0200, Holger Vogt wrote:
> > Hi,
> > 
> > independently of the requested stack size (first parameter in
> > CreateFiber()), CYGWIN will give only 53 fibers. Only when I increase
> > the stack size above 9.5 MByte, I will get a further reduction in the
> > number of fibers created.
> 
> I was intrigued by this difference between gcc and Borland C++Builder and MS
> Visual C++, so I tried the following code under all three compilers on
> Win2K:
> 
> ---
> 
> #define _WIN32_WINNT 0x0500 /* Coax winbase.h into including
>                                ConvertThreadToFiber() */
> #include <windows.h>
> #include <stdio.h>
> 
> #define MEG       (1024 * 1024)
> #define STACKSIZE (MEG * 2)
> 
> int main()
> {
>         int param = 0, i = 0;
>         LPFIBER_START_ROUTINE saddr = NULL;
>         LPVOID foo;
> 
>         ConvertThreadToFiber(&param);
> 
>         while(++i) {
> 
>                 foo = CreateFiber(STACKSIZE, saddr, &param);
> 
>                 if(foo != NULL)
>                         printf("Created fiber 0x%08x.\n", foo);
>                 else {
>                         printf("Failed to create fiber at iteration %d;\n"
>                                 "stack space allocated: %dMB\n",
>                                 i, (STACKSIZE * i) / MEG);
>                         break;
>                 }
>         }
> 
>         return 0;
> }
> 
> ---
> 
> The results are definitely interesting. The runtime code generated by VC++
> (6.0) and BCB (bcc32.exe v5.5) will allow stack allocation by fibers until
> total stack space allocated hits the free memory limit on the system.
> 
> Whereas with gcc, no matter how small you make your stack, the maximum
> number of fibers will be 52. (If it was 42, I'd suspect somebody was taking
> the Hitchhiker's Guide to the Galaxy a wee bit too seriously.)
> 
> All in all, I don't think this is a bug in the library. It definitely looks
> like a hard limit on the number of stacks/fibers you can allocate --
> something of the sort Danny Smith proposed, but "harder". Without looking at
> the source, I doubt anybody would be able to pin it down (unless they happen
> to be the gcc maintainer).
> 
> You might want to ask on the gcc mailing list(s).
> 
> Cheers,
> 
>   -- danp

Try changing the stacksize when build the app,
eg:

gcc -Wl,--stack,0x1000000 fiber.c

With this setting  I can get 126 fibers

As I set the app stack reserve smaller and smaller, I can create more fibers.
 
gcc -Wl,--stack,0x100000 fiber.c gets me 196 fibers (each with a 1 MB stack
reserve

and so on.

Hmmm, Does CreateFiber implicitly create a thread with a default (set by main
thread) stack reserve and then convert it to a fiber?


danny

> 


_____________________________________________________________________________
http://messenger.yahoo.com.au - Yahoo! Messenger
- Voice chat, mail alerts, stock quotes and favourite news and lots more!

--
Want to unsubscribe from this list?
Check out: http://cygwin.com/ml/#unsubscribe-simple

- Raw text -


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