diff options
| author | Mauro Carvalho Chehab <mchehab@osg.samsung.com> | 2015-04-21 05:33:03 -0400 |
|---|---|---|
| committer | Mauro Carvalho Chehab <mchehab@osg.samsung.com> | 2015-04-21 08:44:55 -0400 |
| commit | 64131a87f2aae2ed9e05d8227c5b009ca6c50d98 (patch) | |
| tree | fdea23fd59216120bf54a48c60ca24489a733f14 /include/linux/context_tracking.h | |
| parent | 676ee36be04985062522804c2de04f0764212be6 (diff) | |
| parent | 2c33ce009ca2389dbf0535d0672214d09738e35e (diff) | |
Merge branch 'drm-next-merged' of git://people.freedesktop.org/~airlied/linux into v4l_for_linus
* 'drm-next-merged' of git://people.freedesktop.org/~airlied/linux: (9717 commits)
media-bus: Fixup RGB444_1X12, RGB565_1X16, and YUV8_1X24 media bus format
hexdump: avoid warning in test function
fs: take i_mutex during prepare_binprm for set[ug]id executables
smp: Fix error case handling in smp_call_function_*()
iommu-common: Fix PARISC compile-time warnings
sparc: Make LDC use common iommu poll management functions
sparc: Make sparc64 use scalable lib/iommu-common.c functions
Break up monolithic iommu table/lock into finer graularity pools and lock
sparc: Revert generic IOMMU allocator.
tools/power turbostat: correct dumped pkg-cstate-limit value
tools/power turbostat: calculate TSC frequency from CPUID(0x15) on SKL
tools/power turbostat: correct DRAM RAPL units on recent Xeon processors
tools/power turbostat: Initial Skylake support
tools/power turbostat: Use $(CURDIR) instead of $(PWD) and add support for O= option in Makefile
tools/power turbostat: modprobe msr, if needed
tools/power turbostat: dump MSR_TURBO_RATIO_LIMIT2
tools/power turbostat: use new MSR_TURBO_RATIO_LIMIT names
Bluetooth: hidp: Fix regression with older userspace and flags validation
config: Enable NEED_DMA_MAP_STATE by default when SWIOTLB is selected
perf/x86/intel/pt: Fix and clean up error handling in pt_event_add()
...
That solves several merge conflicts:
Documentation/DocBook/media/v4l/subdev-formats.xml
Documentation/devicetree/bindings/vendor-prefixes.txt
drivers/staging/media/mn88473/mn88473.c
include/linux/kconfig.h
include/uapi/linux/media-bus-format.h
The ones at subdev-formats.xml and media-bus-format.h are not trivial.
That's why we opted to merge from DRM.
Diffstat (limited to 'include/linux/context_tracking.h')
| -rw-r--r-- | include/linux/context_tracking.h | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/include/linux/context_tracking.h b/include/linux/context_tracking.h index 37b81bd51ec0..2821838256b4 100644 --- a/include/linux/context_tracking.h +++ b/include/linux/context_tracking.h | |||
| @@ -10,6 +10,8 @@ | |||
| 10 | #ifdef CONFIG_CONTEXT_TRACKING | 10 | #ifdef CONFIG_CONTEXT_TRACKING |
| 11 | extern void context_tracking_cpu_set(int cpu); | 11 | extern void context_tracking_cpu_set(int cpu); |
| 12 | 12 | ||
| 13 | extern void context_tracking_enter(enum ctx_state state); | ||
| 14 | extern void context_tracking_exit(enum ctx_state state); | ||
| 13 | extern void context_tracking_user_enter(void); | 15 | extern void context_tracking_user_enter(void); |
| 14 | extern void context_tracking_user_exit(void); | 16 | extern void context_tracking_user_exit(void); |
| 15 | extern void __context_tracking_task_switch(struct task_struct *prev, | 17 | extern void __context_tracking_task_switch(struct task_struct *prev, |
| @@ -35,7 +37,8 @@ static inline enum ctx_state exception_enter(void) | |||
| 35 | return 0; | 37 | return 0; |
| 36 | 38 | ||
| 37 | prev_ctx = this_cpu_read(context_tracking.state); | 39 | prev_ctx = this_cpu_read(context_tracking.state); |
| 38 | context_tracking_user_exit(); | 40 | if (prev_ctx != CONTEXT_KERNEL) |
| 41 | context_tracking_exit(prev_ctx); | ||
| 39 | 42 | ||
| 40 | return prev_ctx; | 43 | return prev_ctx; |
| 41 | } | 44 | } |
| @@ -43,8 +46,8 @@ static inline enum ctx_state exception_enter(void) | |||
| 43 | static inline void exception_exit(enum ctx_state prev_ctx) | 46 | static inline void exception_exit(enum ctx_state prev_ctx) |
| 44 | { | 47 | { |
| 45 | if (context_tracking_is_enabled()) { | 48 | if (context_tracking_is_enabled()) { |
| 46 | if (prev_ctx == IN_USER) | 49 | if (prev_ctx != CONTEXT_KERNEL) |
| 47 | context_tracking_user_enter(); | 50 | context_tracking_enter(prev_ctx); |
| 48 | } | 51 | } |
| 49 | } | 52 | } |
| 50 | 53 | ||
| @@ -78,10 +81,16 @@ static inline void guest_enter(void) | |||
| 78 | vtime_guest_enter(current); | 81 | vtime_guest_enter(current); |
| 79 | else | 82 | else |
| 80 | current->flags |= PF_VCPU; | 83 | current->flags |= PF_VCPU; |
| 84 | |||
| 85 | if (context_tracking_is_enabled()) | ||
| 86 | context_tracking_enter(CONTEXT_GUEST); | ||
| 81 | } | 87 | } |
| 82 | 88 | ||
| 83 | static inline void guest_exit(void) | 89 | static inline void guest_exit(void) |
| 84 | { | 90 | { |
| 91 | if (context_tracking_is_enabled()) | ||
| 92 | context_tracking_exit(CONTEXT_GUEST); | ||
| 93 | |||
| 85 | if (vtime_accounting_enabled()) | 94 | if (vtime_accounting_enabled()) |
| 86 | vtime_guest_exit(current); | 95 | vtime_guest_exit(current); |
| 87 | else | 96 | else |
