Function report |
Source Code:kernel\sched\membarrier.c |
Create Date:2022-07-28 09:45:29 |
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
| home page | Tree |
| Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:membarrier_private_expedited
Proto:static int membarrier_private_expedited(int flags)
Type:int
Parameter:
| Type | Parameter | Name |
|---|---|---|
| int | flags |
| 138 | If flags & MEMBARRIER_FLAG_SYNC_CORE Then |
| 139 | If Not IS_ENABLED(CONFIG_FOO) evaluates to 1 if CONFIG_FOO is set to 'y' or 'm',* 0 otherwise.(CONFIG_ARCH_HAS_MEMBARRIER_SYNC_CORE) Then Return -EINVAL |
| 141 | If Not (atomic_read( & membarrier_state) & MEMBARRIER_STATE_PRIVATE_EXPEDITED_SYNC_CORE_READY) Then Return -EPERM |
| 144 | Else |
| 145 | If Not (atomic_read( & membarrier_state) & MEMBARRIER_STATE_PRIVATE_EXPEDITED_READY) Then Return -EPERM |
| 157 | smp_mb() |
| 159 | If Not zalloc_cpumask_var( & tmpmask, GFP_KERNEL) Then Return -ENOMEM |
| 162 | cpus_read_lock() |
| 164 | for_each_online_cpu(cpu) |
| 175 | If cpu == These macros fold the SMP functionality into a single CPU system() Then Continue |
| 184 | smp_call_function_many(tmpmask, ipi_mb, NULL, 1) |
| 185 | preempt_enable() |
| 187 | free_cpumask_var(tmpmask) |
| 188 | cpus_read_unlock() |
| 195 | smp_mb() |
| 197 | Return 0 |
| Name | Describe |
|---|---|
| SYSCALL_DEFINE2 | sys_membarrier - issue memory barriers on a set of threads*@cmd: Takes command values defined in enum membarrier_cmd |
| Source code conversion tool public plug-in interface | X |
|---|---|
| Support c/c++/esqlc/java Oracle/Informix/Mysql Plug-in can realize: logical Report Code generation and batch code conversion |