[OT] Re: Controlling the garbage collector (GC) at RT?

Martin Egholm Nielsen martin@egholm-nielsen.dk
Thu Mar 17 09:16:00 GMT 2005


Hi Hans,
>>> You also need to touch the resulting memory. Try something like
>>> char *v = sbrk( 1000000 );
>>> for (char *p = v; p < p + 1000000; ++p) *p = 42;
>>> in the loop.
>> I'll try something similar tomorrow, thanks alot - although I will 
>> need modify the ever true statement "p < p + 1M" to "p < v + 1M"...
> So, now I tried this:
>> #include <unistd.h>
>> int main( int i )
> {
> while ( 1 ) {
> char *v = sbrk( 1000000 );
> char *p;
> for (*p = v; p < v + 1000000; ++p) {
> *p = 42;
> } // for
>> printf( "%x\n\n", v );
> } // while
> } // main
>> And still nothing happens with the memory consumption, although the 
> pointer ends up at 0xffffffff...
Nooow, after modifying the program to
for ( p = v; ...
it "works" - the application is terminated by the kernel.
This goes regardless what [0,1,2] is echo'ed into 
"/proc/sys/vm/overcommit_memory"...
The kernel reports:
Out of Memory: Killed process 36 (sbrktest)
But what should the outcome really had been?
I tried the same on an elder kernel on a different target - 2.4.17 and 
i386 - and the same outcome...
BR,
 Martin Egholm
>>>> -----Original Message-----
>>>> From: java-owner@gcc.gnu.org [mailto:java-owner@gcc.gnu.org] On 
>>>> Behalf Of Martin Egholm Nielsen
>>>> Sent: Wednesday, February 23, 2005 12:04 AM
>>>> To: java@gcc.gnu.org
>>>> Subject: Re: Controlling the garbage collector (GC) at RT?
>>>>>>>>>>>>>>>>> It seems to me that the only problem here is that this 
>>>> still seems to
>>>>> happen with overcommit-accounting set to 2.
>>>>> I would expect that you can reproduce this problem with a 
>>>> program that
>>>>> alternately allocates a few MB with sbrk, and then touches the 
>>>>> allocated memory. If you can't, there's something really 
>>>> weird going
>>>>> on here. If you can, it'll give you a test case for the kernel 
>>>>> people.
>>>> I tried the following:
>>>>>>>> #include <unistd.h>
>>>>>>>> int main( int i )
>>>> {
>>>> while ( 1 ) {
>>>> void *v = sbrk( 100000 );
>>>> // sleep( 1 );
>>>> } // while
>>>> } // main
>>>>>>>> But that doesn't result in anything - the memory usage for the 
>>>> application does not grow...
>>>> Are there anything else I should do to allocate the memory?
>>>>>>>> BR,
>>>> Martin
>>>>>>>>>>>>> Hans
>>>>>>>>>> On 2005年2月16日, Martin Egholm Nielsen wrote:
>>>>>>>>>>>>>>>>>>>>> Hi Hans,
>>>>>>>>>>>>>>>>>>>>>>>>>>> It would indeed be interesting to know why the Linux kernel
>>>>>>>>>>>>>>>>>>>>>>>>>>> kills the application rather than returning failure.
>>>>>>>>>>>>>>>>>>>>>>>>>> Sure, but how to do that? Any guidelines?
>>>>>>>>>>>>>>>>>>>>>>>>>>>> What do you see on the console? Anything in the system log? 
>>>>>>> Does strace tell you anything?
>>>>>>>>>>>>>>>>>>>>>>>> Below is the last part of "strace -f -F -i -v". It doesn't 
>>>>>>>>>>>>>>>> really look
>>>>>>>>>> like there's anything of value?
>>>>>>>>>>>> // Martin
>>>>>>>>>>>> [pid 75] [0f833558] write(1, "*** MEM CHUNK TAKEN: 
>>>>>>>>>>>>>>>> 8388608\n", 29***
>>>>>>>>>> MEM CHUNK TAKEN: 8388608
>>>>>> ) = 29
>>>>>> [pid 75] [0f839834] brk(0x12d15000) = 0x12d15000
>>>>>> [pid 75] [0f839834] brk(0x12d25000) = 0x12d25000
>>>>>> [pid 75] [0f81126c] getpid() = 75
>>>>>> [pid 75] [0f799444] kill(77, SIGPWR <unfinished ...>
>>>>>> [pid 76] [0f840e2c] <... poll resumed> [{fd=3, events=POLLIN,
>>>>>> revents=POLLIN}
>>>>>> ], 1, 2000) = 1
>>>>>> [pid 75] [0f799444] <... kill resumed> ) = 0
>>>>>> [pid 76] [0f81127c] getppid() = 75
>>>>>> [pid 76] [0f833548] read(3,
>>>>>> "20円7円/234円0円0円0円4円17円374円0ドル20円7円/240円$0円0円B17円3円
>>>>>> 72j(177円"..., 148) = 148
>>>>>> [pid 76] [0f840e2c] poll( <unfinished ...>
>>>>>> [pid 75] [0f799444] kill(77, SIGXCPU) = 0
>>>>>> [pid 75] [0f839834] brk(0x13525000) = 0x13525000
>>>>>> [pid 75] [0f833558] write(1, "*** MEM CHUNK TAKEN: 
>>>>>>>>>>>>>>>> 8388608\n", 29***
>>>>>>>>>> MEM CHUNK TAKEN: 8388608
>>>>>> ) = 29
>>>>>> [pid 75] [0f839834] brk(0x13535000) = 0x13535000
>>>>>> [pid 75] [0f839834] brk(0x13545000) = 0x13545000
>>>>>> [pid 75] [0f839834] brk(0x13d45000) = 0x13d45000
>>>>>> [pid 75] [0f833558] write(1, "*** MEM CHUNK TAKEN: 
>>>>>>>>>>>>>>>> 8388608\n", 29***
>>>>>>>>>> MEM CHUNK TAKEN: 8388608
>>>>>> ) = 29
>>>>>> [pid 76] [0f840e2c] <... poll resumed> [{fd=3, 
>>>>>>>>>>>>>>>> events=POLLIN}], 1,
>>>>>>>>>> 2000) = 0
>>>>>> [pid 76] [0f840e2c] --- SIGTERM (Terminated) ---
>>>>>> #
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>


More information about the Java mailing list

AltStyle によって変換されたページ (->オリジナル) /