All of lore.kernel.org
 help / color / mirror / Atom feed
* [kselftests] compaction_test is blocked
@ 2018-02-09  7:53 ` lizhijian
  0 siblings, 0 replies; 15+ messages in thread
From: Li Zhijian @ 2018-02-09  7:53 UTC (permalink / raw)
  To: linux-kselftest; +Cc: Li, Philip, linux-kernel, Li Zhijian(intel)

Hi

kselftests is integrated Intel 0Day project.
Sometimes we found compaction_test is blocked for more than 1 hours until i kill it.

Try to figure out where it is running, i added some log to this case.

the test log is like:
-------------------
  [  111.750543] main: 248
  [  111.750544]-
  [ 111.750821] check_compaction: 98
  [  111.750822]-
  [  111.751102] check_compaction: 105
  [  111.751103]-
  [  111.751362] check_compaction: 111
  [  111.751363]-
  [  111.751621] check_compaction: 118
  [  111.751622]-
  [  111.751879] check_compaction: 123
  [  111.751880]-
-------------------
118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
119         lseek(fd, 0, SEEK_SET);
120
121         /* Request a large number of huge pages. The Kernel will allocate
122            as much as it can */
123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         <<<======== the last line we can catch.
124         if (write(fd, "100000", (6*sizeof(char))) != (6*sizeof(char))) {        <<<<============ blocking position
125                 perror("Failed to write 100000 to /proc/sys/vm/nr_hugepages\n");
126                 goto close_fd;
127         }
128
129         lseek(fd, 0, SEEK_SET);
130
131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
133                 perror("Failed to re-read from /proc/sys/vm/nr_hugepages\n");
134                 goto close_fd;
135         }
-------------------

According to above log and code, it most likely it is blocking at the writing operation.

my environment is like:
OS: debian
kernel: v4.15
model: Ivytown Ivy Bridge-EP
nr_cpu: 48
memory: 64G


NOTE: 0Day can reproduce this issue in 20% on 0Day.

Anybody can help have a look?

Thanks
Zhjian




^ permalink raw reply	[flat|nested] 15+ messages in thread

* [Linux-kselftest-mirror] [kselftests] compaction_test is blocked
@ 2018-02-09  7:53 ` lizhijian
  0 siblings, 0 replies; 15+ messages in thread
From: lizhijian @ 2018-02-09  7:53 UTC (permalink / raw)


Hi

kselftests is integrated Intel 0Day project.
Sometimes we found compaction_test is blocked for more than 1 hours until i kill it.

Try to figure out where it is running, i added some log to this case.

the test log is like:
-------------------
  [  111.750543] main: 248
  [  111.750544]-
  [ 111.750821] check_compaction: 98
  [  111.750822]-
  [  111.751102] check_compaction: 105
  [  111.751103]-
  [  111.751362] check_compaction: 111
  [  111.751363]-
  [  111.751621] check_compaction: 118
  [  111.751622]-
  [  111.751879] check_compaction: 123
  [  111.751880]-
-------------------
118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
119         lseek(fd, 0, SEEK_SET);
120
121         /* Request a large number of huge pages. The Kernel will allocate
122            as much as it can */
123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         <<<======== the last line we can catch.
124         if (write(fd, "100000", (6*sizeof(char))) != (6*sizeof(char))) {        <<<<============ blocking position
125                 perror("Failed to write 100000 to /proc/sys/vm/nr_hugepages\n");
126                 goto close_fd;
127         }
128
129         lseek(fd, 0, SEEK_SET);
130
131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
133                 perror("Failed to re-read from /proc/sys/vm/nr_hugepages\n");
134                 goto close_fd;
135         }
-------------------

According to above log and code, it most likely it is blocking at the writing operation.

my environment is like:
OS: debian
kernel: v4.15
model: Ivytown Ivy Bridge-EP
nr_cpu: 48
memory: 64G


NOTE: 0Day can reproduce this issue in 20% on 0Day.

Anybody can help have a look?

Thanks
Zhjian



--
To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 15+ messages in thread

* [Linux-kselftest-mirror] [kselftests] compaction_test is blocked
@ 2018-02-09  7:53 ` lizhijian
  0 siblings, 0 replies; 15+ messages in thread
From: Li Zhijian @ 2018-02-09  7:53 UTC (permalink / raw)


Hi

kselftests is integrated Intel 0Day project.
Sometimes we found compaction_test is blocked for more than 1 hours until i kill it.

Try to figure out where it is running, i added some log to this case.

the test log is like:
-------------------
  [  111.750543] main: 248
  [  111.750544]-
  [ 111.750821] check_compaction: 98
  [  111.750822]-
  [  111.751102] check_compaction: 105
  [  111.751103]-
  [  111.751362] check_compaction: 111
  [  111.751363]-
  [  111.751621] check_compaction: 118
  [  111.751622]-
  [  111.751879] check_compaction: 123
  [  111.751880]-
-------------------
118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
119         lseek(fd, 0, SEEK_SET);
120
121         /* Request a large number of huge pages. The Kernel will allocate
122            as much as it can */
123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         <<<======== the last line we can catch.
124         if (write(fd, "100000", (6*sizeof(char))) != (6*sizeof(char))) {        <<<<============ blocking position
125                 perror("Failed to write 100000 to /proc/sys/vm/nr_hugepages\n");
126                 goto close_fd;
127         }
128
129         lseek(fd, 0, SEEK_SET);
130
131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
133                 perror("Failed to re-read from /proc/sys/vm/nr_hugepages\n");
134                 goto close_fd;
135         }
-------------------

According to above log and code, it most likely it is blocking at the writing operation.

my environment is like:
OS: debian
kernel: v4.15
model: Ivytown Ivy Bridge-EP
nr_cpu: 48
memory: 64G


NOTE: 0Day can reproduce this issue in 20% on 0Day.

Anybody can help have a look?

Thanks
Zhjian



--
To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 15+ messages in thread

* Re: [kselftests] compaction_test is blocked
  2018-02-09  7:53 ` lizhijian
  (?)
@ 2018-02-09 21:11   ` dan.rue
  -1 siblings, 0 replies; 15+ messages in thread
From: Dan Rue @ 2018-02-09 21:11 UTC (permalink / raw)
  To: Li Zhijian; +Cc: linux-kselftest, Li, Philip, linux-kernel, Li Zhijian(intel)

On Fri, Feb 09, 2018 at 03:53:59PM +0800, Li Zhijian wrote:
> Hi
> 
> kselftests is integrated Intel 0Day project.
> Sometimes we found compaction_test is blocked for more than 1 hours until i kill it.
> 
> Try to figure out where it is running, i added some log to this case.
> 
> the test log is like:
> -------------------
>  [  111.750543] main: 248
>  [  111.750544]-
>  [ 111.750821] check_compaction: 98
>  [  111.750822]-
>  [  111.751102] check_compaction: 105
>  [  111.751103]-
>  [  111.751362] check_compaction: 111
>  [  111.751363]-
>  [  111.751621] check_compaction: 118
>  [  111.751622]-
>  [  111.751879] check_compaction: 123
>  [  111.751880]-
> -------------------
> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
> 119         lseek(fd, 0, SEEK_SET);
> 120
> 121         /* Request a large number of huge pages. The Kernel will allocate
> 122            as much as it can */
> 123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         <<<======== the last line we can catch.
> 124         if (write(fd, "100000", (6*sizeof(char))) != (6*sizeof(char))) {        <<<<============ blocking position
> 125                 perror("Failed to write 100000 to /proc/sys/vm/nr_hugepages\n");
> 126                 goto close_fd;
> 127         }
> 128
> 129         lseek(fd, 0, SEEK_SET);
> 130
> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
> 133                 perror("Failed to re-read from /proc/sys/vm/nr_hugepages\n");
> 134                 goto close_fd;
> 135         }
> -------------------
> 
> According to above log and code, it most likely it is blocking at the writing operation.
> 
> my environment is like:
> OS: debian
> kernel: v4.15
> model: Ivytown Ivy Bridge-EP
> nr_cpu: 48
> memory: 64G

Hi Zhijian,

Please try this patch in mainline:

    4c1baad22390 kselftest: fix OOM in memory compaction test

Dan

> 
> 
> NOTE: 0Day can reproduce this issue in 20% on 0Day.
> 
> Anybody can help have a look?
> 
> Thanks
> Zhjian
> 
> 
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 15+ messages in thread

* [Linux-kselftest-mirror] [kselftests] compaction_test is blocked
@ 2018-02-09 21:11   ` dan.rue
  0 siblings, 0 replies; 15+ messages in thread
From: dan.rue @ 2018-02-09 21:11 UTC (permalink / raw)


On Fri, Feb 09, 2018 at 03:53:59PM +0800, Li Zhijian wrote:
> Hi
> 
> kselftests is integrated Intel 0Day project.
> Sometimes we found compaction_test is blocked for more than 1 hours until i kill it.
> 
> Try to figure out where it is running, i added some log to this case.
> 
> the test log is like:
> -------------------
>  [  111.750543] main: 248
>  [  111.750544]-
>  [ 111.750821] check_compaction: 98
>  [  111.750822]-
>  [  111.751102] check_compaction: 105
>  [  111.751103]-
>  [  111.751362] check_compaction: 111
>  [  111.751363]-
>  [  111.751621] check_compaction: 118
>  [  111.751622]-
>  [  111.751879] check_compaction: 123
>  [  111.751880]-
> -------------------
> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
> 119         lseek(fd, 0, SEEK_SET);
> 120
> 121         /* Request a large number of huge pages. The Kernel will allocate
> 122            as much as it can */
> 123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         <<<======== the last line we can catch.
> 124         if (write(fd, "100000", (6*sizeof(char))) != (6*sizeof(char))) {        <<<<============ blocking position
> 125                 perror("Failed to write 100000 to /proc/sys/vm/nr_hugepages\n");
> 126                 goto close_fd;
> 127         }
> 128
> 129         lseek(fd, 0, SEEK_SET);
> 130
> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
> 133                 perror("Failed to re-read from /proc/sys/vm/nr_hugepages\n");
> 134                 goto close_fd;
> 135         }
> -------------------
> 
> According to above log and code, it most likely it is blocking at the writing operation.
> 
> my environment is like:
> OS: debian
> kernel: v4.15
> model: Ivytown Ivy Bridge-EP
> nr_cpu: 48
> memory: 64G

Hi Zhijian,

Please try this patch in mainline:

    4c1baad22390 kselftest: fix OOM in memory compaction test

Dan

> 
> 
> NOTE: 0Day can reproduce this issue in 20% on 0Day.
> 
> Anybody can help have a look?
> 
> Thanks
> Zhjian
> 
> 
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
> the body of a message to majordomo at vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 15+ messages in thread

* [Linux-kselftest-mirror] [kselftests] compaction_test is blocked
@ 2018-02-09 21:11   ` dan.rue
  0 siblings, 0 replies; 15+ messages in thread
From: Dan Rue @ 2018-02-09 21:11 UTC (permalink / raw)


On Fri, Feb 09, 2018@03:53:59PM +0800, Li Zhijian wrote:
> Hi
> 
> kselftests is integrated Intel 0Day project.
> Sometimes we found compaction_test is blocked for more than 1 hours until i kill it.
> 
> Try to figure out where it is running, i added some log to this case.
> 
> the test log is like:
> -------------------
>  [  111.750543] main: 248
>  [  111.750544]-
>  [ 111.750821] check_compaction: 98
>  [  111.750822]-
>  [  111.751102] check_compaction: 105
>  [  111.751103]-
>  [  111.751362] check_compaction: 111
>  [  111.751363]-
>  [  111.751621] check_compaction: 118
>  [  111.751622]-
>  [  111.751879] check_compaction: 123
>  [  111.751880]-
> -------------------
> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
> 119         lseek(fd, 0, SEEK_SET);
> 120
> 121         /* Request a large number of huge pages. The Kernel will allocate
> 122            as much as it can */
> 123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         <<<======== the last line we can catch.
> 124         if (write(fd, "100000", (6*sizeof(char))) != (6*sizeof(char))) {        <<<<============ blocking position
> 125                 perror("Failed to write 100000 to /proc/sys/vm/nr_hugepages\n");
> 126                 goto close_fd;
> 127         }
> 128
> 129         lseek(fd, 0, SEEK_SET);
> 130
> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
> 133                 perror("Failed to re-read from /proc/sys/vm/nr_hugepages\n");
> 134                 goto close_fd;
> 135         }
> -------------------
> 
> According to above log and code, it most likely it is blocking at the writing operation.
> 
> my environment is like:
> OS: debian
> kernel: v4.15
> model: Ivytown Ivy Bridge-EP
> nr_cpu: 48
> memory: 64G

Hi Zhijian,

Please try this patch in mainline:

    4c1baad22390 kselftest: fix OOM in memory compaction test

Dan

> 
> 
> NOTE: 0Day can reproduce this issue in 20% on 0Day.
> 
> Anybody can help have a look?
> 
> Thanks
> Zhjian
> 
> 
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
> the body of a message to majordomo at vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 15+ messages in thread

* Re: [kselftests] compaction_test is blocked
  2018-02-09 21:11   ` dan.rue
  (?)
@ 2018-02-11  5:44     ` lizhijian
  -1 siblings, 0 replies; 15+ messages in thread
From: Li Zhijian @ 2018-02-11  5:44 UTC (permalink / raw)
  To: Dan Rue; +Cc: linux-kselftest, Li, Philip, linux-kernel, Li Zhijian(intel)



On 02/10/2018 05:11 AM, Dan Rue wrote:
> On Fri, Feb 09, 2018 at 03:53:59PM +0800, Li Zhijian wrote:
>> Hi
>>
>> kselftests is integrated Intel 0Day project.
>> Sometimes we found compaction_test is blocked for more than 1 hours until i kill it.
>>
>> Try to figure out where it is running, i added some log to this case.
>>
>> the test log is like:
>> -------------------
>>   [  111.750543] main: 248
>>   [  111.750544]-
>>   [ 111.750821] check_compaction: 98
>>   [  111.750822]-
>>   [  111.751102] check_compaction: 105
>>   [  111.751103]-
>>   [  111.751362] check_compaction: 111
>>   [  111.751363]-
>>   [  111.751621] check_compaction: 118
>>   [  111.751622]-
>>   [  111.751879] check_compaction: 123
>>   [  111.751880]-
>> -------------------
>> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>> 119         lseek(fd, 0, SEEK_SET);
>> 120
>> 121         /* Request a large number of huge pages. The Kernel will allocate
>> 122            as much as it can */
>> 123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         <<<======== the last line we can catch.
>> 124         if (write(fd, "100000", (6*sizeof(char))) != (6*sizeof(char))) {        <<<<============ blocking position
>> 125                 perror("Failed to write 100000 to /proc/sys/vm/nr_hugepages\n");
>> 126                 goto close_fd;
>> 127         }
>> 128
>> 129         lseek(fd, 0, SEEK_SET);
>> 130
>> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
>> 133                 perror("Failed to re-read from /proc/sys/vm/nr_hugepages\n");
>> 134                 goto close_fd;
>> 135         }
>> -------------------
>>
>> According to above log and code, it most likely it is blocking at the writing operation.
>>
>> my environment is like:
>> OS: debian
>> kernel: v4.15
>> model: Ivytown Ivy Bridge-EP
>> nr_cpu: 48
>> memory: 64G
> Hi Zhijian,
>
> Please try this patch in mainline:
>
>      4c1baad22390 kselftest: fix OOM in memory compaction test

Hi Dan

Thanks for your replies.

I run this case on v4.15, looks this patch is already merged to v4.15.
lizhijian@inn:~/linux$ git describe 4c1baad
v4.15-rc2-2-g4c1baad223906

Thanks

> Dan
>
>>
>> NOTE: 0Day can reproduce this issue in 20% on 0Day.
>>
>> Anybody can help have a look?
>>
>> Thanks
>> Zhjian
>>
>>
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
>> the body of a message to majordomo@vger.kernel.org
>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>
> .
>

-- 
Best regards.
Li Zhijian (8528)




^ permalink raw reply	[flat|nested] 15+ messages in thread

* [Linux-kselftest-mirror] [kselftests] compaction_test is blocked
@ 2018-02-11  5:44     ` lizhijian
  0 siblings, 0 replies; 15+ messages in thread
From: lizhijian @ 2018-02-11  5:44 UTC (permalink / raw)




On 02/10/2018 05:11 AM, Dan Rue wrote:
> On Fri, Feb 09, 2018 at 03:53:59PM +0800, Li Zhijian wrote:
>> Hi
>>
>> kselftests is integrated Intel 0Day project.
>> Sometimes we found compaction_test is blocked for more than 1 hours until i kill it.
>>
>> Try to figure out where it is running, i added some log to this case.
>>
>> the test log is like:
>> -------------------
>>   [  111.750543] main: 248
>>   [  111.750544]-
>>   [ 111.750821] check_compaction: 98
>>   [  111.750822]-
>>   [  111.751102] check_compaction: 105
>>   [  111.751103]-
>>   [  111.751362] check_compaction: 111
>>   [  111.751363]-
>>   [  111.751621] check_compaction: 118
>>   [  111.751622]-
>>   [  111.751879] check_compaction: 123
>>   [  111.751880]-
>> -------------------
>> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>> 119         lseek(fd, 0, SEEK_SET);
>> 120
>> 121         /* Request a large number of huge pages. The Kernel will allocate
>> 122            as much as it can */
>> 123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         <<<======== the last line we can catch.
>> 124         if (write(fd, "100000", (6*sizeof(char))) != (6*sizeof(char))) {        <<<<============ blocking position
>> 125                 perror("Failed to write 100000 to /proc/sys/vm/nr_hugepages\n");
>> 126                 goto close_fd;
>> 127         }
>> 128
>> 129         lseek(fd, 0, SEEK_SET);
>> 130
>> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
>> 133                 perror("Failed to re-read from /proc/sys/vm/nr_hugepages\n");
>> 134                 goto close_fd;
>> 135         }
>> -------------------
>>
>> According to above log and code, it most likely it is blocking at the writing operation.
>>
>> my environment is like:
>> OS: debian
>> kernel: v4.15
>> model: Ivytown Ivy Bridge-EP
>> nr_cpu: 48
>> memory: 64G
> Hi Zhijian,
>
> Please try this patch in mainline:
>
>      4c1baad22390 kselftest: fix OOM in memory compaction test

Hi Dan

Thanks for your replies.

I run this case on v4.15, looks this patch is already merged to v4.15.
lizhijian at inn:~/linux$ git describe 4c1baad
v4.15-rc2-2-g4c1baad223906

Thanks

> Dan
>
>>
>> NOTE: 0Day can reproduce this issue in 20% on 0Day.
>>
>> Anybody can help have a look?
>>
>> Thanks
>> Zhjian
>>
>>
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
>> the body of a message to majordomo at vger.kernel.org
>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>
> .
>

-- 
Best regards.
Li Zhijian (8528)



--
To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 15+ messages in thread

* [Linux-kselftest-mirror] [kselftests] compaction_test is blocked
@ 2018-02-11  5:44     ` lizhijian
  0 siblings, 0 replies; 15+ messages in thread
From: Li Zhijian @ 2018-02-11  5:44 UTC (permalink / raw)




On 02/10/2018 05:11 AM, Dan Rue wrote:
> On Fri, Feb 09, 2018@03:53:59PM +0800, Li Zhijian wrote:
>> Hi
>>
>> kselftests is integrated Intel 0Day project.
>> Sometimes we found compaction_test is blocked for more than 1 hours until i kill it.
>>
>> Try to figure out where it is running, i added some log to this case.
>>
>> the test log is like:
>> -------------------
>>   [  111.750543] main: 248
>>   [  111.750544]-
>>   [ 111.750821] check_compaction: 98
>>   [  111.750822]-
>>   [  111.751102] check_compaction: 105
>>   [  111.751103]-
>>   [  111.751362] check_compaction: 111
>>   [  111.751363]-
>>   [  111.751621] check_compaction: 118
>>   [  111.751622]-
>>   [  111.751879] check_compaction: 123
>>   [  111.751880]-
>> -------------------
>> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>> 119         lseek(fd, 0, SEEK_SET);
>> 120
>> 121         /* Request a large number of huge pages. The Kernel will allocate
>> 122            as much as it can */
>> 123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         <<<======== the last line we can catch.
>> 124         if (write(fd, "100000", (6*sizeof(char))) != (6*sizeof(char))) {        <<<<============ blocking position
>> 125                 perror("Failed to write 100000 to /proc/sys/vm/nr_hugepages\n");
>> 126                 goto close_fd;
>> 127         }
>> 128
>> 129         lseek(fd, 0, SEEK_SET);
>> 130
>> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
>> 133                 perror("Failed to re-read from /proc/sys/vm/nr_hugepages\n");
>> 134                 goto close_fd;
>> 135         }
>> -------------------
>>
>> According to above log and code, it most likely it is blocking at the writing operation.
>>
>> my environment is like:
>> OS: debian
>> kernel: v4.15
>> model: Ivytown Ivy Bridge-EP
>> nr_cpu: 48
>> memory: 64G
> Hi Zhijian,
>
> Please try this patch in mainline:
>
>      4c1baad22390 kselftest: fix OOM in memory compaction test

Hi Dan

Thanks for your replies.

I run this case on v4.15, looks this patch is already merged to v4.15.
lizhijian at inn:~/linux$ git describe 4c1baad
v4.15-rc2-2-g4c1baad223906

Thanks

> Dan
>
>>
>> NOTE: 0Day can reproduce this issue in 20% on 0Day.
>>
>> Anybody can help have a look?
>>
>> Thanks
>> Zhjian
>>
>>
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
>> the body of a message to majordomo at vger.kernel.org
>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>
> .
>

-- 
Best regards.
Li Zhijian (8528)



--
To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 15+ messages in thread

* Re: [kselftests] compaction_test is blocked
  2018-02-11  5:44     ` lizhijian
  (?)
@ 2018-02-12  3:26       ` zhijianx.li
  -1 siblings, 0 replies; 15+ messages in thread
From: Li Zhijian @ 2018-02-12  3:26 UTC (permalink / raw)
  To: Li Zhijian, Dan Rue; +Cc: linux-kselftest, Li, Philip, linux-kernel



On 2018年02月11日 13:44, Li Zhijian wrote:
>
>
> On 02/10/2018 05:11 AM, Dan Rue wrote:
>> On Fri, Feb 09, 2018 at 03:53:59PM +0800, Li Zhijian wrote:
>>> Hi
>>>
>>> kselftests is integrated Intel 0Day project.
>>> Sometimes we found compaction_test is blocked for more than 1 hours 
>>> until i kill it.
>>>
>>> Try to figure out where it is running, i added some log to this case.
>>>
>>> the test log is like:
>>> -------------------
>>>   [  111.750543] main: 248
>>>   [  111.750544]-
>>>   [ 111.750821] check_compaction: 98
>>>   [  111.750822]-
>>>   [  111.751102] check_compaction: 105
>>>   [  111.751103]-
>>>   [  111.751362] check_compaction: 111
>>>   [  111.751363]-
>>>   [  111.751621] check_compaction: 118
>>>   [  111.751622]-
>>>   [  111.751879] check_compaction: 123
>>>   [  111.751880]-
>>> -------------------
>>> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>> 119         lseek(fd, 0, SEEK_SET);
>>> 120
>>> 121         /* Request a large number of huge pages. The Kernel will 
>>> allocate
>>> 122            as much as it can */
>>> 123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         
>>> <<<======== the last line we can catch.
>>> 124         if (write(fd, "100000", (6*sizeof(char))) != 
>>> (6*sizeof(char))) {        <<<<============ blocking position
>>> 125                 perror("Failed to write 100000 to 
>>> /proc/sys/vm/nr_hugepages\n");
>>> 126                 goto close_fd;
>>> 127         }
>>> 128
>>> 129         lseek(fd, 0, SEEK_SET);
>>> 130
>>> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
>>> 133                 perror("Failed to re-read from 
>>> /proc/sys/vm/nr_hugepages\n");
>>> 134                 goto close_fd;
>>> 135         }
>>> -------------------
>>>
>>> According to above log and code, it most likely it is blocking at 
>>> the writing operation.
>>>
>>> my environment is like:
>>> OS: debian
>>> kernel: v4.15
>>> model: Ivytown Ivy Bridge-EP
>>> nr_cpu: 48
>>> memory: 64G
>> Hi Zhijian,
>>
>> Please try this patch in mainline:
>>
>>      4c1baad22390 kselftest: fix OOM in memory compaction test
>
> Hi Dan
>
> Thanks for your replies.
>
> I run this case on v4.15, looks this patch is already merged to v4.15.
> lizhijian@inn:~/linux$ git describe 4c1baad
> v4.15-rc2-2-g4c1baad223906

My mistake, this path is not contained by v4.15 yet.
i will have a try.

Thanks



>
> Thanks
>
>> Dan
>>
>>>
>>> NOTE: 0Day can reproduce this issue in 20% on 0Day.
>>>
>>> Anybody can help have a look?
>>>
>>> Thanks
>>> Zhjian
>>>
>>>
>>>
>>> -- 
>>> To unsubscribe from this list: send the line "unsubscribe 
>>> linux-kselftest" in
>>> the body of a message to majordomo@vger.kernel.org
>>> More majordomo info at http://vger.kernel.org/majordomo-info.html
>>
>> .
>>
>


^ permalink raw reply	[flat|nested] 15+ messages in thread

* [Linux-kselftest-mirror] [kselftests] compaction_test is blocked
@ 2018-02-12  3:26       ` zhijianx.li
  0 siblings, 0 replies; 15+ messages in thread
From: zhijianx.li @ 2018-02-12  3:26 UTC (permalink / raw)


[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #1: Type: text/plain, Size: 3273 bytes --]



On 2018年02月11日 13:44, Li Zhijian wrote:
>
>
> On 02/10/2018 05:11 AM, Dan Rue wrote:
>> On Fri, Feb 09, 2018 at 03:53:59PM +0800, Li Zhijian wrote:
>>> Hi
>>>
>>> kselftests is integrated Intel 0Day project.
>>> Sometimes we found compaction_test is blocked for more than 1 hours 
>>> until i kill it.
>>>
>>> Try to figure out where it is running, i added some log to this case.
>>>
>>> the test log is like:
>>> -------------------
>>>   [  111.750543] main: 248
>>>   [  111.750544]-
>>>   [ 111.750821] check_compaction: 98
>>>   [  111.750822]-
>>>   [  111.751102] check_compaction: 105
>>>   [  111.751103]-
>>>   [  111.751362] check_compaction: 111
>>>   [  111.751363]-
>>>   [  111.751621] check_compaction: 118
>>>   [  111.751622]-
>>>   [  111.751879] check_compaction: 123
>>>   [  111.751880]-
>>> -------------------
>>> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>> 119         lseek(fd, 0, SEEK_SET);
>>> 120
>>> 121         /* Request a large number of huge pages. The Kernel will 
>>> allocate
>>> 122            as much as it can */
>>> 123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         
>>> <<<======== the last line we can catch.
>>> 124         if (write(fd, "100000", (6*sizeof(char))) != 
>>> (6*sizeof(char))) {        <<<<============ blocking position
>>> 125                 perror("Failed to write 100000 to 
>>> /proc/sys/vm/nr_hugepages\n");
>>> 126                 goto close_fd;
>>> 127         }
>>> 128
>>> 129         lseek(fd, 0, SEEK_SET);
>>> 130
>>> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
>>> 133                 perror("Failed to re-read from 
>>> /proc/sys/vm/nr_hugepages\n");
>>> 134                 goto close_fd;
>>> 135         }
>>> -------------------
>>>
>>> According to above log and code, it most likely it is blocking at 
>>> the writing operation.
>>>
>>> my environment is like:
>>> OS: debian
>>> kernel: v4.15
>>> model: Ivytown Ivy Bridge-EP
>>> nr_cpu: 48
>>> memory: 64G
>> Hi Zhijian,
>>
>> Please try this patch in mainline:
>>
>>      4c1baad22390 kselftest: fix OOM in memory compaction test
>
> Hi Dan
>
> Thanks for your replies.
>
> I run this case on v4.15, looks this patch is already merged to v4.15.
> lizhijian at inn:~/linux$ git describe 4c1baad
> v4.15-rc2-2-g4c1baad223906

My mistake, this path is not contained by v4.15 yet.
i will have a try.

Thanks



>
> Thanks
>
>> Dan
>>
>>>
>>> NOTE: 0Day can reproduce this issue in 20% on 0Day.
>>>
>>> Anybody can help have a look?
>>>
>>> Thanks
>>> Zhjian
>>>
>>>
>>>
>>> -- 
>>> To unsubscribe from this list: send the line "unsubscribe 
>>> linux-kselftest" in
>>> the body of a message to majordomo at vger.kernel.org
>>> More majordomo info at http://vger.kernel.org/majordomo-info.html
>>
>> .
>>
>

--
To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 15+ messages in thread

* [Linux-kselftest-mirror] [kselftests] compaction_test is blocked
@ 2018-02-12  3:26       ` zhijianx.li
  0 siblings, 0 replies; 15+ messages in thread
From: Li Zhijian @ 2018-02-12  3:26 UTC (permalink / raw)




On 2018年02月11日 13:44, Li Zhijian wrote:
>
>
> On 02/10/2018 05:11 AM, Dan Rue wrote:
>> On Fri, Feb 09, 2018@03:53:59PM +0800, Li Zhijian wrote:
>>> Hi
>>>
>>> kselftests is integrated Intel 0Day project.
>>> Sometimes we found compaction_test is blocked for more than 1 hours 
>>> until i kill it.
>>>
>>> Try to figure out where it is running, i added some log to this case.
>>>
>>> the test log is like:
>>> -------------------
>>>   [  111.750543] main: 248
>>>   [  111.750544]-
>>>   [ 111.750821] check_compaction: 98
>>>   [  111.750822]-
>>>   [  111.751102] check_compaction: 105
>>>   [  111.751103]-
>>>   [  111.751362] check_compaction: 111
>>>   [  111.751363]-
>>>   [  111.751621] check_compaction: 118
>>>   [  111.751622]-
>>>   [  111.751879] check_compaction: 123
>>>   [  111.751880]-
>>> -------------------
>>> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>> 119         lseek(fd, 0, SEEK_SET);
>>> 120
>>> 121         /* Request a large number of huge pages. The Kernel will 
>>> allocate
>>> 122            as much as it can */
>>> 123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);         
>>> <<<======== the last line we can catch.
>>> 124         if (write(fd, "100000", (6*sizeof(char))) != 
>>> (6*sizeof(char))) {        <<<<============ blocking position
>>> 125                 perror("Failed to write 100000 to 
>>> /proc/sys/vm/nr_hugepages\n");
>>> 126                 goto close_fd;
>>> 127         }
>>> 128
>>> 129         lseek(fd, 0, SEEK_SET);
>>> 130
>>> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
>>> 133                 perror("Failed to re-read from 
>>> /proc/sys/vm/nr_hugepages\n");
>>> 134                 goto close_fd;
>>> 135         }
>>> -------------------
>>>
>>> According to above log and code, it most likely it is blocking at 
>>> the writing operation.
>>>
>>> my environment is like:
>>> OS: debian
>>> kernel: v4.15
>>> model: Ivytown Ivy Bridge-EP
>>> nr_cpu: 48
>>> memory: 64G
>> Hi Zhijian,
>>
>> Please try this patch in mainline:
>>
>>      4c1baad22390 kselftest: fix OOM in memory compaction test
>
> Hi Dan
>
> Thanks for your replies.
>
> I run this case on v4.15, looks this patch is already merged to v4.15.
> lizhijian at inn:~/linux$ git describe 4c1baad
> v4.15-rc2-2-g4c1baad223906

My mistake, this path is not contained by v4.15 yet.
i will have a try.

Thanks



>
> Thanks
>
>> Dan
>>
>>>
>>> NOTE: 0Day can reproduce this issue in 20% on 0Day.
>>>
>>> Anybody can help have a look?
>>>
>>> Thanks
>>> Zhjian
>>>
>>>
>>>
>>> -- 
>>> To unsubscribe from this list: send the line "unsubscribe 
>>> linux-kselftest" in
>>> the body of a message to majordomo at vger.kernel.org
>>> More majordomo info at http://vger.kernel.org/majordomo-info.html
>>
>> .
>>
>

--
To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 15+ messages in thread

* Re: [kselftests] compaction_test is blocked
  2018-02-12  3:26       ` zhijianx.li
  (?)
@ 2018-02-12  9:58         ` zhijianx.li
  -1 siblings, 0 replies; 15+ messages in thread
From: Li Zhijian @ 2018-02-12  9:58 UTC (permalink / raw)
  To: Li Zhijian, Dan Rue; +Cc: linux-kselftest, Li, Philip, linux-kernel



On 2018年02月12日 11:26, Li Zhijian wrote:
>
>
> On 2018年02月11日 13:44, Li Zhijian wrote:
>>
>>
>> On 02/10/2018 05:11 AM, Dan Rue wrote:
>>> On Fri, Feb 09, 2018 at 03:53:59PM +0800, Li Zhijian wrote:
>>>> Hi
>>>>
>>>> kselftests is integrated Intel 0Day project.
>>>> Sometimes we found compaction_test is blocked for more than 1 hours 
>>>> until i kill it.
>>>>
>>>> Try to figure out where it is running, i added some log to this case.
>>>>
>>>> the test log is like:
>>>> -------------------
>>>>   [  111.750543] main: 248
>>>>   [  111.750544]-
>>>>   [ 111.750821] check_compaction: 98
>>>>   [  111.750822]-
>>>>   [  111.751102] check_compaction: 105
>>>>   [  111.751103]-
>>>>   [  111.751362] check_compaction: 111
>>>>   [  111.751363]-
>>>>   [  111.751621] check_compaction: 118
>>>>   [  111.751622]-
>>>>   [  111.751879] check_compaction: 123
>>>>   [  111.751880]-
>>>> -------------------
>>>> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>>> 119         lseek(fd, 0, SEEK_SET);
>>>> 120
>>>> 121         /* Request a large number of huge pages. The Kernel 
>>>> will allocate
>>>> 122            as much as it can */
>>>> 123         fprintf(stderr, "%s: %d\n", __func__, 
>>>> __LINE__);         <<<======== the last line we can catch.
>>>> 124         if (write(fd, "100000", (6*sizeof(char))) != 
>>>> (6*sizeof(char))) {        <<<<============ blocking position
>>>> 125                 perror("Failed to write 100000 to 
>>>> /proc/sys/vm/nr_hugepages\n");
>>>> 126                 goto close_fd;
>>>> 127         }
>>>> 128
>>>> 129         lseek(fd, 0, SEEK_SET);
>>>> 130
>>>> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>>> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
>>>> 133                 perror("Failed to re-read from 
>>>> /proc/sys/vm/nr_hugepages\n");
>>>> 134                 goto close_fd;
>>>> 135         }
>>>> -------------------
>>>>
>>>> According to above log and code, it most likely it is blocking at 
>>>> the writing operation.
>>>>
>>>> my environment is like:
>>>> OS: debian
>>>> kernel: v4.15
>>>> model: Ivytown Ivy Bridge-EP
>>>> nr_cpu: 48
>>>> memory: 64G
>>> Hi Zhijian,
>>>
>>> Please try this patch in mainline:
>>>
>>>      4c1baad22390 kselftest: fix OOM in memory compaction test
>>
>> Hi Dan
>>
>> Thanks for your replies.
>>
>> I run this case on v4.15, looks this patch is already merged to v4.15.
>> lizhijian@inn:~/linux$ git describe 4c1baad
>> v4.15-rc2-2-g4c1baad223906
>
> My mistake, this path is not contained by v4.15 yet.
> i will have a try.
Hi Dan,

I ran this case on this commit 4c1baad22390, this issue still occurs.

root@ivb44 ~# dmesg | tail -n 30
[  105.825870] main: 247

[  105.825994] main: 242

[  105.826130] main: 247

[  105.826250] main: 242

[  105.826394] main: 247

[  105.826506] main: 242

[  105.826617] main: 247

[  105.826728] main: 242

[  105.826840] main: 247

[  105.826950] main: 250

[  105.827272] check_compaction: 98

[  105.827589] check_compaction: 105

[  105.827849] check_compaction: 111

[  105.828152] check_compaction: 118

[  105.828451] check_compaction: 123


the runtime code is like
-------------------
110
111         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
112         /* Start with the initial condition of 0 huge pages*/
113         if (write(fd, "0", sizeof(char)) != sizeof(char)) {
114                 perror("Failed to write 0 to 
/proc/sys/vm/nr_hugepages\n");
115                 goto close_fd;
116 }
117
118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
119         lseek(fd, 0, SEEK_SET);
120
121         /* Request a large number of huge pages. The Kernel will 
allocate
122            as much as it can */
123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
124         if (write(fd, "100000", (6*sizeof(char))) != 
(6*sizeof(char))) {
125                 perror("Failed to write 100000 to 
/proc/sys/vm/nr_hugepages\n");
126                 goto close_fd;
127         }
-------------------

Thanks
>
> Thanks
>
>
>
>>
>> Thanks
>>
>>> Dan
>>>
>>>>
>>>> NOTE: 0Day can reproduce this issue in 20% on 0Day.
>>>>
>>>> Anybody can help have a look?
>>>>
>>>> Thanks
>>>> Zhjian
>>>>
>>>>
>>>>
>>>> -- 
>>>> To unsubscribe from this list: send the line "unsubscribe 
>>>> linux-kselftest" in
>>>> the body of a message to majordomo@vger.kernel.org
>>>> More majordomo info at http://vger.kernel.org/majordomo-info.html
>>>
>>> .
>>>
>>
>


^ permalink raw reply	[flat|nested] 15+ messages in thread

* [Linux-kselftest-mirror] [kselftests] compaction_test is blocked
@ 2018-02-12  9:58         ` zhijianx.li
  0 siblings, 0 replies; 15+ messages in thread
From: zhijianx.li @ 2018-02-12  9:58 UTC (permalink / raw)


[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #1: Type: text/plain, Size: 5048 bytes --]



On 2018年02月12日 11:26, Li Zhijian wrote:
>
>
> On 2018年02月11日 13:44, Li Zhijian wrote:
>>
>>
>> On 02/10/2018 05:11 AM, Dan Rue wrote:
>>> On Fri, Feb 09, 2018 at 03:53:59PM +0800, Li Zhijian wrote:
>>>> Hi
>>>>
>>>> kselftests is integrated Intel 0Day project.
>>>> Sometimes we found compaction_test is blocked for more than 1 hours 
>>>> until i kill it.
>>>>
>>>> Try to figure out where it is running, i added some log to this case.
>>>>
>>>> the test log is like:
>>>> -------------------
>>>>   [  111.750543] main: 248
>>>>   [  111.750544]-
>>>>   [ 111.750821] check_compaction: 98
>>>>   [  111.750822]-
>>>>   [  111.751102] check_compaction: 105
>>>>   [  111.751103]-
>>>>   [  111.751362] check_compaction: 111
>>>>   [  111.751363]-
>>>>   [  111.751621] check_compaction: 118
>>>>   [  111.751622]-
>>>>   [  111.751879] check_compaction: 123
>>>>   [  111.751880]-
>>>> -------------------
>>>> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>>> 119         lseek(fd, 0, SEEK_SET);
>>>> 120
>>>> 121         /* Request a large number of huge pages. The Kernel 
>>>> will allocate
>>>> 122            as much as it can */
>>>> 123         fprintf(stderr, "%s: %d\n", __func__, 
>>>> __LINE__);         <<<======== the last line we can catch.
>>>> 124         if (write(fd, "100000", (6*sizeof(char))) != 
>>>> (6*sizeof(char))) {        <<<<============ blocking position
>>>> 125                 perror("Failed to write 100000 to 
>>>> /proc/sys/vm/nr_hugepages\n");
>>>> 126                 goto close_fd;
>>>> 127         }
>>>> 128
>>>> 129         lseek(fd, 0, SEEK_SET);
>>>> 130
>>>> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>>> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
>>>> 133                 perror("Failed to re-read from 
>>>> /proc/sys/vm/nr_hugepages\n");
>>>> 134                 goto close_fd;
>>>> 135         }
>>>> -------------------
>>>>
>>>> According to above log and code, it most likely it is blocking at 
>>>> the writing operation.
>>>>
>>>> my environment is like:
>>>> OS: debian
>>>> kernel: v4.15
>>>> model: Ivytown Ivy Bridge-EP
>>>> nr_cpu: 48
>>>> memory: 64G
>>> Hi Zhijian,
>>>
>>> Please try this patch in mainline:
>>>
>>>      4c1baad22390 kselftest: fix OOM in memory compaction test
>>
>> Hi Dan
>>
>> Thanks for your replies.
>>
>> I run this case on v4.15, looks this patch is already merged to v4.15.
>> lizhijian at inn:~/linux$ git describe 4c1baad
>> v4.15-rc2-2-g4c1baad223906
>
> My mistake, this path is not contained by v4.15 yet.
> i will have a try.
Hi Dan,

I ran this case on this commit 4c1baad22390, this issue still occurs.

root at ivb44 ~# dmesg | tail -n 30
[  105.825870] main: 247

[  105.825994] main: 242

[  105.826130] main: 247

[  105.826250] main: 242

[  105.826394] main: 247

[  105.826506] main: 242

[  105.826617] main: 247

[  105.826728] main: 242

[  105.826840] main: 247

[  105.826950] main: 250

[  105.827272] check_compaction: 98

[  105.827589] check_compaction: 105

[  105.827849] check_compaction: 111

[  105.828152] check_compaction: 118

[  105.828451] check_compaction: 123


the runtime code is like
-------------------
110
111         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
112         /* Start with the initial condition of 0 huge pages*/
113         if (write(fd, "0", sizeof(char)) != sizeof(char)) {
114                 perror("Failed to write 0 to 
/proc/sys/vm/nr_hugepages\n");
115                 goto close_fd;
116 }
117
118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
119         lseek(fd, 0, SEEK_SET);
120
121         /* Request a large number of huge pages. The Kernel will 
allocate
122            as much as it can */
123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
124         if (write(fd, "100000", (6*sizeof(char))) != 
(6*sizeof(char))) {
125                 perror("Failed to write 100000 to 
/proc/sys/vm/nr_hugepages\n");
126                 goto close_fd;
127         }
-------------------

Thanks
>
> Thanks
>
>
>
>>
>> Thanks
>>
>>> Dan
>>>
>>>>
>>>> NOTE: 0Day can reproduce this issue in 20% on 0Day.
>>>>
>>>> Anybody can help have a look?
>>>>
>>>> Thanks
>>>> Zhjian
>>>>
>>>>
>>>>
>>>> -- 
>>>> To unsubscribe from this list: send the line "unsubscribe 
>>>> linux-kselftest" in
>>>> the body of a message to majordomo at vger.kernel.org
>>>> More majordomo info at http://vger.kernel.org/majordomo-info.html
>>>
>>> .
>>>
>>
>

--
To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 15+ messages in thread

* [Linux-kselftest-mirror] [kselftests] compaction_test is blocked
@ 2018-02-12  9:58         ` zhijianx.li
  0 siblings, 0 replies; 15+ messages in thread
From: Li Zhijian @ 2018-02-12  9:58 UTC (permalink / raw)




On 2018年02月12日 11:26, Li Zhijian wrote:
>
>
> On 2018年02月11日 13:44, Li Zhijian wrote:
>>
>>
>> On 02/10/2018 05:11 AM, Dan Rue wrote:
>>> On Fri, Feb 09, 2018@03:53:59PM +0800, Li Zhijian wrote:
>>>> Hi
>>>>
>>>> kselftests is integrated Intel 0Day project.
>>>> Sometimes we found compaction_test is blocked for more than 1 hours 
>>>> until i kill it.
>>>>
>>>> Try to figure out where it is running, i added some log to this case.
>>>>
>>>> the test log is like:
>>>> -------------------
>>>>   [  111.750543] main: 248
>>>>   [  111.750544]-
>>>>   [ 111.750821] check_compaction: 98
>>>>   [  111.750822]-
>>>>   [  111.751102] check_compaction: 105
>>>>   [  111.751103]-
>>>>   [  111.751362] check_compaction: 111
>>>>   [  111.751363]-
>>>>   [  111.751621] check_compaction: 118
>>>>   [  111.751622]-
>>>>   [  111.751879] check_compaction: 123
>>>>   [  111.751880]-
>>>> -------------------
>>>> 118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>>> 119         lseek(fd, 0, SEEK_SET);
>>>> 120
>>>> 121         /* Request a large number of huge pages. The Kernel 
>>>> will allocate
>>>> 122            as much as it can */
>>>> 123         fprintf(stderr, "%s: %d\n", __func__, 
>>>> __LINE__);         <<<======== the last line we can catch.
>>>> 124         if (write(fd, "100000", (6*sizeof(char))) != 
>>>> (6*sizeof(char))) {        <<<<============ blocking position
>>>> 125                 perror("Failed to write 100000 to 
>>>> /proc/sys/vm/nr_hugepages\n");
>>>> 126                 goto close_fd;
>>>> 127         }
>>>> 128
>>>> 129         lseek(fd, 0, SEEK_SET);
>>>> 130
>>>> 131         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
>>>> 132         if (read(fd, nr_hugepages, sizeof(nr_hugepages)) <= 0) {
>>>> 133                 perror("Failed to re-read from 
>>>> /proc/sys/vm/nr_hugepages\n");
>>>> 134                 goto close_fd;
>>>> 135         }
>>>> -------------------
>>>>
>>>> According to above log and code, it most likely it is blocking at 
>>>> the writing operation.
>>>>
>>>> my environment is like:
>>>> OS: debian
>>>> kernel: v4.15
>>>> model: Ivytown Ivy Bridge-EP
>>>> nr_cpu: 48
>>>> memory: 64G
>>> Hi Zhijian,
>>>
>>> Please try this patch in mainline:
>>>
>>>      4c1baad22390 kselftest: fix OOM in memory compaction test
>>
>> Hi Dan
>>
>> Thanks for your replies.
>>
>> I run this case on v4.15, looks this patch is already merged to v4.15.
>> lizhijian at inn:~/linux$ git describe 4c1baad
>> v4.15-rc2-2-g4c1baad223906
>
> My mistake, this path is not contained by v4.15 yet.
> i will have a try.
Hi Dan,

I ran this case on this commit 4c1baad22390, this issue still occurs.

root at ivb44 ~# dmesg | tail -n 30
[  105.825870] main: 247

[  105.825994] main: 242

[  105.826130] main: 247

[  105.826250] main: 242

[  105.826394] main: 247

[  105.826506] main: 242

[  105.826617] main: 247

[  105.826728] main: 242

[  105.826840] main: 247

[  105.826950] main: 250

[  105.827272] check_compaction: 98

[  105.827589] check_compaction: 105

[  105.827849] check_compaction: 111

[  105.828152] check_compaction: 118

[  105.828451] check_compaction: 123


the runtime code is like
-------------------
110
111         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
112         /* Start with the initial condition of 0 huge pages*/
113         if (write(fd, "0", sizeof(char)) != sizeof(char)) {
114                 perror("Failed to write 0 to 
/proc/sys/vm/nr_hugepages\n");
115                 goto close_fd;
116 }
117
118         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
119         lseek(fd, 0, SEEK_SET);
120
121         /* Request a large number of huge pages. The Kernel will 
allocate
122            as much as it can */
123         fprintf(stderr, "%s: %d\n", __func__, __LINE__);
124         if (write(fd, "100000", (6*sizeof(char))) != 
(6*sizeof(char))) {
125                 perror("Failed to write 100000 to 
/proc/sys/vm/nr_hugepages\n");
126                 goto close_fd;
127         }
-------------------

Thanks
>
> Thanks
>
>
>
>>
>> Thanks
>>
>>> Dan
>>>
>>>>
>>>> NOTE: 0Day can reproduce this issue in 20% on 0Day.
>>>>
>>>> Anybody can help have a look?
>>>>
>>>> Thanks
>>>> Zhjian
>>>>
>>>>
>>>>
>>>> -- 
>>>> To unsubscribe from this list: send the line "unsubscribe 
>>>> linux-kselftest" in
>>>> the body of a message to majordomo at vger.kernel.org
>>>> More majordomo info at http://vger.kernel.org/majordomo-info.html
>>>
>>> .
>>>
>>
>

--
To unsubscribe from this list: send the line "unsubscribe linux-kselftest" in
the body of a message to majordomo at vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 15+ messages in thread

end of thread, other threads:[~2018-02-12  9:58 UTC | newest]

Thread overview: 15+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2018-02-09  7:53 [kselftests] compaction_test is blocked Li Zhijian
2018-02-09  7:53 ` [Linux-kselftest-mirror] " Li Zhijian
2018-02-09  7:53 ` lizhijian
2018-02-09 21:11 ` Dan Rue
2018-02-09 21:11   ` [Linux-kselftest-mirror] " Dan Rue
2018-02-09 21:11   ` dan.rue
2018-02-11  5:44   ` Li Zhijian
2018-02-11  5:44     ` [Linux-kselftest-mirror] " Li Zhijian
2018-02-11  5:44     ` lizhijian
2018-02-12  3:26     ` Li Zhijian
2018-02-12  3:26       ` [Linux-kselftest-mirror] " Li Zhijian
2018-02-12  3:26       ` zhijianx.li
2018-02-12  9:58       ` Li Zhijian
2018-02-12  9:58         ` [Linux-kselftest-mirror] " Li Zhijian
2018-02-12  9:58         ` zhijianx.li

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.