diff options
| author | Mauro Carvalho Chehab <mchehab@s-opensource.com> | 2017-11-14 10:47:01 -0500 |
|---|---|---|
| committer | Mauro Carvalho Chehab <mchehab@s-opensource.com> | 2017-11-14 10:47:01 -0500 |
| commit | f2ecc3d0787e05d9145722feed01d4a11ab6bec1 (patch) | |
| tree | 8b952af40dad67d728f1e421efc640907c523982 /samples | |
| parent | b1cb7372fa822af6c06c8045963571d13ad6348b (diff) | |
| parent | c14dd9d5f8beda9d8c621683b4e7d6cb5cd3cda7 (diff) | |
Merge tag 'staging-4.15-rc1' into v4l_for_linus
There are some conflicts between staging and media trees,
as reported by Stephen Rothwell <sfr@canb.auug.org.au>.
So, merge from staging.
* tag 'staging-4.15-rc1': (775 commits)
staging: lustre: add SPDX identifiers to all lustre files
staging: greybus: Remove redundant license text
staging: greybus: add SPDX identifiers to all greybus driver files
staging: ccree: simplify ioread/iowrite
staging: ccree: simplify registers access
staging: ccree: simplify error handling logic
staging: ccree: remove dead code
staging: ccree: handle limiting of DMA masks
staging: ccree: copy IV to DMAable memory
staging: fbtft: remove redundant initialization of buf
staging: sm750fb: Fix parameter mistake in poke32
staging: wilc1000: Fix bssid buffer offset in Txq
staging: fbtft: fb_ssd1331: fix mirrored display
staging: android: Fix checkpatch.pl error
staging: greybus: loopback: convert loopback to use generic async operations
staging: greybus: operation: add private data with get/set accessors
staging: greybus: loopback: Fix iteration count on async path
staging: greybus: loopback: Hold per-connection mutex across operations
staging: greybus/loopback: use ktime_get() for time intervals
staging: fsl-dpaa2/eth: Extra headroom in RX buffers
...
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
Diffstat (limited to 'samples')
| -rw-r--r-- | samples/sockmap/sockmap_kern.c | 2 | ||||
| -rw-r--r-- | samples/trace_events/trace-events-sample.c | 14 |
2 files changed, 12 insertions, 4 deletions
diff --git a/samples/sockmap/sockmap_kern.c b/samples/sockmap/sockmap_kern.c index f9b38ef82dc2..52b0053274f4 100644 --- a/samples/sockmap/sockmap_kern.c +++ b/samples/sockmap/sockmap_kern.c | |||
| @@ -62,7 +62,7 @@ int bpf_prog2(struct __sk_buff *skb) | |||
| 62 | ret = 1; | 62 | ret = 1; |
| 63 | 63 | ||
| 64 | bpf_printk("sockmap: %d -> %d @ %d\n", lport, bpf_ntohl(rport), ret); | 64 | bpf_printk("sockmap: %d -> %d @ %d\n", lport, bpf_ntohl(rport), ret); |
| 65 | return bpf_sk_redirect_map(&sock_map, ret, 0); | 65 | return bpf_sk_redirect_map(skb, &sock_map, ret, 0); |
| 66 | } | 66 | } |
| 67 | 67 | ||
| 68 | SEC("sockops") | 68 | SEC("sockops") |
diff --git a/samples/trace_events/trace-events-sample.c b/samples/trace_events/trace-events-sample.c index bc7fcf010a5b..446beb7ac48d 100644 --- a/samples/trace_events/trace-events-sample.c +++ b/samples/trace_events/trace-events-sample.c | |||
| @@ -78,29 +78,37 @@ static int simple_thread_fn(void *arg) | |||
| 78 | } | 78 | } |
| 79 | 79 | ||
| 80 | static DEFINE_MUTEX(thread_mutex); | 80 | static DEFINE_MUTEX(thread_mutex); |
| 81 | static bool simple_thread_cnt; | ||
| 81 | 82 | ||
| 82 | int foo_bar_reg(void) | 83 | int foo_bar_reg(void) |
| 83 | { | 84 | { |
| 85 | mutex_lock(&thread_mutex); | ||
| 86 | if (simple_thread_cnt++) | ||
| 87 | goto out; | ||
| 88 | |||
| 84 | pr_info("Starting thread for foo_bar_fn\n"); | 89 | pr_info("Starting thread for foo_bar_fn\n"); |
| 85 | /* | 90 | /* |
| 86 | * We shouldn't be able to start a trace when the module is | 91 | * We shouldn't be able to start a trace when the module is |
| 87 | * unloading (there's other locks to prevent that). But | 92 | * unloading (there's other locks to prevent that). But |
| 88 | * for consistency sake, we still take the thread_mutex. | 93 | * for consistency sake, we still take the thread_mutex. |
| 89 | */ | 94 | */ |
| 90 | mutex_lock(&thread_mutex); | ||
| 91 | simple_tsk_fn = kthread_run(simple_thread_fn, NULL, "event-sample-fn"); | 95 | simple_tsk_fn = kthread_run(simple_thread_fn, NULL, "event-sample-fn"); |
| 96 | out: | ||
| 92 | mutex_unlock(&thread_mutex); | 97 | mutex_unlock(&thread_mutex); |
| 93 | return 0; | 98 | return 0; |
| 94 | } | 99 | } |
| 95 | 100 | ||
| 96 | void foo_bar_unreg(void) | 101 | void foo_bar_unreg(void) |
| 97 | { | 102 | { |
| 98 | pr_info("Killing thread for foo_bar_fn\n"); | ||
| 99 | /* protect against module unloading */ | ||
| 100 | mutex_lock(&thread_mutex); | 103 | mutex_lock(&thread_mutex); |
| 104 | if (--simple_thread_cnt) | ||
| 105 | goto out; | ||
| 106 | |||
| 107 | pr_info("Killing thread for foo_bar_fn\n"); | ||
| 101 | if (simple_tsk_fn) | 108 | if (simple_tsk_fn) |
| 102 | kthread_stop(simple_tsk_fn); | 109 | kthread_stop(simple_tsk_fn); |
| 103 | simple_tsk_fn = NULL; | 110 | simple_tsk_fn = NULL; |
| 111 | out: | ||
| 104 | mutex_unlock(&thread_mutex); | 112 | mutex_unlock(&thread_mutex); |
| 105 | } | 113 | } |
| 106 | 114 | ||
