1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-14 14:55:41 +00:00

acquire/release Giant in vm_page_zero_idle(), like on i386

Discused with: jhb
This commit is contained in:
Andrew Gallatin 2000-12-01 18:55:58 +00:00
parent c6105ae6e5
commit 4c0b7a9327
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=69488
3 changed files with 6 additions and 24 deletions

View File

@ -425,9 +425,7 @@ vm_page_zero_idle()
if (vm_page_zero_count >= ZIDLE_HI(cnt.v_free_count)) if (vm_page_zero_count >= ZIDLE_HI(cnt.v_free_count))
return(0); return(0);
#ifdef SMP if (mtx_try_enter(&Giant, MTX_DEF)) {
if (KLOCK_ENTER(M_TRY)) {
#endif
s = splvm(); s = splvm();
m = vm_page_list_find(PQ_FREE, free_rover, FALSE); m = vm_page_list_find(PQ_FREE, free_rover, FALSE);
zero_state = 0; zero_state = 0;
@ -456,13 +454,9 @@ vm_page_zero_idle()
} }
free_rover = (free_rover + PQ_PRIME2) & PQ_L2_MASK; free_rover = (free_rover + PQ_PRIME2) & PQ_L2_MASK;
splx(s); splx(s);
#ifdef SMP mtx_exit(&Giant, MTX_DEF);
KLOCK_EXIT;
#endif
return (1); return (1);
#ifdef SMP
} }
#endif
return (0); return (0);
} }

View File

@ -425,9 +425,7 @@ vm_page_zero_idle()
if (vm_page_zero_count >= ZIDLE_HI(cnt.v_free_count)) if (vm_page_zero_count >= ZIDLE_HI(cnt.v_free_count))
return(0); return(0);
#ifdef SMP if (mtx_try_enter(&Giant, MTX_DEF)) {
if (KLOCK_ENTER(M_TRY)) {
#endif
s = splvm(); s = splvm();
m = vm_page_list_find(PQ_FREE, free_rover, FALSE); m = vm_page_list_find(PQ_FREE, free_rover, FALSE);
zero_state = 0; zero_state = 0;
@ -456,13 +454,9 @@ vm_page_zero_idle()
} }
free_rover = (free_rover + PQ_PRIME2) & PQ_L2_MASK; free_rover = (free_rover + PQ_PRIME2) & PQ_L2_MASK;
splx(s); splx(s);
#ifdef SMP mtx_exit(&Giant, MTX_DEF);
KLOCK_EXIT;
#endif
return (1); return (1);
#ifdef SMP
} }
#endif
return (0); return (0);
} }

View File

@ -425,9 +425,7 @@ vm_page_zero_idle()
if (vm_page_zero_count >= ZIDLE_HI(cnt.v_free_count)) if (vm_page_zero_count >= ZIDLE_HI(cnt.v_free_count))
return(0); return(0);
#ifdef SMP if (mtx_try_enter(&Giant, MTX_DEF)) {
if (KLOCK_ENTER(M_TRY)) {
#endif
s = splvm(); s = splvm();
m = vm_page_list_find(PQ_FREE, free_rover, FALSE); m = vm_page_list_find(PQ_FREE, free_rover, FALSE);
zero_state = 0; zero_state = 0;
@ -456,13 +454,9 @@ vm_page_zero_idle()
} }
free_rover = (free_rover + PQ_PRIME2) & PQ_L2_MASK; free_rover = (free_rover + PQ_PRIME2) & PQ_L2_MASK;
splx(s); splx(s);
#ifdef SMP mtx_exit(&Giant, MTX_DEF);
KLOCK_EXIT;
#endif
return (1); return (1);
#ifdef SMP
} }
#endif
return (0); return (0);
} }