On Tue, Aug 6, 2019 at 8:42 PM Michal Hocko <mhocko@xxxxxxxxxx> wrote:
>
> On Tue 06-08-19 20:39:22, Pankaj Suryawanshi wrote:
> > On Tue, Aug 6, 2019 at 8:37 PM Michal Hocko <mhocko@xxxxxxxxxx> wrote:
> > >
> > > On Tue 06-08-19 20:24:03, Pankaj Suryawanshi wrote:
> > > > On Tue, 6 Aug, 2019, 1:46 AM Michal Hocko, <mhocko@xxxxxxxxxx> wrote:
> > > > >
> > > > > On Mon 05-08-19 21:04:53, Pankaj Suryawanshi wrote:
> > > > > > On Mon, Aug 5, 2019 at 5:35 PM Michal Hocko <mhocko@xxxxxxxxxx> wrote:
> > > > > > >
> > > > > > > On Mon 05-08-19 13:56:20, Vlastimil Babka wrote:
> > > > > > > > On 8/5/19 1:24 PM, Michal Hocko wrote:
> > > > > > > > >> [ 727.954355] CPU: 0 PID: 56 Comm: kworker/u8:2 Tainted: P O 4.14.65 #606
> > > > > > > > > [...]
> > > > > > > > >> [ 728.029390] [<c034a094>] (oom_kill_process) from [<c034af24>] (out_of_memory+0x140/0x368)
> > > > > > > > >> [ 728.037569] r10:00000001 r9:c12169bc r8:00000041 r7:c121e680 r6:c1216588 r5:dd347d7c > [ 728.045392] r4:d5737080
> > > > > > > > >> [ 728.047929] [<c034ade4>] (out_of_memory) from [<c03519ac>] (__alloc_pages_nodemask+0x1178/0x124c)
> > > > > > > > >> [ 728.056798] r7:c141e7d0 r6:c12166a4 r5:00000000 r4:00001155
> > > > > > > > >> [ 728.062460] [<c0350834>] (__alloc_pages_nodemask) from [<c021e9d4>] (copy_process.part.5+0x114/0x1a28)
> > > > > > > > >> [ 728.071764] r10:00000000 r9:dd358000 r8:00000000 r7:c1447e08 r6:c1216588 r5:00808111
> > > > > > > > >> [ 728.079587] r4:d1063c00
> > > > > > > > >> [ 728.082119] [<c021e8c0>] (copy_process.part.5) from [<c0220470>] (_do_fork+0xd0/0x464)
> > > > > > > > >> [ 728.090034] r10:00000000 r9:00000000 r8:dd008400 r7:00000000 r6:c1216588 r5:d2d58ac0
> > > > > > > > >> [ 728.097857] r4:00808111
> > > > > > > > >
> > > > > > > > > The call trace tells that this is a fork (of a usermodhlper but that is
> > > > > > > > > not all that important.
> > > > > > > > > [...]
> > > > > > > > >> [ 728.260031] DMA free:17960kB min:16384kB low:25664kB high:29760kB active_anon:3556kB inactive_anon:0kB active_file:280kB inactive_file:28kB unevictable:0kB writepending:0kB present:458752kB managed:422896kB mlocked:0kB kernel_stack:6496kB pagetables:9904kB bounce:0kB free_pcp:348kB local_pcp:0kB free_cma:0kB
> > > > > > > > >> [ 728.287402] lowmem_reserve[]: 0 0 579 579
> > > > > > > > >
> > > > > > > > > So this is the only usable zone and you are close to the min watermark
> > > > > > > > > which means that your system is under a serious memory pressure but not
> > > > > > > > > yet under OOM for order-0 request. The situation is not great though
> > > > > > > > sometimes application(which cause to oom) works very slowly(result of application/score opengl app which allocate memory for graphics) and sometime it closed itself.
So the question is only Why their is difference in result when same oom killer killing applications (on same system/same mode/same situation) ? How to debug that because as you said oom killer dumped information after everything okay ?
> > > > > > > > Looking at lowmem_reserve above, wonder if 579 applies here? What does
> > > > > > > > /proc/zoneinfo say?
> > > > > >
> > > > > >
> > > > > > What is lowmem_reserve[]: 0 0 579 579 ?
> > > > >
> > > > > This controls how much of memory from a lower zone you might an
> > > > > allocation request for a higher zone consume. E.g. __GFP_HIGHMEM is
> > > > > allowed to use both lowmem and highmem zones. It is preferable to use
> > > > > highmem zone because other requests are not allowed to use it.
> > > > >
> > > > > Please see __zone_watermark_ok for more details.
> > > > >
> > > > >
> > > > > > > This is GFP_KERNEL request essentially so there shouldn't be any lowmem
> > > > > > > reserve here, no?
> > > > > >
> > > > > >
> > > > > > Why only low 1G is accessible by kernel in 32-bit system ?
> > > >
> > > >
> > > > 1G ivirtual or physical memory (I have 2GB of RAM) ?
> > >
> > > virtual
> > >
> > I have set 2G/2G still it works ?
>
> It would reduce the amount of memory that userspace might use. It may
> work for your particular case but the fundamental restriction is still
> there
> > > > > > > > Looking at lowmem_reserve above, wonder if 579 applies here? What does
> > > > > > > > /proc/zoneinfo say?
> > > > > >
> > > > > >
> > > > > > What is lowmem_reserve[]: 0 0 579 579 ?
> > > > >
> > > > > This controls how much of memory from a lower zone you might an
> > > > > allocation request for a higher zone consume. E.g. __GFP_HIGHMEM is
> > > > > allowed to use both lowmem and highmem zones. It is preferable to use
> > > > > highmem zone because other requests are not allowed to use it.
> > > > >
> > > > > Please see __zone_watermark_ok for more details.
> > > > >
> > > > >
> > > > > > > This is GFP_KERNEL request essentially so there shouldn't be any lowmem
> > > > > > > reserve here, no?
> > > > > >
> > > > > >
> > > > > > Why only low 1G is accessible by kernel in 32-bit system ?
> > > >
> > > >
> > > > 1G ivirtual or physical memory (I have 2GB of RAM) ?
> > >
> > > virtual
> > >
> > I have set 2G/2G still it works ?
>
> It would reduce the amount of memory that userspace might use. It may
> work for your particular case but the fundamental restriction is still
> there
Thanks Michal..
> --
> Michal Hocko
> SUSE Labs
> Michal Hocko
> SUSE Labs