diff options
author | Mauro Carvalho Chehab <mchehab@redhat.com> | 2010-04-04 09:44:51 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2010-05-19 11:56:57 -0400 |
commit | 587835a4b0ada7d78c4f3300e3ab26b7b2495705 (patch) | |
tree | ad22f6a0e603f19450227b0cb260b5bb5960dfd5 /drivers/media | |
parent | 26d5683d36729f11f5764909ae37c69488596d36 (diff) |
V4L-DVB: ir-core: remove the ancillary buffer
Now that the decoders are state machine, there's no need to create
an ancillary buffer while decoding the protocol. Just call the decoders
code directly, event by event.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media')
-rw-r--r-- | drivers/media/IR/ir-nec-decoder.c | 32 | ||||
-rw-r--r-- | drivers/media/IR/ir-raw-event.c | 20 | ||||
-rw-r--r-- | drivers/media/IR/ir-rc5-decoder.c | 28 |
3 files changed, 12 insertions, 68 deletions
diff --git a/drivers/media/IR/ir-nec-decoder.c b/drivers/media/IR/ir-nec-decoder.c index 087211c5496a..28d773563556 100644 --- a/drivers/media/IR/ir-nec-decoder.c +++ b/drivers/media/IR/ir-nec-decoder.c | |||
@@ -125,14 +125,14 @@ static struct attribute_group decoder_attribute_group = { | |||
125 | 125 | ||
126 | 126 | ||
127 | /** | 127 | /** |
128 | * handle_event() - Decode one NEC pulse or space | 128 | * ir_nec_decode() - Decode one NEC pulse or space |
129 | * @input_dev: the struct input_dev descriptor of the device | 129 | * @input_dev: the struct input_dev descriptor of the device |
130 | * @ev: event array with type/duration of pulse/space | 130 | * @ev: event array with type/duration of pulse/space |
131 | * | 131 | * |
132 | * This function returns -EINVAL if the pulse violates the state machine | 132 | * This function returns -EINVAL if the pulse violates the state machine |
133 | */ | 133 | */ |
134 | static int handle_event(struct input_dev *input_dev, | 134 | static int ir_nec_decode(struct input_dev *input_dev, |
135 | struct ir_raw_event *ev) | 135 | struct ir_raw_event *ev) |
136 | { | 136 | { |
137 | struct decoder_data *data; | 137 | struct decoder_data *data; |
138 | struct ir_input_dev *ir_dev = input_get_drvdata(input_dev); | 138 | struct ir_input_dev *ir_dev = input_get_drvdata(input_dev); |
@@ -289,32 +289,6 @@ checksum_err: | |||
289 | return -EINVAL; | 289 | return -EINVAL; |
290 | } | 290 | } |
291 | 291 | ||
292 | /** | ||
293 | * ir_nec_decode() - Decodes all NEC pulsecodes on a given array | ||
294 | * @input_dev: the struct input_dev descriptor of the device | ||
295 | * @evs: event array with type/duration of pulse/space | ||
296 | * @len: length of the array | ||
297 | * This function returns the number of decoded pulses | ||
298 | */ | ||
299 | static int ir_nec_decode(struct input_dev *input_dev, | ||
300 | struct ir_raw_event *evs, | ||
301 | int len) | ||
302 | { | ||
303 | struct ir_input_dev *ir_dev = input_get_drvdata(input_dev); | ||
304 | struct decoder_data *data; | ||
305 | int pos = 0; | ||
306 | int rc = 0; | ||
307 | |||
308 | data = get_decoder_data(ir_dev); | ||
309 | if (!data || !data->enabled) | ||
310 | return 0; | ||
311 | |||
312 | for (pos = 0; pos < len; pos++) | ||
313 | handle_event(input_dev, &evs[pos]); | ||
314 | |||
315 | return rc; | ||
316 | } | ||
317 | |||
318 | static int ir_nec_register(struct input_dev *input_dev) | 292 | static int ir_nec_register(struct input_dev *input_dev) |
319 | { | 293 | { |
320 | struct ir_input_dev *ir_dev = input_get_drvdata(input_dev); | 294 | struct ir_input_dev *ir_dev = input_get_drvdata(input_dev); |
diff --git a/drivers/media/IR/ir-raw-event.c b/drivers/media/IR/ir-raw-event.c index 617e437e2beb..57990a337922 100644 --- a/drivers/media/IR/ir-raw-event.c +++ b/drivers/media/IR/ir-raw-event.c | |||
@@ -138,37 +138,33 @@ int ir_raw_event_handle(struct input_dev *input_dev) | |||
138 | { | 138 | { |
139 | struct ir_input_dev *ir = input_get_drvdata(input_dev); | 139 | struct ir_input_dev *ir = input_get_drvdata(input_dev); |
140 | int rc; | 140 | int rc; |
141 | struct ir_raw_event *evs; | 141 | struct ir_raw_event ev; |
142 | int len, i; | 142 | int len, i; |
143 | 143 | ||
144 | /* | 144 | /* |
145 | * Store the events into a temporary buffer. This allows calling more than | 145 | * Store the events into a temporary buffer. This allows calling more than |
146 | * one decoder to deal with the received data | 146 | * one decoder to deal with the received data |
147 | */ | 147 | */ |
148 | len = kfifo_len(&ir->raw->kfifo) / sizeof(*evs); | 148 | len = kfifo_len(&ir->raw->kfifo) / sizeof(ev); |
149 | if (!len) | 149 | if (!len) |
150 | return 0; | 150 | return 0; |
151 | evs = kmalloc(len * sizeof(*evs), GFP_ATOMIC); | ||
152 | 151 | ||
153 | for (i = 0; i < len; i++) { | 152 | for (i = 0; i < len; i++) { |
154 | rc = kfifo_out(&ir->raw->kfifo, &evs[i], sizeof(*evs)); | 153 | rc = kfifo_out(&ir->raw->kfifo, &ev, sizeof(ev)); |
155 | if (rc != sizeof(*evs)) { | 154 | if (rc != sizeof(ev)) { |
156 | IR_dprintk(1, "overflow error: received %d instead of %zd\n", | 155 | IR_dprintk(1, "overflow error: received %d instead of %zd\n", |
157 | rc, sizeof(*evs)); | 156 | rc, sizeof(ev)); |
158 | return -EINVAL; | 157 | return -EINVAL; |
159 | } | 158 | } |
160 | IR_dprintk(2, "event type %d, time before event: %07luus\n", | 159 | IR_dprintk(2, "event type %d, time before event: %07luus\n", |
161 | evs[i].type, (evs[i].delta.tv_nsec + 500) / 1000); | 160 | ev.type, (ev.delta.tv_nsec + 500) / 1000); |
161 | rc = RUN_DECODER(decode, input_dev, &ev); | ||
162 | } | 162 | } |
163 | 163 | ||
164 | /* | 164 | /* |
165 | * Call all ir decoders. This allows decoding the same event with | 165 | * Call all ir decoders. This allows decoding the same event with |
166 | * more than one protocol handler. It returns the number of keystrokes | 166 | * more than one protocol handler. |
167 | * sent to the event interface | ||
168 | */ | 167 | */ |
169 | rc = RUN_DECODER(decode, input_dev, evs, len); | ||
170 | |||
171 | kfree(evs); | ||
172 | 168 | ||
173 | return rc; | 169 | return rc; |
174 | } | 170 | } |
diff --git a/drivers/media/IR/ir-rc5-decoder.c b/drivers/media/IR/ir-rc5-decoder.c index 4b7eafecd842..61b58397a3c2 100644 --- a/drivers/media/IR/ir-rc5-decoder.c +++ b/drivers/media/IR/ir-rc5-decoder.c | |||
@@ -142,7 +142,7 @@ static struct attribute_group decoder_attribute_group = { | |||
142 | * | 142 | * |
143 | * This function returns -EINVAL if the pulse violates the state machine | 143 | * This function returns -EINVAL if the pulse violates the state machine |
144 | */ | 144 | */ |
145 | static int handle_event(struct input_dev *input_dev, | 145 | static int ir_rc5_decode(struct input_dev *input_dev, |
146 | struct ir_raw_event *ev) | 146 | struct ir_raw_event *ev) |
147 | { | 147 | { |
148 | struct decoder_data *data; | 148 | struct decoder_data *data; |
@@ -273,32 +273,6 @@ err2: | |||
273 | return -EINVAL; | 273 | return -EINVAL; |
274 | } | 274 | } |
275 | 275 | ||
276 | /** | ||
277 | * ir_rc5_decode() - Decodes all RC-5 pulsecodes on a given array | ||
278 | * @input_dev: the struct input_dev descriptor of the device | ||
279 | * @evs: event array with type/duration of pulse/space | ||
280 | * @len: length of the array | ||
281 | * This function returns the number of decoded pulses | ||
282 | */ | ||
283 | static int ir_rc5_decode(struct input_dev *input_dev, | ||
284 | struct ir_raw_event *evs, | ||
285 | int len) | ||
286 | { | ||
287 | struct ir_input_dev *ir_dev = input_get_drvdata(input_dev); | ||
288 | struct decoder_data *data; | ||
289 | int pos = 0; | ||
290 | int rc = 0; | ||
291 | |||
292 | data = get_decoder_data(ir_dev); | ||
293 | if (!data || !data->enabled) | ||
294 | return 0; | ||
295 | |||
296 | for (pos = 0; pos < len; pos++) | ||
297 | handle_event(input_dev, &evs[pos]); | ||
298 | |||
299 | return rc; | ||
300 | } | ||
301 | |||
302 | static int ir_rc5_register(struct input_dev *input_dev) | 276 | static int ir_rc5_register(struct input_dev *input_dev) |
303 | { | 277 | { |
304 | struct ir_input_dev *ir_dev = input_get_drvdata(input_dev); | 278 | struct ir_input_dev *ir_dev = input_get_drvdata(input_dev); |