diff options
Diffstat (limited to 'sound')
26 files changed, 1069 insertions, 916 deletions
diff --git a/sound/core/seq/seq_clientmgr.c b/sound/core/seq/seq_clientmgr.c index a886db94b1fa..5eab4201c640 100644 --- a/sound/core/seq/seq_clientmgr.c +++ b/sound/core/seq/seq_clientmgr.c | |||
@@ -58,14 +58,18 @@ static DECLARE_MUTEX(register_mutex); | |||
58 | * client table | 58 | * client table |
59 | */ | 59 | */ |
60 | static char clienttablock[SNDRV_SEQ_MAX_CLIENTS]; | 60 | static char clienttablock[SNDRV_SEQ_MAX_CLIENTS]; |
61 | static client_t *clienttab[SNDRV_SEQ_MAX_CLIENTS]; | 61 | static struct snd_seq_client *clienttab[SNDRV_SEQ_MAX_CLIENTS]; |
62 | static usage_t client_usage; | 62 | static struct snd_seq_usage client_usage; |
63 | 63 | ||
64 | /* | 64 | /* |
65 | * prototypes | 65 | * prototypes |
66 | */ | 66 | */ |
67 | static int bounce_error_event(client_t *client, snd_seq_event_t *event, int err, int atomic, int hop); | 67 | static int bounce_error_event(struct snd_seq_client *client, |
68 | static int snd_seq_deliver_single_event(client_t *client, snd_seq_event_t *event, int filter, int atomic, int hop); | 68 | struct snd_seq_event *event, |
69 | int err, int atomic, int hop); | ||
70 | static int snd_seq_deliver_single_event(struct snd_seq_client *client, | ||
71 | struct snd_seq_event *event, | ||
72 | int filter, int atomic, int hop); | ||
69 | 73 | ||
70 | /* | 74 | /* |
71 | */ | 75 | */ |
@@ -96,16 +100,17 @@ static inline unsigned short snd_seq_file_flags(struct file *file) | |||
96 | } | 100 | } |
97 | } | 101 | } |
98 | 102 | ||
99 | static inline int snd_seq_write_pool_allocated(client_t *client) | 103 | static inline int snd_seq_write_pool_allocated(struct snd_seq_client *client) |
100 | { | 104 | { |
101 | return snd_seq_total_cells(client->pool) > 0; | 105 | return snd_seq_total_cells(client->pool) > 0; |
102 | } | 106 | } |
103 | 107 | ||
104 | /* return pointer to client structure for specified id */ | 108 | /* return pointer to client structure for specified id */ |
105 | static client_t *clientptr(int clientid) | 109 | static struct snd_seq_client *clientptr(int clientid) |
106 | { | 110 | { |
107 | if (clientid < 0 || clientid >= SNDRV_SEQ_MAX_CLIENTS) { | 111 | if (clientid < 0 || clientid >= SNDRV_SEQ_MAX_CLIENTS) { |
108 | snd_printd("Seq: oops. Trying to get pointer to client %d\n", clientid); | 112 | snd_printd("Seq: oops. Trying to get pointer to client %d\n", |
113 | clientid); | ||
109 | return NULL; | 114 | return NULL; |
110 | } | 115 | } |
111 | return clienttab[clientid]; | 116 | return clienttab[clientid]; |
@@ -113,13 +118,14 @@ static client_t *clientptr(int clientid) | |||
113 | 118 | ||
114 | extern int seq_client_load[]; | 119 | extern int seq_client_load[]; |
115 | 120 | ||
116 | client_t *snd_seq_client_use_ptr(int clientid) | 121 | struct snd_seq_client *snd_seq_client_use_ptr(int clientid) |
117 | { | 122 | { |
118 | unsigned long flags; | 123 | unsigned long flags; |
119 | client_t *client; | 124 | struct snd_seq_client *client; |
120 | 125 | ||
121 | if (clientid < 0 || clientid >= SNDRV_SEQ_MAX_CLIENTS) { | 126 | if (clientid < 0 || clientid >= SNDRV_SEQ_MAX_CLIENTS) { |
122 | snd_printd("Seq: oops. Trying to get pointer to client %d\n", clientid); | 127 | snd_printd("Seq: oops. Trying to get pointer to client %d\n", |
128 | clientid); | ||
123 | return NULL; | 129 | return NULL; |
124 | } | 130 | } |
125 | spin_lock_irqsave(&clients_lock, flags); | 131 | spin_lock_irqsave(&clients_lock, flags); |
@@ -144,7 +150,8 @@ client_t *snd_seq_client_use_ptr(int clientid) | |||
144 | if (seq_client_load[idx] < 0) | 150 | if (seq_client_load[idx] < 0) |
145 | break; | 151 | break; |
146 | if (seq_client_load[idx] == clientid) { | 152 | if (seq_client_load[idx] == clientid) { |
147 | request_module("snd-seq-client-%i", clientid); | 153 | request_module("snd-seq-client-%i", |
154 | clientid); | ||
148 | break; | 155 | break; |
149 | } | 156 | } |
150 | } | 157 | } |
@@ -174,14 +181,14 @@ client_t *snd_seq_client_use_ptr(int clientid) | |||
174 | return client; | 181 | return client; |
175 | } | 182 | } |
176 | 183 | ||
177 | static void usage_alloc(usage_t * res, int num) | 184 | static void usage_alloc(struct snd_seq_usage *res, int num) |
178 | { | 185 | { |
179 | res->cur += num; | 186 | res->cur += num; |
180 | if (res->cur > res->peak) | 187 | if (res->cur > res->peak) |
181 | res->peak = res->cur; | 188 | res->peak = res->cur; |
182 | } | 189 | } |
183 | 190 | ||
184 | static void usage_free(usage_t * res, int num) | 191 | static void usage_free(struct snd_seq_usage *res, int num) |
185 | { | 192 | { |
186 | res->cur -= num; | 193 | res->cur -= num; |
187 | } | 194 | } |
@@ -196,11 +203,11 @@ int __init client_init_data(void) | |||
196 | } | 203 | } |
197 | 204 | ||
198 | 205 | ||
199 | static client_t *seq_create_client1(int client_index, int poolsize) | 206 | static struct snd_seq_client *seq_create_client1(int client_index, int poolsize) |
200 | { | 207 | { |
201 | unsigned long flags; | 208 | unsigned long flags; |
202 | int c; | 209 | int c; |
203 | client_t *client; | 210 | struct snd_seq_client *client; |
204 | 211 | ||
205 | /* init client data */ | 212 | /* init client data */ |
206 | client = kzalloc(sizeof(*client), GFP_KERNEL); | 213 | client = kzalloc(sizeof(*client), GFP_KERNEL); |
@@ -241,7 +248,7 @@ static client_t *seq_create_client1(int client_index, int poolsize) | |||
241 | } | 248 | } |
242 | 249 | ||
243 | 250 | ||
244 | static int seq_free_client1(client_t *client) | 251 | static int seq_free_client1(struct snd_seq_client *client) |
245 | { | 252 | { |
246 | unsigned long flags; | 253 | unsigned long flags; |
247 | 254 | ||
@@ -263,12 +270,13 @@ static int seq_free_client1(client_t *client) | |||
263 | } | 270 | } |
264 | 271 | ||
265 | 272 | ||
266 | static void seq_free_client(client_t * client) | 273 | static void seq_free_client(struct snd_seq_client * client) |
267 | { | 274 | { |
268 | down(®ister_mutex); | 275 | down(®ister_mutex); |
269 | switch (client->type) { | 276 | switch (client->type) { |
270 | case NO_CLIENT: | 277 | case NO_CLIENT: |
271 | snd_printk(KERN_WARNING "Seq: Trying to free unused client %d\n", client->number); | 278 | snd_printk(KERN_WARNING "Seq: Trying to free unused client %d\n", |
279 | client->number); | ||
272 | break; | 280 | break; |
273 | case USER_CLIENT: | 281 | case USER_CLIENT: |
274 | case KERNEL_CLIENT: | 282 | case KERNEL_CLIENT: |
@@ -277,7 +285,8 @@ static void seq_free_client(client_t * client) | |||
277 | break; | 285 | break; |
278 | 286 | ||
279 | default: | 287 | default: |
280 | snd_printk(KERN_ERR "Seq: Trying to free client %d with undefined type = %d\n", client->number, client->type); | 288 | snd_printk(KERN_ERR "Seq: Trying to free client %d with undefined type = %d\n", |
289 | client->number, client->type); | ||
281 | } | 290 | } |
282 | up(®ister_mutex); | 291 | up(®ister_mutex); |
283 | 292 | ||
@@ -292,8 +301,8 @@ static void seq_free_client(client_t * client) | |||
292 | static int snd_seq_open(struct inode *inode, struct file *file) | 301 | static int snd_seq_open(struct inode *inode, struct file *file) |
293 | { | 302 | { |
294 | int c, mode; /* client id */ | 303 | int c, mode; /* client id */ |
295 | client_t *client; | 304 | struct snd_seq_client *client; |
296 | user_client_t *user; | 305 | struct snd_seq_user_client *user; |
297 | 306 | ||
298 | if (down_interruptible(®ister_mutex)) | 307 | if (down_interruptible(®ister_mutex)) |
299 | return -ERESTARTSYS; | 308 | return -ERESTARTSYS; |
@@ -344,7 +353,7 @@ static int snd_seq_open(struct inode *inode, struct file *file) | |||
344 | /* delete a user client */ | 353 | /* delete a user client */ |
345 | static int snd_seq_release(struct inode *inode, struct file *file) | 354 | static int snd_seq_release(struct inode *inode, struct file *file) |
346 | { | 355 | { |
347 | client_t *client = (client_t *) file->private_data; | 356 | struct snd_seq_client *client = file->private_data; |
348 | 357 | ||
349 | if (client) { | 358 | if (client) { |
350 | seq_free_client(client); | 359 | seq_free_client(client); |
@@ -364,13 +373,14 @@ static int snd_seq_release(struct inode *inode, struct file *file) | |||
364 | * -EINVAL no enough user-space buffer to write the whole event | 373 | * -EINVAL no enough user-space buffer to write the whole event |
365 | * -EFAULT seg. fault during copy to user space | 374 | * -EFAULT seg. fault during copy to user space |
366 | */ | 375 | */ |
367 | static ssize_t snd_seq_read(struct file *file, char __user *buf, size_t count, loff_t *offset) | 376 | static ssize_t snd_seq_read(struct file *file, char __user *buf, size_t count, |
377 | loff_t *offset) | ||
368 | { | 378 | { |
369 | client_t *client = (client_t *) file->private_data; | 379 | struct snd_seq_client *client = file->private_data; |
370 | fifo_t *fifo; | 380 | struct snd_seq_fifo *fifo; |
371 | int err; | 381 | int err; |
372 | long result = 0; | 382 | long result = 0; |
373 | snd_seq_event_cell_t *cell; | 383 | struct snd_seq_event_cell *cell; |
374 | 384 | ||
375 | if (!(snd_seq_file_flags(file) & SNDRV_SEQ_LFLG_INPUT)) | 385 | if (!(snd_seq_file_flags(file) & SNDRV_SEQ_LFLG_INPUT)) |
376 | return -ENXIO; | 386 | return -ENXIO; |
@@ -396,7 +406,7 @@ static ssize_t snd_seq_read(struct file *file, char __user *buf, size_t count, l | |||
396 | snd_seq_fifo_lock(fifo); | 406 | snd_seq_fifo_lock(fifo); |
397 | 407 | ||
398 | /* while data available in queue */ | 408 | /* while data available in queue */ |
399 | while (count >= sizeof(snd_seq_event_t)) { | 409 | while (count >= sizeof(struct snd_seq_event)) { |
400 | int nonblock; | 410 | int nonblock; |
401 | 411 | ||
402 | nonblock = (file->f_flags & O_NONBLOCK) || result > 0; | 412 | nonblock = (file->f_flags & O_NONBLOCK) || result > 0; |
@@ -404,34 +414,34 @@ static ssize_t snd_seq_read(struct file *file, char __user *buf, size_t count, l | |||
404 | break; | 414 | break; |
405 | } | 415 | } |
406 | if (snd_seq_ev_is_variable(&cell->event)) { | 416 | if (snd_seq_ev_is_variable(&cell->event)) { |
407 | snd_seq_event_t tmpev; | 417 | struct snd_seq_event tmpev; |
408 | tmpev = cell->event; | 418 | tmpev = cell->event; |
409 | tmpev.data.ext.len &= ~SNDRV_SEQ_EXT_MASK; | 419 | tmpev.data.ext.len &= ~SNDRV_SEQ_EXT_MASK; |
410 | if (copy_to_user(buf, &tmpev, sizeof(snd_seq_event_t))) { | 420 | if (copy_to_user(buf, &tmpev, sizeof(struct snd_seq_event))) { |
411 | err = -EFAULT; | 421 | err = -EFAULT; |
412 | break; | 422 | break; |
413 | } | 423 | } |
414 | count -= sizeof(snd_seq_event_t); | 424 | count -= sizeof(struct snd_seq_event); |
415 | buf += sizeof(snd_seq_event_t); | 425 | buf += sizeof(struct snd_seq_event); |
416 | err = snd_seq_expand_var_event(&cell->event, count, | 426 | err = snd_seq_expand_var_event(&cell->event, count, |
417 | (char __force *)buf, 0, | 427 | (char __force *)buf, 0, |
418 | sizeof(snd_seq_event_t)); | 428 | sizeof(struct snd_seq_event)); |
419 | if (err < 0) | 429 | if (err < 0) |
420 | break; | 430 | break; |
421 | result += err; | 431 | result += err; |
422 | count -= err; | 432 | count -= err; |
423 | buf += err; | 433 | buf += err; |
424 | } else { | 434 | } else { |
425 | if (copy_to_user(buf, &cell->event, sizeof(snd_seq_event_t))) { | 435 | if (copy_to_user(buf, &cell->event, sizeof(struct snd_seq_event))) { |
426 | err = -EFAULT; | 436 | err = -EFAULT; |
427 | break; | 437 | break; |
428 | } | 438 | } |
429 | count -= sizeof(snd_seq_event_t); | 439 | count -= sizeof(struct snd_seq_event); |
430 | buf += sizeof(snd_seq_event_t); | 440 | buf += sizeof(struct snd_seq_event); |
431 | } | 441 | } |
432 | snd_seq_cell_free(cell); | 442 | snd_seq_cell_free(cell); |
433 | cell = NULL; /* to be sure */ | 443 | cell = NULL; /* to be sure */ |
434 | result += sizeof(snd_seq_event_t); | 444 | result += sizeof(struct snd_seq_event); |
435 | } | 445 | } |
436 | 446 | ||
437 | if (err < 0) { | 447 | if (err < 0) { |
@@ -449,7 +459,7 @@ static ssize_t snd_seq_read(struct file *file, char __user *buf, size_t count, l | |||
449 | /* | 459 | /* |
450 | * check access permission to the port | 460 | * check access permission to the port |
451 | */ | 461 | */ |
452 | static int check_port_perm(client_port_t *port, unsigned int flags) | 462 | static int check_port_perm(struct snd_seq_client_port *port, unsigned int flags) |
453 | { | 463 | { |
454 | if ((port->capability & flags) != flags) | 464 | if ((port->capability & flags) != flags) |
455 | return 0; | 465 | return 0; |
@@ -460,9 +470,10 @@ static int check_port_perm(client_port_t *port, unsigned int flags) | |||
460 | * check if the destination client is available, and return the pointer | 470 | * check if the destination client is available, and return the pointer |
461 | * if filter is non-zero, client filter bitmap is tested. | 471 | * if filter is non-zero, client filter bitmap is tested. |
462 | */ | 472 | */ |
463 | static client_t *get_event_dest_client(snd_seq_event_t *event, int filter) | 473 | static struct snd_seq_client *get_event_dest_client(struct snd_seq_event *event, |
474 | int filter) | ||
464 | { | 475 | { |
465 | client_t *dest; | 476 | struct snd_seq_client *dest; |
466 | 477 | ||
467 | dest = snd_seq_client_use_ptr(event->dest.client); | 478 | dest = snd_seq_client_use_ptr(event->dest.client); |
468 | if (dest == NULL) | 479 | if (dest == NULL) |
@@ -493,10 +504,11 @@ __not_avail: | |||
493 | * quoted in SNDRV_SEQ_EVENT_KERNEL_ERROR, since this requires no extra | 504 | * quoted in SNDRV_SEQ_EVENT_KERNEL_ERROR, since this requires no extra |
494 | * kmalloc. | 505 | * kmalloc. |
495 | */ | 506 | */ |
496 | static int bounce_error_event(client_t *client, snd_seq_event_t *event, | 507 | static int bounce_error_event(struct snd_seq_client *client, |
508 | struct snd_seq_event *event, | ||
497 | int err, int atomic, int hop) | 509 | int err, int atomic, int hop) |
498 | { | 510 | { |
499 | snd_seq_event_t bounce_ev; | 511 | struct snd_seq_event bounce_ev; |
500 | int result; | 512 | int result; |
501 | 513 | ||
502 | if (client == NULL || | 514 | if (client == NULL || |
@@ -531,9 +543,10 @@ static int bounce_error_event(client_t *client, snd_seq_event_t *event, | |||
531 | * of the given queue. | 543 | * of the given queue. |
532 | * return non-zero if updated. | 544 | * return non-zero if updated. |
533 | */ | 545 | */ |
534 | static int update_timestamp_of_queue(snd_seq_event_t *event, int queue, int real_time) | 546 | static int update_timestamp_of_queue(struct snd_seq_event *event, |
547 | int queue, int real_time) | ||
535 | { | 548 | { |
536 | queue_t *q; | 549 | struct snd_seq_queue *q; |
537 | 550 | ||
538 | q = queueptr(queue); | 551 | q = queueptr(queue); |
539 | if (! q) | 552 | if (! q) |
@@ -559,12 +572,12 @@ static int update_timestamp_of_queue(snd_seq_event_t *event, int queue, int real | |||
559 | * RETURN VALUE: 0 : if succeeded | 572 | * RETURN VALUE: 0 : if succeeded |
560 | * <0 : error | 573 | * <0 : error |
561 | */ | 574 | */ |
562 | static int snd_seq_deliver_single_event(client_t *client, | 575 | static int snd_seq_deliver_single_event(struct snd_seq_client *client, |
563 | snd_seq_event_t *event, | 576 | struct snd_seq_event *event, |
564 | int filter, int atomic, int hop) | 577 | int filter, int atomic, int hop) |
565 | { | 578 | { |
566 | client_t *dest = NULL; | 579 | struct snd_seq_client *dest = NULL; |
567 | client_port_t *dest_port = NULL; | 580 | struct snd_seq_client_port *dest_port = NULL; |
568 | int result = -ENOENT; | 581 | int result = -ENOENT; |
569 | int direct; | 582 | int direct; |
570 | 583 | ||
@@ -596,7 +609,9 @@ static int snd_seq_deliver_single_event(client_t *client, | |||
596 | case KERNEL_CLIENT: | 609 | case KERNEL_CLIENT: |
597 | if (dest_port->event_input == NULL) | 610 | if (dest_port->event_input == NULL) |
598 | break; | 611 | break; |
599 | result = dest_port->event_input(event, direct, dest_port->private_data, atomic, hop); | 612 | result = dest_port->event_input(event, direct, |
613 | dest_port->private_data, | ||
614 | atomic, hop); | ||
600 | break; | 615 | break; |
601 | default: | 616 | default: |
602 | break; | 617 | break; |
@@ -618,16 +633,16 @@ static int snd_seq_deliver_single_event(client_t *client, | |||
618 | /* | 633 | /* |
619 | * send the event to all subscribers: | 634 | * send the event to all subscribers: |
620 | */ | 635 | */ |
621 | static int deliver_to_subscribers(client_t *client, | 636 | static int deliver_to_subscribers(struct snd_seq_client *client, |
622 | snd_seq_event_t *event, | 637 | struct snd_seq_event *event, |
623 | int atomic, int hop) | 638 | int atomic, int hop) |
624 | { | 639 | { |
625 | subscribers_t *subs; | 640 | struct snd_seq_subscribers *subs; |
626 | int err = 0, num_ev = 0; | 641 | int err = 0, num_ev = 0; |
627 | snd_seq_event_t event_saved; | 642 | struct snd_seq_event event_saved; |
628 | client_port_t *src_port; | 643 | struct snd_seq_client_port *src_port; |
629 | struct list_head *p; | 644 | struct list_head *p; |
630 | port_subs_info_t *grp; | 645 | struct snd_seq_port_subs_info *grp; |
631 | 646 | ||
632 | src_port = snd_seq_port_use_ptr(client, event->source.port); | 647 | src_port = snd_seq_port_use_ptr(client, event->source.port); |
633 | if (src_port == NULL) | 648 | if (src_port == NULL) |
@@ -642,7 +657,7 @@ static int deliver_to_subscribers(client_t *client, | |||
642 | else | 657 | else |
643 | down_read(&grp->list_mutex); | 658 | down_read(&grp->list_mutex); |
644 | list_for_each(p, &grp->list_head) { | 659 | list_for_each(p, &grp->list_head) { |
645 | subs = list_entry(p, subscribers_t, src_list); | 660 | subs = list_entry(p, struct snd_seq_subscribers, src_list); |
646 | event->dest = subs->info.dest; | 661 | event->dest = subs->info.dest; |
647 | if (subs->info.flags & SNDRV_SEQ_PORT_SUBS_TIMESTAMP) | 662 | if (subs->info.flags & SNDRV_SEQ_PORT_SUBS_TIMESTAMP) |
648 | /* convert time according to flag with subscription */ | 663 | /* convert time according to flag with subscription */ |
@@ -670,12 +685,12 @@ static int deliver_to_subscribers(client_t *client, | |||
670 | /* | 685 | /* |
671 | * broadcast to all ports: | 686 | * broadcast to all ports: |
672 | */ | 687 | */ |
673 | static int port_broadcast_event(client_t *client, | 688 | static int port_broadcast_event(struct snd_seq_client *client, |
674 | snd_seq_event_t *event, | 689 | struct snd_seq_event *event, |
675 | int atomic, int hop) | 690 | int atomic, int hop) |
676 | { | 691 | { |
677 | int num_ev = 0, err = 0; | 692 | int num_ev = 0, err = 0; |
678 | client_t *dest_client; | 693 | struct snd_seq_client *dest_client; |
679 | struct list_head *p; | 694 | struct list_head *p; |
680 | 695 | ||
681 | dest_client = get_event_dest_client(event, SNDRV_SEQ_FILTER_BROADCAST); | 696 | dest_client = get_event_dest_client(event, SNDRV_SEQ_FILTER_BROADCAST); |
@@ -684,7 +699,7 @@ static int port_broadcast_event(client_t *client, | |||
684 | 699 | ||
685 | read_lock(&dest_client->ports_lock); | 700 | read_lock(&dest_client->ports_lock); |
686 | list_for_each(p, &dest_client->ports_list_head) { | 701 | list_for_each(p, &dest_client->ports_list_head) { |
687 | client_port_t *port = list_entry(p, client_port_t, list); | 702 | struct snd_seq_client_port *port = list_entry(p, struct snd_seq_client_port, list); |
688 | event->dest.port = port->addr.port; | 703 | event->dest.port = port->addr.port; |
689 | /* pass NULL as source client to avoid error bounce */ | 704 | /* pass NULL as source client to avoid error bounce */ |
690 | err = snd_seq_deliver_single_event(NULL, event, | 705 | err = snd_seq_deliver_single_event(NULL, event, |
@@ -704,12 +719,12 @@ static int port_broadcast_event(client_t *client, | |||
704 | * send the event to all clients: | 719 | * send the event to all clients: |
705 | * if destination port is also ADDRESS_BROADCAST, deliver to all ports. | 720 | * if destination port is also ADDRESS_BROADCAST, deliver to all ports. |
706 | */ | 721 | */ |
707 | static int broadcast_event(client_t *client, | 722 | static int broadcast_event(struct snd_seq_client *client, |
708 | snd_seq_event_t *event, int atomic, int hop) | 723 | struct snd_seq_event *event, int atomic, int hop) |
709 | { | 724 | { |
710 | int err = 0, num_ev = 0; | 725 | int err = 0, num_ev = 0; |
711 | int dest; | 726 | int dest; |
712 | snd_seq_addr_t addr; | 727 | struct snd_seq_addr addr; |
713 | 728 | ||
714 | addr = event->dest; /* save */ | 729 | addr = event->dest; /* save */ |
715 | 730 | ||
@@ -736,7 +751,7 @@ static int broadcast_event(client_t *client, | |||
736 | 751 | ||
737 | 752 | ||
738 | /* multicast - not supported yet */ | 753 | /* multicast - not supported yet */ |
739 | static int multicast_event(client_t *client, snd_seq_event_t *event, | 754 | static int multicast_event(struct snd_seq_client *client, struct snd_seq_event *event, |
740 | int atomic, int hop) | 755 | int atomic, int hop) |
741 | { | 756 | { |
742 | snd_printd("seq: multicast not supported yet.\n"); | 757 | snd_printd("seq: multicast not supported yet.\n"); |
@@ -753,7 +768,7 @@ static int multicast_event(client_t *client, snd_seq_event_t *event, | |||
753 | * n == 0 : the event was not passed to any client. | 768 | * n == 0 : the event was not passed to any client. |
754 | * n < 0 : error - event was not processed. | 769 | * n < 0 : error - event was not processed. |
755 | */ | 770 | */ |
756 | static int snd_seq_deliver_event(client_t *client, snd_seq_event_t *event, | 771 | static int snd_seq_deliver_event(struct snd_seq_client *client, struct snd_seq_event *event, |
757 | int atomic, int hop) | 772 | int atomic, int hop) |
758 | { | 773 | { |
759 | int result; | 774 | int result; |
@@ -794,9 +809,9 @@ static int snd_seq_deliver_event(client_t *client, snd_seq_event_t *event, | |||
794 | * n == 0 : the event was not passed to any client. | 809 | * n == 0 : the event was not passed to any client. |
795 | * n < 0 : error - event was not processed. | 810 | * n < 0 : error - event was not processed. |
796 | */ | 811 | */ |
797 | int snd_seq_dispatch_event(snd_seq_event_cell_t *cell, int atomic, int hop) | 812 | int snd_seq_dispatch_event(struct snd_seq_event_cell *cell, int atomic, int hop) |
798 | { | 813 | { |
799 | client_t *client; | 814 | struct snd_seq_client *client; |
800 | int result; | 815 | int result; |
801 | 816 | ||
802 | snd_assert(cell != NULL, return -EINVAL); | 817 | snd_assert(cell != NULL, return -EINVAL); |
@@ -812,7 +827,7 @@ int snd_seq_dispatch_event(snd_seq_event_cell_t *cell, int atomic, int hop) | |||
812 | * the event cell is re-used as a NOTE-OFF event and | 827 | * the event cell is re-used as a NOTE-OFF event and |
813 | * enqueued again. | 828 | * enqueued again. |
814 | */ | 829 | */ |
815 | snd_seq_event_t tmpev, *ev; | 830 | struct snd_seq_event tmpev, *ev; |
816 | 831 | ||
817 | /* reserve this event to enqueue note-off later */ | 832 | /* reserve this event to enqueue note-off later */ |
818 | tmpev = cell->event; | 833 | tmpev = cell->event; |
@@ -865,12 +880,12 @@ int snd_seq_dispatch_event(snd_seq_event_cell_t *cell, int atomic, int hop) | |||
865 | * if pool is empty and blocking is TRUE, sleep until a new cell is | 880 | * if pool is empty and blocking is TRUE, sleep until a new cell is |
866 | * available. | 881 | * available. |
867 | */ | 882 | */ |
868 | static int snd_seq_client_enqueue_event(client_t *client, | 883 | static int snd_seq_client_enqueue_event(struct snd_seq_client *client, |
869 | snd_seq_event_t *event, | 884 | struct snd_seq_event *event, |
870 | struct file *file, int blocking, | 885 | struct file *file, int blocking, |
871 | int atomic, int hop) | 886 | int atomic, int hop) |
872 | { | 887 | { |
873 | snd_seq_event_cell_t *cell; | 888 | struct snd_seq_event_cell *cell; |
874 | int err; | 889 | int err; |
875 | 890 | ||
876 | /* special queue values - force direct passing */ | 891 | /* special queue values - force direct passing */ |
@@ -886,7 +901,7 @@ static int snd_seq_client_enqueue_event(client_t *client, | |||
886 | #endif | 901 | #endif |
887 | if (event->dest.client == SNDRV_SEQ_ADDRESS_SUBSCRIBERS) { | 902 | if (event->dest.client == SNDRV_SEQ_ADDRESS_SUBSCRIBERS) { |
888 | /* check presence of source port */ | 903 | /* check presence of source port */ |
889 | client_port_t *src_port = snd_seq_port_use_ptr(client, event->source.port); | 904 | struct snd_seq_client_port *src_port = snd_seq_port_use_ptr(client, event->source.port); |
890 | if (src_port == NULL) | 905 | if (src_port == NULL) |
891 | return -EINVAL; | 906 | return -EINVAL; |
892 | snd_seq_port_unlock(src_port); | 907 | snd_seq_port_unlock(src_port); |
@@ -924,7 +939,7 @@ static int snd_seq_client_enqueue_event(client_t *client, | |||
924 | * check validity of event type and data length. | 939 | * check validity of event type and data length. |
925 | * return non-zero if invalid. | 940 | * return non-zero if invalid. |
926 | */ | 941 | */ |
927 | static int check_event_type_and_length(snd_seq_event_t *ev) | 942 | static int check_event_type_and_length(struct snd_seq_event *ev) |
928 | { | 943 | { |
929 | switch (snd_seq_ev_length_type(ev)) { | 944 | switch (snd_seq_ev_length_type(ev)) { |
930 | case SNDRV_SEQ_EVENT_LENGTH_FIXED: | 945 | case SNDRV_SEQ_EVENT_LENGTH_FIXED: |
@@ -957,12 +972,13 @@ static int check_event_type_and_length(snd_seq_event_t *ev) | |||
957 | * -EMLINK too many hops | 972 | * -EMLINK too many hops |
958 | * others depends on return value from driver callback | 973 | * others depends on return value from driver callback |
959 | */ | 974 | */ |
960 | static ssize_t snd_seq_write(struct file *file, const char __user *buf, size_t count, loff_t *offset) | 975 | static ssize_t snd_seq_write(struct file *file, const char __user *buf, |
976 | size_t count, loff_t *offset) | ||
961 | { | 977 | { |
962 | client_t *client = (client_t *) file->private_data; | 978 | struct snd_seq_client *client = file->private_data; |
963 | int written = 0, len; | 979 | int written = 0, len; |
964 | int err = -EINVAL; | 980 | int err = -EINVAL; |
965 | snd_seq_event_t event; | 981 | struct snd_seq_event event; |
966 | 982 | ||
967 | if (!(snd_seq_file_flags(file) & SNDRV_SEQ_LFLG_OUTPUT)) | 983 | if (!(snd_seq_file_flags(file) & SNDRV_SEQ_LFLG_OUTPUT)) |
968 | return -ENXIO; | 984 | return -ENXIO; |
@@ -980,7 +996,7 @@ static ssize_t snd_seq_write(struct file *file, const char __user *buf, size_t c | |||
980 | } | 996 | } |
981 | 997 | ||
982 | /* only process whole events */ | 998 | /* only process whole events */ |
983 | while (count >= sizeof(snd_seq_event_t)) { | 999 | while (count >= sizeof(struct snd_seq_event)) { |
984 | /* Read in the event header from the user */ | 1000 | /* Read in the event header from the user */ |
985 | len = sizeof(event); | 1001 | len = sizeof(event); |
986 | if (copy_from_user(&event, buf, len)) { | 1002 | if (copy_from_user(&event, buf, len)) { |
@@ -1012,7 +1028,7 @@ static ssize_t snd_seq_write(struct file *file, const char __user *buf, size_t c | |||
1012 | /* set user space pointer */ | 1028 | /* set user space pointer */ |
1013 | event.data.ext.len = extlen | SNDRV_SEQ_EXT_USRPTR; | 1029 | event.data.ext.len = extlen | SNDRV_SEQ_EXT_USRPTR; |
1014 | event.data.ext.ptr = (char __force *)buf | 1030 | event.data.ext.ptr = (char __force *)buf |
1015 | + sizeof(snd_seq_event_t); | 1031 | + sizeof(struct snd_seq_event); |
1016 | len += extlen; /* increment data length */ | 1032 | len += extlen; /* increment data length */ |
1017 | } else { | 1033 | } else { |
1018 | #ifdef CONFIG_COMPAT | 1034 | #ifdef CONFIG_COMPAT |
@@ -1046,7 +1062,7 @@ static ssize_t snd_seq_write(struct file *file, const char __user *buf, size_t c | |||
1046 | */ | 1062 | */ |
1047 | static unsigned int snd_seq_poll(struct file *file, poll_table * wait) | 1063 | static unsigned int snd_seq_poll(struct file *file, poll_table * wait) |
1048 | { | 1064 | { |
1049 | client_t *client = (client_t *) file->private_data; | 1065 | struct snd_seq_client *client = file->private_data; |
1050 | unsigned int mask = 0; | 1066 | unsigned int mask = 0; |
1051 | 1067 | ||
1052 | /* check client structures are in place */ | 1068 | /* check client structures are in place */ |
@@ -1076,9 +1092,9 @@ static unsigned int snd_seq_poll(struct file *file, poll_table * wait) | |||
1076 | 1092 | ||
1077 | 1093 | ||
1078 | /* SYSTEM_INFO ioctl() */ | 1094 | /* SYSTEM_INFO ioctl() */ |
1079 | static int snd_seq_ioctl_system_info(client_t *client, void __user *arg) | 1095 | static int snd_seq_ioctl_system_info(struct snd_seq_client *client, void __user *arg) |
1080 | { | 1096 | { |
1081 | snd_seq_system_info_t info; | 1097 | struct snd_seq_system_info info; |
1082 | 1098 | ||
1083 | memset(&info, 0, sizeof(info)); | 1099 | memset(&info, 0, sizeof(info)); |
1084 | /* fill the info fields */ | 1100 | /* fill the info fields */ |
@@ -1096,10 +1112,10 @@ static int snd_seq_ioctl_system_info(client_t *client, void __user *arg) | |||
1096 | 1112 | ||
1097 | 1113 | ||
1098 | /* RUNNING_MODE ioctl() */ | 1114 | /* RUNNING_MODE ioctl() */ |
1099 | static int snd_seq_ioctl_running_mode(client_t *client, void __user *arg) | 1115 | static int snd_seq_ioctl_running_mode(struct snd_seq_client *client, void __user *arg) |
1100 | { | 1116 | { |
1101 | struct sndrv_seq_running_info info; | 1117 | struct snd_seq_running_info info; |
1102 | client_t *cptr; | 1118 | struct snd_seq_client *cptr; |
1103 | int err = 0; | 1119 | int err = 0; |
1104 | 1120 | ||
1105 | if (copy_from_user(&info, arg, sizeof(info))) | 1121 | if (copy_from_user(&info, arg, sizeof(info))) |
@@ -1133,7 +1149,8 @@ static int snd_seq_ioctl_running_mode(client_t *client, void __user *arg) | |||
1133 | } | 1149 | } |
1134 | 1150 | ||
1135 | /* CLIENT_INFO ioctl() */ | 1151 | /* CLIENT_INFO ioctl() */ |
1136 | static void get_client_info(client_t *cptr, snd_seq_client_info_t *info) | 1152 | static void get_client_info(struct snd_seq_client *cptr, |
1153 | struct snd_seq_client_info *info) | ||
1137 | { | 1154 | { |
1138 | info->client = cptr->number; | 1155 | info->client = cptr->number; |
1139 | 1156 | ||
@@ -1147,10 +1164,11 @@ static void get_client_info(client_t *cptr, snd_seq_client_info_t *info) | |||
1147 | memset(info->reserved, 0, sizeof(info->reserved)); | 1164 | memset(info->reserved, 0, sizeof(info->reserved)); |
1148 | } | 1165 | } |
1149 | 1166 | ||
1150 | static int snd_seq_ioctl_get_client_info(client_t * client, void __user *arg) | 1167 | static int snd_seq_ioctl_get_client_info(struct snd_seq_client *client, |
1168 | void __user *arg) | ||
1151 | { | 1169 | { |
1152 | client_t *cptr; | 1170 | struct snd_seq_client *cptr; |
1153 | snd_seq_client_info_t client_info; | 1171 | struct snd_seq_client_info client_info; |
1154 | 1172 | ||
1155 | if (copy_from_user(&client_info, arg, sizeof(client_info))) | 1173 | if (copy_from_user(&client_info, arg, sizeof(client_info))) |
1156 | return -EFAULT; | 1174 | return -EFAULT; |
@@ -1170,9 +1188,10 @@ static int snd_seq_ioctl_get_client_info(client_t * client, void __user *arg) | |||
1170 | 1188 | ||
1171 | 1189 | ||
1172 | /* CLIENT_INFO ioctl() */ | 1190 | /* CLIENT_INFO ioctl() */ |
1173 | static int snd_seq_ioctl_set_client_info(client_t * client, void __user *arg) | 1191 | static int snd_seq_ioctl_set_client_info(struct snd_seq_client *client, |
1192 | void __user *arg) | ||
1174 | { | 1193 | { |
1175 | snd_seq_client_info_t client_info; | 1194 | struct snd_seq_client_info client_info; |
1176 | 1195 | ||
1177 | if (copy_from_user(&client_info, arg, sizeof(client_info))) | 1196 | if (copy_from_user(&client_info, arg, sizeof(client_info))) |
1178 | return -EFAULT; | 1197 | return -EFAULT; |
@@ -1199,11 +1218,12 @@ static int snd_seq_ioctl_set_client_info(client_t * client, void __user *arg) | |||
1199 | /* | 1218 | /* |
1200 | * CREATE PORT ioctl() | 1219 | * CREATE PORT ioctl() |
1201 | */ | 1220 | */ |
1202 | static int snd_seq_ioctl_create_port(client_t * client, void __user *arg) | 1221 | static int snd_seq_ioctl_create_port(struct snd_seq_client *client, |
1222 | void __user *arg) | ||
1203 | { | 1223 | { |
1204 | client_port_t *port; | 1224 | struct snd_seq_client_port *port; |
1205 | snd_seq_port_info_t info; | 1225 | struct snd_seq_port_info info; |
1206 | snd_seq_port_callback_t *callback; | 1226 | struct snd_seq_port_callback *callback; |
1207 | 1227 | ||
1208 | if (copy_from_user(&info, arg, sizeof(info))) | 1228 | if (copy_from_user(&info, arg, sizeof(info))) |
1209 | return -EFAULT; | 1229 | return -EFAULT; |
@@ -1249,9 +1269,10 @@ static int snd_seq_ioctl_create_port(client_t * client, void __user *arg) | |||
1249 | /* | 1269 | /* |
1250 | * DELETE PORT ioctl() | 1270 | * DELETE PORT ioctl() |
1251 | */ | 1271 | */ |
1252 | static int snd_seq_ioctl_delete_port(client_t * client, void __user *arg) | 1272 | static int snd_seq_ioctl_delete_port(struct snd_seq_client *client, |
1273 | void __user *arg) | ||
1253 | { | 1274 | { |
1254 | snd_seq_port_info_t info; | 1275 | struct snd_seq_port_info info; |
1255 | int err; | 1276 | int err; |
1256 | 1277 | ||
1257 | /* set passed parameters */ | 1278 | /* set passed parameters */ |
@@ -1272,11 +1293,12 @@ static int snd_seq_ioctl_delete_port(client_t * client, void __user *arg) | |||
1272 | /* | 1293 | /* |
1273 | * GET_PORT_INFO ioctl() (on any client) | 1294 | * GET_PORT_INFO ioctl() (on any client) |
1274 | */ | 1295 | */ |
1275 | static int snd_seq_ioctl_get_port_info(client_t *client, void __user *arg) | 1296 | static int snd_seq_ioctl_get_port_info(struct snd_seq_client *client, |
1297 | void __user *arg) | ||
1276 | { | 1298 | { |
1277 | client_t *cptr; | 1299 | struct snd_seq_client *cptr; |
1278 | client_port_t *port; | 1300 | struct snd_seq_client_port *port; |
1279 | snd_seq_port_info_t info; | 1301 | struct snd_seq_port_info info; |
1280 | 1302 | ||
1281 | if (copy_from_user(&info, arg, sizeof(info))) | 1303 | if (copy_from_user(&info, arg, sizeof(info))) |
1282 | return -EFAULT; | 1304 | return -EFAULT; |
@@ -1304,10 +1326,11 @@ static int snd_seq_ioctl_get_port_info(client_t *client, void __user *arg) | |||
1304 | /* | 1326 | /* |
1305 | * SET_PORT_INFO ioctl() (only ports on this/own client) | 1327 | * SET_PORT_INFO ioctl() (only ports on this/own client) |
1306 | */ | 1328 | */ |
1307 | static int snd_seq_ioctl_set_port_info(client_t * client, void __user *arg) | 1329 | static int snd_seq_ioctl_set_port_info(struct snd_seq_client *client, |
1330 | void __user *arg) | ||
1308 | { | 1331 | { |
1309 | client_port_t *port; | 1332 | struct snd_seq_client_port *port; |
1310 | snd_seq_port_info_t info; | 1333 | struct snd_seq_port_info info; |
1311 | 1334 | ||
1312 | if (copy_from_user(&info, arg, sizeof(info))) | 1335 | if (copy_from_user(&info, arg, sizeof(info))) |
1313 | return -EFAULT; | 1336 | return -EFAULT; |
@@ -1329,9 +1352,10 @@ static int snd_seq_ioctl_set_port_info(client_t * client, void __user *arg) | |||
1329 | #define PERM_RD (SNDRV_SEQ_PORT_CAP_READ|SNDRV_SEQ_PORT_CAP_SUBS_READ) | 1352 | #define PERM_RD (SNDRV_SEQ_PORT_CAP_READ|SNDRV_SEQ_PORT_CAP_SUBS_READ) |
1330 | #define PERM_WR (SNDRV_SEQ_PORT_CAP_WRITE|SNDRV_SEQ_PORT_CAP_SUBS_WRITE) | 1353 | #define PERM_WR (SNDRV_SEQ_PORT_CAP_WRITE|SNDRV_SEQ_PORT_CAP_SUBS_WRITE) |
1331 | 1354 | ||
1332 | static int check_subscription_permission(client_t *client, client_port_t *sport, | 1355 | static int check_subscription_permission(struct snd_seq_client *client, |
1333 | client_port_t *dport, | 1356 | struct snd_seq_client_port *sport, |
1334 | snd_seq_port_subscribe_t *subs) | 1357 | struct snd_seq_client_port *dport, |
1358 | struct snd_seq_port_subscribe *subs) | ||
1335 | { | 1359 | { |
1336 | if (client->number != subs->sender.client && | 1360 | if (client->number != subs->sender.client && |
1337 | client->number != subs->dest.client) { | 1361 | client->number != subs->dest.client) { |
@@ -1363,9 +1387,10 @@ static int check_subscription_permission(client_t *client, client_port_t *sport, | |||
1363 | * client must be user client. | 1387 | * client must be user client. |
1364 | */ | 1388 | */ |
1365 | int snd_seq_client_notify_subscription(int client, int port, | 1389 | int snd_seq_client_notify_subscription(int client, int port, |
1366 | snd_seq_port_subscribe_t *info, int evtype) | 1390 | struct snd_seq_port_subscribe *info, |
1391 | int evtype) | ||
1367 | { | 1392 | { |
1368 | snd_seq_event_t event; | 1393 | struct snd_seq_event event; |
1369 | 1394 | ||
1370 | memset(&event, 0, sizeof(event)); | 1395 | memset(&event, 0, sizeof(event)); |
1371 | event.type = evtype; | 1396 | event.type = evtype; |
@@ -1379,12 +1404,13 @@ int snd_seq_client_notify_subscription(int client, int port, | |||
1379 | /* | 1404 | /* |
1380 | * add to port's subscription list IOCTL interface | 1405 | * add to port's subscription list IOCTL interface |
1381 | */ | 1406 | */ |
1382 | static int snd_seq_ioctl_subscribe_port(client_t * client, void __user *arg) | 1407 | static int snd_seq_ioctl_subscribe_port(struct snd_seq_client *client, |
1408 | void __user *arg) | ||
1383 | { | 1409 | { |
1384 | int result = -EINVAL; | 1410 | int result = -EINVAL; |
1385 | client_t *receiver = NULL, *sender = NULL; | 1411 | struct snd_seq_client *receiver = NULL, *sender = NULL; |
1386 | client_port_t *sport = NULL, *dport = NULL; | 1412 | struct snd_seq_client_port *sport = NULL, *dport = NULL; |
1387 | snd_seq_port_subscribe_t subs; | 1413 | struct snd_seq_port_subscribe subs; |
1388 | 1414 | ||
1389 | if (copy_from_user(&subs, arg, sizeof(subs))) | 1415 | if (copy_from_user(&subs, arg, sizeof(subs))) |
1390 | return -EFAULT; | 1416 | return -EFAULT; |
@@ -1423,12 +1449,13 @@ static int snd_seq_ioctl_subscribe_port(client_t * client, void __user *arg) | |||
1423 | /* | 1449 | /* |
1424 | * remove from port's subscription list | 1450 | * remove from port's subscription list |
1425 | */ | 1451 | */ |
1426 | static int snd_seq_ioctl_unsubscribe_port(client_t * client, void __user *arg) | 1452 | static int snd_seq_ioctl_unsubscribe_port(struct snd_seq_client *client, |
1453 | void __user *arg) | ||
1427 | { | 1454 | { |
1428 | int result = -ENXIO; | 1455 | int result = -ENXIO; |
1429 | client_t *receiver = NULL, *sender = NULL; | 1456 | struct snd_seq_client *receiver = NULL, *sender = NULL; |
1430 | client_port_t *sport = NULL, *dport = NULL; | 1457 | struct snd_seq_client_port *sport = NULL, *dport = NULL; |
1431 | snd_seq_port_subscribe_t subs; | 1458 | struct snd_seq_port_subscribe subs; |
1432 | 1459 | ||
1433 | if (copy_from_user(&subs, arg, sizeof(subs))) | 1460 | if (copy_from_user(&subs, arg, sizeof(subs))) |
1434 | return -EFAULT; | 1461 | return -EFAULT; |
@@ -1464,11 +1491,12 @@ static int snd_seq_ioctl_unsubscribe_port(client_t * client, void __user *arg) | |||
1464 | 1491 | ||
1465 | 1492 | ||
1466 | /* CREATE_QUEUE ioctl() */ | 1493 | /* CREATE_QUEUE ioctl() */ |
1467 | static int snd_seq_ioctl_create_queue(client_t *client, void __user *arg) | 1494 | static int snd_seq_ioctl_create_queue(struct snd_seq_client *client, |
1495 | void __user *arg) | ||
1468 | { | 1496 | { |
1469 | snd_seq_queue_info_t info; | 1497 | struct snd_seq_queue_info info; |
1470 | int result; | 1498 | int result; |
1471 | queue_t *q; | 1499 | struct snd_seq_queue *q; |
1472 | 1500 | ||
1473 | if (copy_from_user(&info, arg, sizeof(info))) | 1501 | if (copy_from_user(&info, arg, sizeof(info))) |
1474 | return -EFAULT; | 1502 | return -EFAULT; |
@@ -1498,9 +1526,10 @@ static int snd_seq_ioctl_create_queue(client_t *client, void __user *arg) | |||
1498 | } | 1526 | } |
1499 | 1527 | ||
1500 | /* DELETE_QUEUE ioctl() */ | 1528 | /* DELETE_QUEUE ioctl() */ |
1501 | static int snd_seq_ioctl_delete_queue(client_t *client, void __user *arg) | 1529 | static int snd_seq_ioctl_delete_queue(struct snd_seq_client *client, |
1530 | void __user *arg) | ||
1502 | { | 1531 | { |
1503 | snd_seq_queue_info_t info; | 1532 | struct snd_seq_queue_info info; |
1504 | 1533 | ||
1505 | if (copy_from_user(&info, arg, sizeof(info))) | 1534 | if (copy_from_user(&info, arg, sizeof(info))) |
1506 | return -EFAULT; | 1535 | return -EFAULT; |
@@ -1509,10 +1538,11 @@ static int snd_seq_ioctl_delete_queue(client_t *client, void __user *arg) | |||
1509 | } | 1538 | } |
1510 | 1539 | ||
1511 | /* GET_QUEUE_INFO ioctl() */ | 1540 | /* GET_QUEUE_INFO ioctl() */ |
1512 | static int snd_seq_ioctl_get_queue_info(client_t *client, void __user *arg) | 1541 | static int snd_seq_ioctl_get_queue_info(struct snd_seq_client *client, |
1542 | void __user *arg) | ||
1513 | { | 1543 | { |
1514 | snd_seq_queue_info_t info; | 1544 | struct snd_seq_queue_info info; |
1515 | queue_t *q; | 1545 | struct snd_seq_queue *q; |
1516 | 1546 | ||
1517 | if (copy_from_user(&info, arg, sizeof(info))) | 1547 | if (copy_from_user(&info, arg, sizeof(info))) |
1518 | return -EFAULT; | 1548 | return -EFAULT; |
@@ -1535,10 +1565,11 @@ static int snd_seq_ioctl_get_queue_info(client_t *client, void __user *arg) | |||
1535 | } | 1565 | } |
1536 | 1566 | ||
1537 | /* SET_QUEUE_INFO ioctl() */ | 1567 | /* SET_QUEUE_INFO ioctl() */ |
1538 | static int snd_seq_ioctl_set_queue_info(client_t *client, void __user *arg) | 1568 | static int snd_seq_ioctl_set_queue_info(struct snd_seq_client *client, |
1569 | void __user *arg) | ||
1539 | { | 1570 | { |
1540 | snd_seq_queue_info_t info; | 1571 | struct snd_seq_queue_info info; |
1541 | queue_t *q; | 1572 | struct snd_seq_queue *q; |
1542 | 1573 | ||
1543 | if (copy_from_user(&info, arg, sizeof(info))) | 1574 | if (copy_from_user(&info, arg, sizeof(info))) |
1544 | return -EFAULT; | 1575 | return -EFAULT; |
@@ -1570,10 +1601,10 @@ static int snd_seq_ioctl_set_queue_info(client_t *client, void __user *arg) | |||
1570 | } | 1601 | } |
1571 | 1602 | ||
1572 | /* GET_NAMED_QUEUE ioctl() */ | 1603 | /* GET_NAMED_QUEUE ioctl() */ |
1573 | static int snd_seq_ioctl_get_named_queue(client_t *client, void __user *arg) | 1604 | static int snd_seq_ioctl_get_named_queue(struct snd_seq_client *client, void __user *arg) |
1574 | { | 1605 | { |
1575 | snd_seq_queue_info_t info; | 1606 | struct snd_seq_queue_info info; |
1576 | queue_t *q; | 1607 | struct snd_seq_queue *q; |
1577 | 1608 | ||
1578 | if (copy_from_user(&info, arg, sizeof(info))) | 1609 | if (copy_from_user(&info, arg, sizeof(info))) |
1579 | return -EFAULT; | 1610 | return -EFAULT; |
@@ -1593,11 +1624,12 @@ static int snd_seq_ioctl_get_named_queue(client_t *client, void __user *arg) | |||
1593 | } | 1624 | } |
1594 | 1625 | ||
1595 | /* GET_QUEUE_STATUS ioctl() */ | 1626 | /* GET_QUEUE_STATUS ioctl() */ |
1596 | static int snd_seq_ioctl_get_queue_status(client_t * client, void __user *arg) | 1627 | static int snd_seq_ioctl_get_queue_status(struct snd_seq_client *client, |
1628 | void __user *arg) | ||
1597 | { | 1629 | { |
1598 | snd_seq_queue_status_t status; | 1630 | struct snd_seq_queue_status status; |
1599 | queue_t *queue; | 1631 | struct snd_seq_queue *queue; |
1600 | seq_timer_t *tmr; | 1632 | struct snd_seq_timer *tmr; |
1601 | 1633 | ||
1602 | if (copy_from_user(&status, arg, sizeof(status))) | 1634 | if (copy_from_user(&status, arg, sizeof(status))) |
1603 | return -EFAULT; | 1635 | return -EFAULT; |
@@ -1626,11 +1658,12 @@ static int snd_seq_ioctl_get_queue_status(client_t * client, void __user *arg) | |||
1626 | 1658 | ||
1627 | 1659 | ||
1628 | /* GET_QUEUE_TEMPO ioctl() */ | 1660 | /* GET_QUEUE_TEMPO ioctl() */ |
1629 | static int snd_seq_ioctl_get_queue_tempo(client_t * client, void __user *arg) | 1661 | static int snd_seq_ioctl_get_queue_tempo(struct snd_seq_client *client, |
1662 | void __user *arg) | ||
1630 | { | 1663 | { |
1631 | snd_seq_queue_tempo_t tempo; | 1664 | struct snd_seq_queue_tempo tempo; |
1632 | queue_t *queue; | 1665 | struct snd_seq_queue *queue; |
1633 | seq_timer_t *tmr; | 1666 | struct snd_seq_timer *tmr; |
1634 | 1667 | ||
1635 | if (copy_from_user(&tempo, arg, sizeof(tempo))) | 1668 | if (copy_from_user(&tempo, arg, sizeof(tempo))) |
1636 | return -EFAULT; | 1669 | return -EFAULT; |
@@ -1656,17 +1689,18 @@ static int snd_seq_ioctl_get_queue_tempo(client_t * client, void __user *arg) | |||
1656 | 1689 | ||
1657 | 1690 | ||
1658 | /* SET_QUEUE_TEMPO ioctl() */ | 1691 | /* SET_QUEUE_TEMPO ioctl() */ |
1659 | int snd_seq_set_queue_tempo(int client, snd_seq_queue_tempo_t *tempo) | 1692 | int snd_seq_set_queue_tempo(int client, struct snd_seq_queue_tempo *tempo) |
1660 | { | 1693 | { |
1661 | if (!snd_seq_queue_check_access(tempo->queue, client)) | 1694 | if (!snd_seq_queue_check_access(tempo->queue, client)) |
1662 | return -EPERM; | 1695 | return -EPERM; |
1663 | return snd_seq_queue_timer_set_tempo(tempo->queue, client, tempo); | 1696 | return snd_seq_queue_timer_set_tempo(tempo->queue, client, tempo); |
1664 | } | 1697 | } |
1665 | 1698 | ||
1666 | static int snd_seq_ioctl_set_queue_tempo(client_t * client, void __user *arg) | 1699 | static int snd_seq_ioctl_set_queue_tempo(struct snd_seq_client *client, |
1700 | void __user *arg) | ||
1667 | { | 1701 | { |
1668 | int result; | 1702 | int result; |
1669 | snd_seq_queue_tempo_t tempo; | 1703 | struct snd_seq_queue_tempo tempo; |
1670 | 1704 | ||
1671 | if (copy_from_user(&tempo, arg, sizeof(tempo))) | 1705 | if (copy_from_user(&tempo, arg, sizeof(tempo))) |
1672 | return -EFAULT; | 1706 | return -EFAULT; |
@@ -1677,11 +1711,12 @@ static int snd_seq_ioctl_set_queue_tempo(client_t * client, void __user *arg) | |||
1677 | 1711 | ||
1678 | 1712 | ||
1679 | /* GET_QUEUE_TIMER ioctl() */ | 1713 | /* GET_QUEUE_TIMER ioctl() */ |
1680 | static int snd_seq_ioctl_get_queue_timer(client_t * client, void __user *arg) | 1714 | static int snd_seq_ioctl_get_queue_timer(struct snd_seq_client *client, |
1715 | void __user *arg) | ||
1681 | { | 1716 | { |
1682 | snd_seq_queue_timer_t timer; | 1717 | struct snd_seq_queue_timer timer; |
1683 | queue_t *queue; | 1718 | struct snd_seq_queue *queue; |
1684 | seq_timer_t *tmr; | 1719 | struct snd_seq_timer *tmr; |
1685 | 1720 | ||
1686 | if (copy_from_user(&timer, arg, sizeof(timer))) | 1721 | if (copy_from_user(&timer, arg, sizeof(timer))) |
1687 | return -EFAULT; | 1722 | return -EFAULT; |
@@ -1713,10 +1748,11 @@ static int snd_seq_ioctl_get_queue_timer(client_t * client, void __user *arg) | |||
1713 | 1748 | ||
1714 | 1749 | ||
1715 | /* SET_QUEUE_TIMER ioctl() */ | 1750 | /* SET_QUEUE_TIMER ioctl() */ |
1716 | static int snd_seq_ioctl_set_queue_timer(client_t * client, void __user *arg) | 1751 | static int snd_seq_ioctl_set_queue_timer(struct snd_seq_client *client, |
1752 | void __user *arg) | ||
1717 | { | 1753 | { |
1718 | int result = 0; | 1754 | int result = 0; |
1719 | snd_seq_queue_timer_t timer; | 1755 | struct snd_seq_queue_timer timer; |
1720 | 1756 | ||
1721 | if (copy_from_user(&timer, arg, sizeof(timer))) | 1757 | if (copy_from_user(&timer, arg, sizeof(timer))) |
1722 | return -EFAULT; | 1758 | return -EFAULT; |
@@ -1725,8 +1761,8 @@ static int snd_seq_ioctl_set_queue_timer(client_t * client, void __user *arg) | |||
1725 | return -EINVAL; | 1761 | return -EINVAL; |
1726 | 1762 | ||
1727 | if (snd_seq_queue_check_access(timer.queue, client->number)) { | 1763 | if (snd_seq_queue_check_access(timer.queue, client->number)) { |
1728 | queue_t *q; | 1764 | struct snd_seq_queue *q; |
1729 | seq_timer_t *tmr; | 1765 | struct snd_seq_timer *tmr; |
1730 | 1766 | ||
1731 | q = queueptr(timer.queue); | 1767 | q = queueptr(timer.queue); |
1732 | if (q == NULL) | 1768 | if (q == NULL) |
@@ -1754,9 +1790,10 @@ static int snd_seq_ioctl_set_queue_timer(client_t * client, void __user *arg) | |||
1754 | 1790 | ||
1755 | 1791 | ||
1756 | /* GET_QUEUE_CLIENT ioctl() */ | 1792 | /* GET_QUEUE_CLIENT ioctl() */ |
1757 | static int snd_seq_ioctl_get_queue_client(client_t * client, void __user *arg) | 1793 | static int snd_seq_ioctl_get_queue_client(struct snd_seq_client *client, |
1794 | void __user *arg) | ||
1758 | { | 1795 | { |
1759 | snd_seq_queue_client_t info; | 1796 | struct snd_seq_queue_client info; |
1760 | int used; | 1797 | int used; |
1761 | 1798 | ||
1762 | if (copy_from_user(&info, arg, sizeof(info))) | 1799 | if (copy_from_user(&info, arg, sizeof(info))) |
@@ -1775,10 +1812,11 @@ static int snd_seq_ioctl_get_queue_client(client_t * client, void __user *arg) | |||
1775 | 1812 | ||
1776 | 1813 | ||
1777 | /* SET_QUEUE_CLIENT ioctl() */ | 1814 | /* SET_QUEUE_CLIENT ioctl() */ |
1778 | static int snd_seq_ioctl_set_queue_client(client_t * client, void __user *arg) | 1815 | static int snd_seq_ioctl_set_queue_client(struct snd_seq_client *client, |
1816 | void __user *arg) | ||
1779 | { | 1817 | { |
1780 | int err; | 1818 | int err; |
1781 | snd_seq_queue_client_t info; | 1819 | struct snd_seq_queue_client info; |
1782 | 1820 | ||
1783 | if (copy_from_user(&info, arg, sizeof(info))) | 1821 | if (copy_from_user(&info, arg, sizeof(info))) |
1784 | return -EFAULT; | 1822 | return -EFAULT; |
@@ -1794,10 +1832,11 @@ static int snd_seq_ioctl_set_queue_client(client_t * client, void __user *arg) | |||
1794 | 1832 | ||
1795 | 1833 | ||
1796 | /* GET_CLIENT_POOL ioctl() */ | 1834 | /* GET_CLIENT_POOL ioctl() */ |
1797 | static int snd_seq_ioctl_get_client_pool(client_t * client, void __user *arg) | 1835 | static int snd_seq_ioctl_get_client_pool(struct snd_seq_client *client, |
1836 | void __user *arg) | ||
1798 | { | 1837 | { |
1799 | snd_seq_client_pool_t info; | 1838 | struct snd_seq_client_pool info; |
1800 | client_t *cptr; | 1839 | struct snd_seq_client *cptr; |
1801 | 1840 | ||
1802 | if (copy_from_user(&info, arg, sizeof(info))) | 1841 | if (copy_from_user(&info, arg, sizeof(info))) |
1803 | return -EFAULT; | 1842 | return -EFAULT; |
@@ -1828,9 +1867,10 @@ static int snd_seq_ioctl_get_client_pool(client_t * client, void __user *arg) | |||
1828 | } | 1867 | } |
1829 | 1868 | ||
1830 | /* SET_CLIENT_POOL ioctl() */ | 1869 | /* SET_CLIENT_POOL ioctl() */ |
1831 | static int snd_seq_ioctl_set_client_pool(client_t * client, void __user *arg) | 1870 | static int snd_seq_ioctl_set_client_pool(struct snd_seq_client *client, |
1871 | void __user *arg) | ||
1832 | { | 1872 | { |
1833 | snd_seq_client_pool_t info; | 1873 | struct snd_seq_client_pool info; |
1834 | int rc; | 1874 | int rc; |
1835 | 1875 | ||
1836 | if (copy_from_user(&info, arg, sizeof(info))) | 1876 | if (copy_from_user(&info, arg, sizeof(info))) |
@@ -1872,9 +1912,10 @@ static int snd_seq_ioctl_set_client_pool(client_t * client, void __user *arg) | |||
1872 | 1912 | ||
1873 | 1913 | ||
1874 | /* REMOVE_EVENTS ioctl() */ | 1914 | /* REMOVE_EVENTS ioctl() */ |
1875 | static int snd_seq_ioctl_remove_events(client_t * client, void __user *arg) | 1915 | static int snd_seq_ioctl_remove_events(struct snd_seq_client *client, |
1916 | void __user *arg) | ||
1876 | { | 1917 | { |
1877 | snd_seq_remove_events_t info; | 1918 | struct snd_seq_remove_events info; |
1878 | 1919 | ||
1879 | if (copy_from_user(&info, arg, sizeof(info))) | 1920 | if (copy_from_user(&info, arg, sizeof(info))) |
1880 | return -EFAULT; | 1921 | return -EFAULT; |
@@ -1901,13 +1942,14 @@ static int snd_seq_ioctl_remove_events(client_t * client, void __user *arg) | |||
1901 | /* | 1942 | /* |
1902 | * get subscription info | 1943 | * get subscription info |
1903 | */ | 1944 | */ |
1904 | static int snd_seq_ioctl_get_subscription(client_t *client, void __user *arg) | 1945 | static int snd_seq_ioctl_get_subscription(struct snd_seq_client *client, |
1946 | void __user *arg) | ||
1905 | { | 1947 | { |
1906 | int result; | 1948 | int result; |
1907 | client_t *sender = NULL; | 1949 | struct snd_seq_client *sender = NULL; |
1908 | client_port_t *sport = NULL; | 1950 | struct snd_seq_client_port *sport = NULL; |
1909 | snd_seq_port_subscribe_t subs; | 1951 | struct snd_seq_port_subscribe subs; |
1910 | subscribers_t *p; | 1952 | struct snd_seq_subscribers *p; |
1911 | 1953 | ||
1912 | if (copy_from_user(&subs, arg, sizeof(subs))) | 1954 | if (copy_from_user(&subs, arg, sizeof(subs))) |
1913 | return -EFAULT; | 1955 | return -EFAULT; |
@@ -1940,13 +1982,14 @@ static int snd_seq_ioctl_get_subscription(client_t *client, void __user *arg) | |||
1940 | /* | 1982 | /* |
1941 | * get subscription info - check only its presence | 1983 | * get subscription info - check only its presence |
1942 | */ | 1984 | */ |
1943 | static int snd_seq_ioctl_query_subs(client_t *client, void __user *arg) | 1985 | static int snd_seq_ioctl_query_subs(struct snd_seq_client *client, |
1986 | void __user *arg) | ||
1944 | { | 1987 | { |
1945 | int result = -ENXIO; | 1988 | int result = -ENXIO; |
1946 | client_t *cptr = NULL; | 1989 | struct snd_seq_client *cptr = NULL; |
1947 | client_port_t *port = NULL; | 1990 | struct snd_seq_client_port *port = NULL; |
1948 | snd_seq_query_subs_t subs; | 1991 | struct snd_seq_query_subs subs; |
1949 | port_subs_info_t *group; | 1992 | struct snd_seq_port_subs_info *group; |
1950 | struct list_head *p; | 1993 | struct list_head *p; |
1951 | int i; | 1994 | int i; |
1952 | 1995 | ||
@@ -1977,12 +2020,12 @@ static int snd_seq_ioctl_query_subs(client_t *client, void __user *arg) | |||
1977 | list_for_each(p, &group->list_head) { | 2020 | list_for_each(p, &group->list_head) { |
1978 | if (i++ == subs.index) { | 2021 | if (i++ == subs.index) { |
1979 | /* found! */ | 2022 | /* found! */ |
1980 | subscribers_t *s; | 2023 | struct snd_seq_subscribers *s; |
1981 | if (subs.type == SNDRV_SEQ_QUERY_SUBS_READ) { | 2024 | if (subs.type == SNDRV_SEQ_QUERY_SUBS_READ) { |
1982 | s = list_entry(p, subscribers_t, src_list); | 2025 | s = list_entry(p, struct snd_seq_subscribers, src_list); |
1983 | subs.addr = s->info.dest; | 2026 | subs.addr = s->info.dest; |
1984 | } else { | 2027 | } else { |
1985 | s = list_entry(p, subscribers_t, dest_list); | 2028 | s = list_entry(p, struct snd_seq_subscribers, dest_list); |
1986 | subs.addr = s->info.sender; | 2029 | subs.addr = s->info.sender; |
1987 | } | 2030 | } |
1988 | subs.flags = s->info.flags; | 2031 | subs.flags = s->info.flags; |
@@ -2009,10 +2052,11 @@ static int snd_seq_ioctl_query_subs(client_t *client, void __user *arg) | |||
2009 | /* | 2052 | /* |
2010 | * query next client | 2053 | * query next client |
2011 | */ | 2054 | */ |
2012 | static int snd_seq_ioctl_query_next_client(client_t *client, void __user *arg) | 2055 | static int snd_seq_ioctl_query_next_client(struct snd_seq_client *client, |
2056 | void __user *arg) | ||
2013 | { | 2057 | { |
2014 | client_t *cptr = NULL; | 2058 | struct snd_seq_client *cptr = NULL; |
2015 | snd_seq_client_info_t info; | 2059 | struct snd_seq_client_info info; |
2016 | 2060 | ||
2017 | if (copy_from_user(&info, arg, sizeof(info))) | 2061 | if (copy_from_user(&info, arg, sizeof(info))) |
2018 | return -EFAULT; | 2062 | return -EFAULT; |
@@ -2040,11 +2084,12 @@ static int snd_seq_ioctl_query_next_client(client_t *client, void __user *arg) | |||
2040 | /* | 2084 | /* |
2041 | * query next port | 2085 | * query next port |
2042 | */ | 2086 | */ |
2043 | static int snd_seq_ioctl_query_next_port(client_t *client, void __user *arg) | 2087 | static int snd_seq_ioctl_query_next_port(struct snd_seq_client *client, |
2088 | void __user *arg) | ||
2044 | { | 2089 | { |
2045 | client_t *cptr; | 2090 | struct snd_seq_client *cptr; |
2046 | client_port_t *port = NULL; | 2091 | struct snd_seq_client_port *port = NULL; |
2047 | snd_seq_port_info_t info; | 2092 | struct snd_seq_port_info info; |
2048 | 2093 | ||
2049 | if (copy_from_user(&info, arg, sizeof(info))) | 2094 | if (copy_from_user(&info, arg, sizeof(info))) |
2050 | return -EFAULT; | 2095 | return -EFAULT; |
@@ -2075,7 +2120,7 @@ static int snd_seq_ioctl_query_next_port(client_t *client, void __user *arg) | |||
2075 | 2120 | ||
2076 | static struct seq_ioctl_table { | 2121 | static struct seq_ioctl_table { |
2077 | unsigned int cmd; | 2122 | unsigned int cmd; |
2078 | int (*func)(client_t *client, void __user * arg); | 2123 | int (*func)(struct snd_seq_client *client, void __user * arg); |
2079 | } ioctl_tables[] = { | 2124 | } ioctl_tables[] = { |
2080 | { SNDRV_SEQ_IOCTL_SYSTEM_INFO, snd_seq_ioctl_system_info }, | 2125 | { SNDRV_SEQ_IOCTL_SYSTEM_INFO, snd_seq_ioctl_system_info }, |
2081 | { SNDRV_SEQ_IOCTL_RUNNING_MODE, snd_seq_ioctl_running_mode }, | 2126 | { SNDRV_SEQ_IOCTL_RUNNING_MODE, snd_seq_ioctl_running_mode }, |
@@ -2109,7 +2154,8 @@ static struct seq_ioctl_table { | |||
2109 | { 0, NULL }, | 2154 | { 0, NULL }, |
2110 | }; | 2155 | }; |
2111 | 2156 | ||
2112 | static int snd_seq_do_ioctl(client_t *client, unsigned int cmd, void __user *arg) | 2157 | static int snd_seq_do_ioctl(struct snd_seq_client *client, unsigned int cmd, |
2158 | void __user *arg) | ||
2113 | { | 2159 | { |
2114 | struct seq_ioctl_table *p; | 2160 | struct seq_ioctl_table *p; |
2115 | 2161 | ||
@@ -2136,7 +2182,7 @@ static int snd_seq_do_ioctl(client_t *client, unsigned int cmd, void __user *arg | |||
2136 | 2182 | ||
2137 | static long snd_seq_ioctl(struct file *file, unsigned int cmd, unsigned long arg) | 2183 | static long snd_seq_ioctl(struct file *file, unsigned int cmd, unsigned long arg) |
2138 | { | 2184 | { |
2139 | client_t *client = (client_t *) file->private_data; | 2185 | struct snd_seq_client *client = file->private_data; |
2140 | 2186 | ||
2141 | snd_assert(client != NULL, return -ENXIO); | 2187 | snd_assert(client != NULL, return -ENXIO); |
2142 | 2188 | ||
@@ -2153,9 +2199,10 @@ static long snd_seq_ioctl(struct file *file, unsigned int cmd, unsigned long arg | |||
2153 | 2199 | ||
2154 | 2200 | ||
2155 | /* exported to kernel modules */ | 2201 | /* exported to kernel modules */ |
2156 | int snd_seq_create_kernel_client(snd_card_t *card, int client_index, snd_seq_client_callback_t * callback) | 2202 | int snd_seq_create_kernel_client(struct snd_card *card, int client_index, |
2203 | struct snd_seq_client_callback *callback) | ||
2157 | { | 2204 | { |
2158 | client_t *client; | 2205 | struct snd_seq_client *client; |
2159 | 2206 | ||
2160 | snd_assert(! in_interrupt(), return -EBUSY); | 2207 | snd_assert(! in_interrupt(), return -EBUSY); |
2161 | 2208 | ||
@@ -2199,7 +2246,7 @@ int snd_seq_create_kernel_client(snd_card_t *card, int client_index, snd_seq_cli | |||
2199 | /* exported to kernel modules */ | 2246 | /* exported to kernel modules */ |
2200 | int snd_seq_delete_kernel_client(int client) | 2247 | int snd_seq_delete_kernel_client(int client) |
2201 | { | 2248 | { |
2202 | client_t *ptr; | 2249 | struct snd_seq_client *ptr; |
2203 | 2250 | ||
2204 | snd_assert(! in_interrupt(), return -EBUSY); | 2251 | snd_assert(! in_interrupt(), return -EBUSY); |
2205 | 2252 | ||
@@ -2216,11 +2263,11 @@ int snd_seq_delete_kernel_client(int client) | |||
2216 | /* skeleton to enqueue event, called from snd_seq_kernel_client_enqueue | 2263 | /* skeleton to enqueue event, called from snd_seq_kernel_client_enqueue |
2217 | * and snd_seq_kernel_client_enqueue_blocking | 2264 | * and snd_seq_kernel_client_enqueue_blocking |
2218 | */ | 2265 | */ |
2219 | static int kernel_client_enqueue(int client, snd_seq_event_t *ev, | 2266 | static int kernel_client_enqueue(int client, struct snd_seq_event *ev, |
2220 | struct file *file, int blocking, | 2267 | struct file *file, int blocking, |
2221 | int atomic, int hop) | 2268 | int atomic, int hop) |
2222 | { | 2269 | { |
2223 | client_t *cptr; | 2270 | struct snd_seq_client *cptr; |
2224 | int result; | 2271 | int result; |
2225 | 2272 | ||
2226 | snd_assert(ev != NULL, return -EINVAL); | 2273 | snd_assert(ev != NULL, return -EINVAL); |
@@ -2254,7 +2301,7 @@ static int kernel_client_enqueue(int client, snd_seq_event_t *ev, | |||
2254 | * | 2301 | * |
2255 | * RETURN VALUE: zero if succeed, negative if error | 2302 | * RETURN VALUE: zero if succeed, negative if error |
2256 | */ | 2303 | */ |
2257 | int snd_seq_kernel_client_enqueue(int client, snd_seq_event_t * ev, | 2304 | int snd_seq_kernel_client_enqueue(int client, struct snd_seq_event * ev, |
2258 | int atomic, int hop) | 2305 | int atomic, int hop) |
2259 | { | 2306 | { |
2260 | return kernel_client_enqueue(client, ev, NULL, 0, atomic, hop); | 2307 | return kernel_client_enqueue(client, ev, NULL, 0, atomic, hop); |
@@ -2265,7 +2312,7 @@ int snd_seq_kernel_client_enqueue(int client, snd_seq_event_t * ev, | |||
2265 | * | 2312 | * |
2266 | * RETURN VALUE: zero if succeed, negative if error | 2313 | * RETURN VALUE: zero if succeed, negative if error |
2267 | */ | 2314 | */ |
2268 | int snd_seq_kernel_client_enqueue_blocking(int client, snd_seq_event_t * ev, | 2315 | int snd_seq_kernel_client_enqueue_blocking(int client, struct snd_seq_event * ev, |
2269 | struct file *file, | 2316 | struct file *file, |
2270 | int atomic, int hop) | 2317 | int atomic, int hop) |
2271 | { | 2318 | { |
@@ -2280,10 +2327,10 @@ int snd_seq_kernel_client_enqueue_blocking(int client, snd_seq_event_t * ev, | |||
2280 | * RETURN VALUE: negative = delivery failed, | 2327 | * RETURN VALUE: negative = delivery failed, |
2281 | * zero, or positive: the number of delivered events | 2328 | * zero, or positive: the number of delivered events |
2282 | */ | 2329 | */ |
2283 | int snd_seq_kernel_client_dispatch(int client, snd_seq_event_t * ev, | 2330 | int snd_seq_kernel_client_dispatch(int client, struct snd_seq_event * ev, |
2284 | int atomic, int hop) | 2331 | int atomic, int hop) |
2285 | { | 2332 | { |
2286 | client_t *cptr; | 2333 | struct snd_seq_client *cptr; |
2287 | int result; | 2334 | int result; |
2288 | 2335 | ||
2289 | snd_assert(ev != NULL, return -EINVAL); | 2336 | snd_assert(ev != NULL, return -EINVAL); |
@@ -2315,7 +2362,7 @@ int snd_seq_kernel_client_dispatch(int client, snd_seq_event_t * ev, | |||
2315 | */ | 2362 | */ |
2316 | int snd_seq_kernel_client_ctl(int clientid, unsigned int cmd, void *arg) | 2363 | int snd_seq_kernel_client_ctl(int clientid, unsigned int cmd, void *arg) |
2317 | { | 2364 | { |
2318 | client_t *client; | 2365 | struct snd_seq_client *client; |
2319 | mm_segment_t fs; | 2366 | mm_segment_t fs; |
2320 | int result; | 2367 | int result; |
2321 | 2368 | ||
@@ -2332,7 +2379,7 @@ int snd_seq_kernel_client_ctl(int clientid, unsigned int cmd, void *arg) | |||
2332 | /* exported (for OSS emulator) */ | 2379 | /* exported (for OSS emulator) */ |
2333 | int snd_seq_kernel_client_write_poll(int clientid, struct file *file, poll_table *wait) | 2380 | int snd_seq_kernel_client_write_poll(int clientid, struct file *file, poll_table *wait) |
2334 | { | 2381 | { |
2335 | client_t *client; | 2382 | struct snd_seq_client *client; |
2336 | 2383 | ||
2337 | client = clientptr(clientid); | 2384 | client = clientptr(clientid); |
2338 | if (client == NULL) | 2385 | if (client == NULL) |
@@ -2350,10 +2397,12 @@ int snd_seq_kernel_client_write_poll(int clientid, struct file *file, poll_table | |||
2350 | /* | 2397 | /* |
2351 | * /proc interface | 2398 | * /proc interface |
2352 | */ | 2399 | */ |
2353 | static void snd_seq_info_dump_subscribers(snd_info_buffer_t *buffer, port_subs_info_t *group, int is_src, char *msg) | 2400 | static void snd_seq_info_dump_subscribers(struct snd_info_buffer *buffer, |
2401 | struct snd_seq_port_subs_info *group, | ||
2402 | int is_src, char *msg) | ||
2354 | { | 2403 | { |
2355 | struct list_head *p; | 2404 | struct list_head *p; |
2356 | subscribers_t *s; | 2405 | struct snd_seq_subscribers *s; |
2357 | int count = 0; | 2406 | int count = 0; |
2358 | 2407 | ||
2359 | down_read(&group->list_mutex); | 2408 | down_read(&group->list_mutex); |
@@ -2364,9 +2413,9 @@ static void snd_seq_info_dump_subscribers(snd_info_buffer_t *buffer, port_subs_i | |||
2364 | snd_iprintf(buffer, msg); | 2413 | snd_iprintf(buffer, msg); |
2365 | list_for_each(p, &group->list_head) { | 2414 | list_for_each(p, &group->list_head) { |
2366 | if (is_src) | 2415 | if (is_src) |
2367 | s = list_entry(p, subscribers_t, src_list); | 2416 | s = list_entry(p, struct snd_seq_subscribers, src_list); |
2368 | else | 2417 | else |
2369 | s = list_entry(p, subscribers_t, dest_list); | 2418 | s = list_entry(p, struct snd_seq_subscribers, dest_list); |
2370 | if (count++) | 2419 | if (count++) |
2371 | snd_iprintf(buffer, ", "); | 2420 | snd_iprintf(buffer, ", "); |
2372 | snd_iprintf(buffer, "%d:%d", | 2421 | snd_iprintf(buffer, "%d:%d", |
@@ -2387,13 +2436,14 @@ static void snd_seq_info_dump_subscribers(snd_info_buffer_t *buffer, port_subs_i | |||
2387 | 2436 | ||
2388 | #define FLAG_PERM_DUPLEX(perm) ((perm) & SNDRV_SEQ_PORT_CAP_DUPLEX ? 'X' : '-') | 2437 | #define FLAG_PERM_DUPLEX(perm) ((perm) & SNDRV_SEQ_PORT_CAP_DUPLEX ? 'X' : '-') |
2389 | 2438 | ||
2390 | static void snd_seq_info_dump_ports(snd_info_buffer_t *buffer, client_t *client) | 2439 | static void snd_seq_info_dump_ports(struct snd_info_buffer *buffer, |
2440 | struct snd_seq_client *client) | ||
2391 | { | 2441 | { |
2392 | struct list_head *l; | 2442 | struct list_head *l; |
2393 | 2443 | ||
2394 | down(&client->ports_mutex); | 2444 | down(&client->ports_mutex); |
2395 | list_for_each(l, &client->ports_list_head) { | 2445 | list_for_each(l, &client->ports_list_head) { |
2396 | client_port_t *p = list_entry(l, client_port_t, list); | 2446 | struct snd_seq_client_port *p = list_entry(l, struct snd_seq_client_port, list); |
2397 | snd_iprintf(buffer, " Port %3d : \"%s\" (%c%c%c%c)\n", | 2447 | snd_iprintf(buffer, " Port %3d : \"%s\" (%c%c%c%c)\n", |
2398 | p->addr.port, p->name, | 2448 | p->addr.port, p->name, |
2399 | FLAG_PERM_RD(p->capability), | 2449 | FLAG_PERM_RD(p->capability), |
@@ -2407,13 +2457,15 @@ static void snd_seq_info_dump_ports(snd_info_buffer_t *buffer, client_t *client) | |||
2407 | } | 2457 | } |
2408 | 2458 | ||
2409 | 2459 | ||
2460 | void snd_seq_info_pool(struct snd_info_buffer *buffer, | ||
2461 | struct snd_seq_pool *pool, char *space); | ||
2462 | |||
2410 | /* exported to seq_info.c */ | 2463 | /* exported to seq_info.c */ |
2411 | void snd_seq_info_clients_read(snd_info_entry_t *entry, | 2464 | void snd_seq_info_clients_read(struct snd_info_entry *entry, |
2412 | snd_info_buffer_t * buffer) | 2465 | struct snd_info_buffer *buffer) |
2413 | { | 2466 | { |
2414 | extern void snd_seq_info_pool(snd_info_buffer_t * buffer, pool_t * pool, char *space); | ||
2415 | int c; | 2467 | int c; |
2416 | client_t *client; | 2468 | struct snd_seq_client *client; |
2417 | 2469 | ||
2418 | snd_iprintf(buffer, "Client info\n"); | 2470 | snd_iprintf(buffer, "Client info\n"); |
2419 | snd_iprintf(buffer, " cur clients : %d\n", client_usage.cur); | 2471 | snd_iprintf(buffer, " cur clients : %d\n", client_usage.cur); |
@@ -2468,7 +2520,7 @@ static struct file_operations snd_seq_f_ops = | |||
2468 | .compat_ioctl = snd_seq_ioctl_compat, | 2520 | .compat_ioctl = snd_seq_ioctl_compat, |
2469 | }; | 2521 | }; |
2470 | 2522 | ||
2471 | static snd_minor_t snd_seq_reg = | 2523 | static struct snd_minor snd_seq_reg = |
2472 | { | 2524 | { |
2473 | .comment = "sequencer", | 2525 | .comment = "sequencer", |
2474 | .f_ops = &snd_seq_f_ops, | 2526 | .f_ops = &snd_seq_f_ops, |
diff --git a/sound/core/seq/seq_clientmgr.h b/sound/core/seq/seq_clientmgr.h index 3715c36183d3..9df562425e3c 100644 --- a/sound/core/seq/seq_clientmgr.h +++ b/sound/core/seq/seq_clientmgr.h | |||
@@ -30,24 +30,24 @@ | |||
30 | 30 | ||
31 | /* client manager */ | 31 | /* client manager */ |
32 | 32 | ||
33 | struct _snd_seq_user_client { | 33 | struct snd_seq_user_client { |
34 | struct file *file; /* file struct of client */ | 34 | struct file *file; /* file struct of client */ |
35 | /* ... */ | 35 | /* ... */ |
36 | 36 | ||
37 | /* fifo */ | 37 | /* fifo */ |
38 | fifo_t *fifo; /* queue for incoming events */ | 38 | struct snd_seq_fifo *fifo; /* queue for incoming events */ |
39 | int fifo_pool_size; | 39 | int fifo_pool_size; |
40 | }; | 40 | }; |
41 | 41 | ||
42 | struct _snd_seq_kernel_client { | 42 | struct snd_seq_kernel_client { |
43 | snd_card_t *card; | 43 | struct snd_card *card; |
44 | /* pointer to client functions */ | 44 | /* pointer to client functions */ |
45 | void *private_data; /* private data for client */ | 45 | void *private_data; /* private data for client */ |
46 | /* ... */ | 46 | /* ... */ |
47 | }; | 47 | }; |
48 | 48 | ||
49 | 49 | ||
50 | struct _snd_seq_client { | 50 | struct snd_seq_client { |
51 | snd_seq_client_type_t type; | 51 | snd_seq_client_type_t type; |
52 | unsigned int accept_input: 1, | 52 | unsigned int accept_input: 1, |
53 | accept_output: 1; | 53 | accept_output: 1; |
@@ -65,40 +65,42 @@ struct _snd_seq_client { | |||
65 | int convert32; /* convert 32->64bit */ | 65 | int convert32; /* convert 32->64bit */ |
66 | 66 | ||
67 | /* output pool */ | 67 | /* output pool */ |
68 | pool_t *pool; /* memory pool for this client */ | 68 | struct snd_seq_pool *pool; /* memory pool for this client */ |
69 | 69 | ||
70 | union { | 70 | union { |
71 | user_client_t user; | 71 | struct snd_seq_user_client user; |
72 | kernel_client_t kernel; | 72 | struct snd_seq_kernel_client kernel; |
73 | } data; | 73 | } data; |
74 | }; | 74 | }; |
75 | 75 | ||
76 | /* usage statistics */ | 76 | /* usage statistics */ |
77 | typedef struct { | 77 | struct snd_seq_usage { |
78 | int cur; | 78 | int cur; |
79 | int peak; | 79 | int peak; |
80 | } usage_t; | 80 | }; |
81 | 81 | ||
82 | 82 | ||
83 | extern int client_init_data(void); | 83 | int client_init_data(void); |
84 | extern int snd_sequencer_device_init(void); | 84 | int snd_sequencer_device_init(void); |
85 | extern void snd_sequencer_device_done(void); | 85 | void snd_sequencer_device_done(void); |
86 | 86 | ||
87 | /* get locked pointer to client */ | 87 | /* get locked pointer to client */ |
88 | extern client_t *snd_seq_client_use_ptr(int clientid); | 88 | struct snd_seq_client *snd_seq_client_use_ptr(int clientid); |
89 | 89 | ||
90 | /* unlock pointer to client */ | 90 | /* unlock pointer to client */ |
91 | #define snd_seq_client_unlock(client) snd_use_lock_free(&(client)->use_lock) | 91 | #define snd_seq_client_unlock(client) snd_use_lock_free(&(client)->use_lock) |
92 | 92 | ||
93 | /* dispatch event to client(s) */ | 93 | /* dispatch event to client(s) */ |
94 | extern int snd_seq_dispatch_event(snd_seq_event_cell_t *cell, int atomic, int hop); | 94 | int snd_seq_dispatch_event(struct snd_seq_event_cell *cell, int atomic, int hop); |
95 | 95 | ||
96 | /* exported to other modules */ | 96 | /* exported to other modules */ |
97 | extern int snd_seq_register_kernel_client(snd_seq_client_callback_t *callback, void *private_data); | 97 | int snd_seq_register_kernel_client(struct snd_seq_client_callback *callback, void *private_data); |
98 | extern int snd_seq_unregister_kernel_client(int client); | 98 | int snd_seq_unregister_kernel_client(int client); |
99 | extern int snd_seq_kernel_client_enqueue(int client, snd_seq_event_t *ev, int atomic, int hop); | 99 | int snd_seq_kernel_client_enqueue(int client, struct snd_seq_event *ev, int atomic, int hop); |
100 | int snd_seq_kernel_client_enqueue_blocking(int client, snd_seq_event_t * ev, struct file *file, int atomic, int hop); | 100 | int snd_seq_kernel_client_enqueue_blocking(int client, struct snd_seq_event * ev, |
101 | struct file *file, int atomic, int hop); | ||
101 | int snd_seq_kernel_client_write_poll(int clientid, struct file *file, poll_table *wait); | 102 | int snd_seq_kernel_client_write_poll(int clientid, struct file *file, poll_table *wait); |
102 | int snd_seq_client_notify_subscription(int client, int port, snd_seq_port_subscribe_t *info, int evtype); | 103 | int snd_seq_client_notify_subscription(int client, int port, |
104 | struct snd_seq_port_subscribe *info, int evtype); | ||
103 | 105 | ||
104 | #endif | 106 | #endif |
diff --git a/sound/core/seq/seq_compat.c b/sound/core/seq/seq_compat.c index 902ad8b0c355..9628c06e4eab 100644 --- a/sound/core/seq/seq_compat.c +++ b/sound/core/seq/seq_compat.c | |||
@@ -22,8 +22,8 @@ | |||
22 | 22 | ||
23 | #include <linux/compat.h> | 23 | #include <linux/compat.h> |
24 | 24 | ||
25 | struct sndrv_seq_port_info32 { | 25 | struct snd_seq_port_info32 { |
26 | struct sndrv_seq_addr addr; /* client/port numbers */ | 26 | struct snd_seq_addr addr; /* client/port numbers */ |
27 | char name[64]; /* port name */ | 27 | char name[64]; /* port name */ |
28 | 28 | ||
29 | u32 capability; /* port capability bits */ | 29 | u32 capability; /* port capability bits */ |
@@ -41,11 +41,11 @@ struct sndrv_seq_port_info32 { | |||
41 | char reserved[59]; /* for future use */ | 41 | char reserved[59]; /* for future use */ |
42 | }; | 42 | }; |
43 | 43 | ||
44 | static int snd_seq_call_port_info_ioctl(client_t *client, unsigned int cmd, | 44 | static int snd_seq_call_port_info_ioctl(struct snd_seq_client *client, unsigned int cmd, |
45 | struct sndrv_seq_port_info32 __user *data32) | 45 | struct snd_seq_port_info32 __user *data32) |
46 | { | 46 | { |
47 | int err = -EFAULT; | 47 | int err = -EFAULT; |
48 | snd_seq_port_info_t *data; | 48 | struct snd_seq_port_info *data; |
49 | mm_segment_t fs; | 49 | mm_segment_t fs; |
50 | 50 | ||
51 | data = kmalloc(sizeof(*data), GFP_KERNEL); | 51 | data = kmalloc(sizeof(*data), GFP_KERNEL); |
@@ -80,16 +80,16 @@ static int snd_seq_call_port_info_ioctl(client_t *client, unsigned int cmd, | |||
80 | */ | 80 | */ |
81 | 81 | ||
82 | enum { | 82 | enum { |
83 | SNDRV_SEQ_IOCTL_CREATE_PORT32 = _IOWR('S', 0x20, struct sndrv_seq_port_info32), | 83 | SNDRV_SEQ_IOCTL_CREATE_PORT32 = _IOWR('S', 0x20, struct snd_seq_port_info32), |
84 | SNDRV_SEQ_IOCTL_DELETE_PORT32 = _IOW ('S', 0x21, struct sndrv_seq_port_info32), | 84 | SNDRV_SEQ_IOCTL_DELETE_PORT32 = _IOW ('S', 0x21, struct snd_seq_port_info32), |
85 | SNDRV_SEQ_IOCTL_GET_PORT_INFO32 = _IOWR('S', 0x22, struct sndrv_seq_port_info32), | 85 | SNDRV_SEQ_IOCTL_GET_PORT_INFO32 = _IOWR('S', 0x22, struct snd_seq_port_info32), |
86 | SNDRV_SEQ_IOCTL_SET_PORT_INFO32 = _IOW ('S', 0x23, struct sndrv_seq_port_info32), | 86 | SNDRV_SEQ_IOCTL_SET_PORT_INFO32 = _IOW ('S', 0x23, struct snd_seq_port_info32), |
87 | SNDRV_SEQ_IOCTL_QUERY_NEXT_PORT32 = _IOWR('S', 0x52, struct sndrv_seq_port_info32), | 87 | SNDRV_SEQ_IOCTL_QUERY_NEXT_PORT32 = _IOWR('S', 0x52, struct snd_seq_port_info32), |
88 | }; | 88 | }; |
89 | 89 | ||
90 | static long snd_seq_ioctl_compat(struct file *file, unsigned int cmd, unsigned long arg) | 90 | static long snd_seq_ioctl_compat(struct file *file, unsigned int cmd, unsigned long arg) |
91 | { | 91 | { |
92 | client_t *client = (client_t *) file->private_data; | 92 | struct snd_seq_client *client = file->private_data; |
93 | void __user *argp = compat_ptr(arg); | 93 | void __user *argp = compat_ptr(arg); |
94 | 94 | ||
95 | snd_assert(client != NULL, return -ENXIO); | 95 | snd_assert(client != NULL, return -ENXIO); |
diff --git a/sound/core/seq/seq_device.c b/sound/core/seq/seq_device.c index 252b52731003..3f935a18b5e7 100644 --- a/sound/core/seq/seq_device.c +++ b/sound/core/seq/seq_device.c | |||
@@ -50,11 +50,6 @@ MODULE_AUTHOR("Takashi Iwai <tiwai@suse.de>"); | |||
50 | MODULE_DESCRIPTION("ALSA sequencer device management"); | 50 | MODULE_DESCRIPTION("ALSA sequencer device management"); |
51 | MODULE_LICENSE("GPL"); | 51 | MODULE_LICENSE("GPL"); |
52 | 52 | ||
53 | /* | ||
54 | * driver list | ||
55 | */ | ||
56 | typedef struct ops_list ops_list_t; | ||
57 | |||
58 | /* driver state */ | 53 | /* driver state */ |
59 | #define DRIVER_EMPTY 0 | 54 | #define DRIVER_EMPTY 0 |
60 | #define DRIVER_LOADED (1<<0) | 55 | #define DRIVER_LOADED (1<<0) |
@@ -68,7 +63,7 @@ struct ops_list { | |||
68 | int argsize; /* argument size */ | 63 | int argsize; /* argument size */ |
69 | 64 | ||
70 | /* operators */ | 65 | /* operators */ |
71 | snd_seq_dev_ops_t ops; | 66 | struct snd_seq_dev_ops ops; |
72 | 67 | ||
73 | /* registred devices */ | 68 | /* registred devices */ |
74 | struct list_head dev_list; /* list of devices */ | 69 | struct list_head dev_list; /* list of devices */ |
@@ -83,35 +78,36 @@ struct ops_list { | |||
83 | static LIST_HEAD(opslist); | 78 | static LIST_HEAD(opslist); |
84 | static int num_ops; | 79 | static int num_ops; |
85 | static DECLARE_MUTEX(ops_mutex); | 80 | static DECLARE_MUTEX(ops_mutex); |
86 | static snd_info_entry_t *info_entry = NULL; | 81 | static struct snd_info_entry *info_entry = NULL; |
87 | 82 | ||
88 | /* | 83 | /* |
89 | * prototypes | 84 | * prototypes |
90 | */ | 85 | */ |
91 | static int snd_seq_device_free(snd_seq_device_t *dev); | 86 | static int snd_seq_device_free(struct snd_seq_device *dev); |
92 | static int snd_seq_device_dev_free(snd_device_t *device); | 87 | static int snd_seq_device_dev_free(struct snd_device *device); |
93 | static int snd_seq_device_dev_register(snd_device_t *device); | 88 | static int snd_seq_device_dev_register(struct snd_device *device); |
94 | static int snd_seq_device_dev_disconnect(snd_device_t *device); | 89 | static int snd_seq_device_dev_disconnect(struct snd_device *device); |
95 | static int snd_seq_device_dev_unregister(snd_device_t *device); | 90 | static int snd_seq_device_dev_unregister(struct snd_device *device); |
96 | 91 | ||
97 | static int init_device(snd_seq_device_t *dev, ops_list_t *ops); | 92 | static int init_device(struct snd_seq_device *dev, struct ops_list *ops); |
98 | static int free_device(snd_seq_device_t *dev, ops_list_t *ops); | 93 | static int free_device(struct snd_seq_device *dev, struct ops_list *ops); |
99 | static ops_list_t *find_driver(char *id, int create_if_empty); | 94 | static struct ops_list *find_driver(char *id, int create_if_empty); |
100 | static ops_list_t *create_driver(char *id); | 95 | static struct ops_list *create_driver(char *id); |
101 | static void unlock_driver(ops_list_t *ops); | 96 | static void unlock_driver(struct ops_list *ops); |
102 | static void remove_drivers(void); | 97 | static void remove_drivers(void); |
103 | 98 | ||
104 | /* | 99 | /* |
105 | * show all drivers and their status | 100 | * show all drivers and their status |
106 | */ | 101 | */ |
107 | 102 | ||
108 | static void snd_seq_device_info(snd_info_entry_t *entry, snd_info_buffer_t * buffer) | 103 | static void snd_seq_device_info(struct snd_info_entry *entry, |
104 | struct snd_info_buffer *buffer) | ||
109 | { | 105 | { |
110 | struct list_head *head; | 106 | struct list_head *head; |
111 | 107 | ||
112 | down(&ops_mutex); | 108 | down(&ops_mutex); |
113 | list_for_each(head, &opslist) { | 109 | list_for_each(head, &opslist) { |
114 | ops_list_t *ops = list_entry(head, ops_list_t, list); | 110 | struct ops_list *ops = list_entry(head, struct ops_list, list); |
115 | snd_iprintf(buffer, "snd-%s%s%s%s,%d\n", | 111 | snd_iprintf(buffer, "snd-%s%s%s%s,%d\n", |
116 | ops->id, | 112 | ops->id, |
117 | ops->driver & DRIVER_LOADED ? ",loaded" : (ops->driver == DRIVER_EMPTY ? ",empty" : ""), | 113 | ops->driver & DRIVER_LOADED ? ",loaded" : (ops->driver == DRIVER_EMPTY ? ",empty" : ""), |
@@ -156,7 +152,7 @@ void snd_seq_device_load_drivers(void) | |||
156 | 152 | ||
157 | down(&ops_mutex); | 153 | down(&ops_mutex); |
158 | list_for_each(head, &opslist) { | 154 | list_for_each(head, &opslist) { |
159 | ops_list_t *ops = list_entry(head, ops_list_t, list); | 155 | struct ops_list *ops = list_entry(head, struct ops_list, list); |
160 | if (! (ops->driver & DRIVER_LOADED) && | 156 | if (! (ops->driver & DRIVER_LOADED) && |
161 | ! (ops->driver & DRIVER_REQUESTED)) { | 157 | ! (ops->driver & DRIVER_REQUESTED)) { |
162 | ops->used++; | 158 | ops->used++; |
@@ -178,13 +174,13 @@ void snd_seq_device_load_drivers(void) | |||
178 | * id = id of driver | 174 | * id = id of driver |
179 | * result = return pointer (NULL allowed if unnecessary) | 175 | * result = return pointer (NULL allowed if unnecessary) |
180 | */ | 176 | */ |
181 | int snd_seq_device_new(snd_card_t *card, int device, char *id, int argsize, | 177 | int snd_seq_device_new(struct snd_card *card, int device, char *id, int argsize, |
182 | snd_seq_device_t **result) | 178 | struct snd_seq_device **result) |
183 | { | 179 | { |
184 | snd_seq_device_t *dev; | 180 | struct snd_seq_device *dev; |
185 | ops_list_t *ops; | 181 | struct ops_list *ops; |
186 | int err; | 182 | int err; |
187 | static snd_device_ops_t dops = { | 183 | static struct snd_device_ops dops = { |
188 | .dev_free = snd_seq_device_dev_free, | 184 | .dev_free = snd_seq_device_dev_free, |
189 | .dev_register = snd_seq_device_dev_register, | 185 | .dev_register = snd_seq_device_dev_register, |
190 | .dev_disconnect = snd_seq_device_dev_disconnect, | 186 | .dev_disconnect = snd_seq_device_dev_disconnect, |
@@ -235,9 +231,9 @@ int snd_seq_device_new(snd_card_t *card, int device, char *id, int argsize, | |||
235 | /* | 231 | /* |
236 | * free the existing device | 232 | * free the existing device |
237 | */ | 233 | */ |
238 | static int snd_seq_device_free(snd_seq_device_t *dev) | 234 | static int snd_seq_device_free(struct snd_seq_device *dev) |
239 | { | 235 | { |
240 | ops_list_t *ops; | 236 | struct ops_list *ops; |
241 | 237 | ||
242 | snd_assert(dev != NULL, return -EINVAL); | 238 | snd_assert(dev != NULL, return -EINVAL); |
243 | 239 | ||
@@ -261,19 +257,19 @@ static int snd_seq_device_free(snd_seq_device_t *dev) | |||
261 | return 0; | 257 | return 0; |
262 | } | 258 | } |
263 | 259 | ||
264 | static int snd_seq_device_dev_free(snd_device_t *device) | 260 | static int snd_seq_device_dev_free(struct snd_device *device) |
265 | { | 261 | { |
266 | snd_seq_device_t *dev = device->device_data; | 262 | struct snd_seq_device *dev = device->device_data; |
267 | return snd_seq_device_free(dev); | 263 | return snd_seq_device_free(dev); |
268 | } | 264 | } |
269 | 265 | ||
270 | /* | 266 | /* |
271 | * register the device | 267 | * register the device |
272 | */ | 268 | */ |
273 | static int snd_seq_device_dev_register(snd_device_t *device) | 269 | static int snd_seq_device_dev_register(struct snd_device *device) |
274 | { | 270 | { |
275 | snd_seq_device_t *dev = device->device_data; | 271 | struct snd_seq_device *dev = device->device_data; |
276 | ops_list_t *ops; | 272 | struct ops_list *ops; |
277 | 273 | ||
278 | ops = find_driver(dev->id, 0); | 274 | ops = find_driver(dev->id, 0); |
279 | if (ops == NULL) | 275 | if (ops == NULL) |
@@ -292,10 +288,10 @@ static int snd_seq_device_dev_register(snd_device_t *device) | |||
292 | /* | 288 | /* |
293 | * disconnect the device | 289 | * disconnect the device |
294 | */ | 290 | */ |
295 | static int snd_seq_device_dev_disconnect(snd_device_t *device) | 291 | static int snd_seq_device_dev_disconnect(struct snd_device *device) |
296 | { | 292 | { |
297 | snd_seq_device_t *dev = device->device_data; | 293 | struct snd_seq_device *dev = device->device_data; |
298 | ops_list_t *ops; | 294 | struct ops_list *ops; |
299 | 295 | ||
300 | ops = find_driver(dev->id, 0); | 296 | ops = find_driver(dev->id, 0); |
301 | if (ops == NULL) | 297 | if (ops == NULL) |
@@ -310,9 +306,9 @@ static int snd_seq_device_dev_disconnect(snd_device_t *device) | |||
310 | /* | 306 | /* |
311 | * unregister the existing device | 307 | * unregister the existing device |
312 | */ | 308 | */ |
313 | static int snd_seq_device_dev_unregister(snd_device_t *device) | 309 | static int snd_seq_device_dev_unregister(struct snd_device *device) |
314 | { | 310 | { |
315 | snd_seq_device_t *dev = device->device_data; | 311 | struct snd_seq_device *dev = device->device_data; |
316 | return snd_seq_device_free(dev); | 312 | return snd_seq_device_free(dev); |
317 | } | 313 | } |
318 | 314 | ||
@@ -321,10 +317,11 @@ static int snd_seq_device_dev_unregister(snd_device_t *device) | |||
321 | * id = driver id | 317 | * id = driver id |
322 | * entry = driver operators - duplicated to each instance | 318 | * entry = driver operators - duplicated to each instance |
323 | */ | 319 | */ |
324 | int snd_seq_device_register_driver(char *id, snd_seq_dev_ops_t *entry, int argsize) | 320 | int snd_seq_device_register_driver(char *id, struct snd_seq_dev_ops *entry, |
321 | int argsize) | ||
325 | { | 322 | { |
326 | struct list_head *head; | 323 | struct list_head *head; |
327 | ops_list_t *ops; | 324 | struct ops_list *ops; |
328 | 325 | ||
329 | if (id == NULL || entry == NULL || | 326 | if (id == NULL || entry == NULL || |
330 | entry->init_device == NULL || entry->free_device == NULL) | 327 | entry->init_device == NULL || entry->free_device == NULL) |
@@ -351,7 +348,7 @@ int snd_seq_device_register_driver(char *id, snd_seq_dev_ops_t *entry, int argsi | |||
351 | 348 | ||
352 | /* initialize existing devices if necessary */ | 349 | /* initialize existing devices if necessary */ |
353 | list_for_each(head, &ops->dev_list) { | 350 | list_for_each(head, &ops->dev_list) { |
354 | snd_seq_device_t *dev = list_entry(head, snd_seq_device_t, list); | 351 | struct snd_seq_device *dev = list_entry(head, struct snd_seq_device, list); |
355 | init_device(dev, ops); | 352 | init_device(dev, ops); |
356 | } | 353 | } |
357 | up(&ops->reg_mutex); | 354 | up(&ops->reg_mutex); |
@@ -366,9 +363,9 @@ int snd_seq_device_register_driver(char *id, snd_seq_dev_ops_t *entry, int argsi | |||
366 | /* | 363 | /* |
367 | * create driver record | 364 | * create driver record |
368 | */ | 365 | */ |
369 | static ops_list_t * create_driver(char *id) | 366 | static struct ops_list * create_driver(char *id) |
370 | { | 367 | { |
371 | ops_list_t *ops; | 368 | struct ops_list *ops; |
372 | 369 | ||
373 | ops = kmalloc(sizeof(*ops), GFP_KERNEL); | 370 | ops = kmalloc(sizeof(*ops), GFP_KERNEL); |
374 | if (ops == NULL) | 371 | if (ops == NULL) |
@@ -399,14 +396,15 @@ static ops_list_t * create_driver(char *id) | |||
399 | int snd_seq_device_unregister_driver(char *id) | 396 | int snd_seq_device_unregister_driver(char *id) |
400 | { | 397 | { |
401 | struct list_head *head; | 398 | struct list_head *head; |
402 | ops_list_t *ops; | 399 | struct ops_list *ops; |
403 | 400 | ||
404 | ops = find_driver(id, 0); | 401 | ops = find_driver(id, 0); |
405 | if (ops == NULL) | 402 | if (ops == NULL) |
406 | return -ENXIO; | 403 | return -ENXIO; |
407 | if (! (ops->driver & DRIVER_LOADED) || | 404 | if (! (ops->driver & DRIVER_LOADED) || |
408 | (ops->driver & DRIVER_LOCKED)) { | 405 | (ops->driver & DRIVER_LOCKED)) { |
409 | snd_printk(KERN_ERR "driver_unregister: cannot unload driver '%s': status=%x\n", id, ops->driver); | 406 | snd_printk(KERN_ERR "driver_unregister: cannot unload driver '%s': status=%x\n", |
407 | id, ops->driver); | ||
410 | unlock_driver(ops); | 408 | unlock_driver(ops); |
411 | return -EBUSY; | 409 | return -EBUSY; |
412 | } | 410 | } |
@@ -415,13 +413,14 @@ int snd_seq_device_unregister_driver(char *id) | |||
415 | down(&ops->reg_mutex); | 413 | down(&ops->reg_mutex); |
416 | ops->driver |= DRIVER_LOCKED; /* do not remove this driver recursively */ | 414 | ops->driver |= DRIVER_LOCKED; /* do not remove this driver recursively */ |
417 | list_for_each(head, &ops->dev_list) { | 415 | list_for_each(head, &ops->dev_list) { |
418 | snd_seq_device_t *dev = list_entry(head, snd_seq_device_t, list); | 416 | struct snd_seq_device *dev = list_entry(head, struct snd_seq_device, list); |
419 | free_device(dev, ops); | 417 | free_device(dev, ops); |
420 | } | 418 | } |
421 | 419 | ||
422 | ops->driver = 0; | 420 | ops->driver = 0; |
423 | if (ops->num_init_devices > 0) | 421 | if (ops->num_init_devices > 0) |
424 | snd_printk(KERN_ERR "free_driver: init_devices > 0!! (%d)\n", ops->num_init_devices); | 422 | snd_printk(KERN_ERR "free_driver: init_devices > 0!! (%d)\n", |
423 | ops->num_init_devices); | ||
425 | up(&ops->reg_mutex); | 424 | up(&ops->reg_mutex); |
426 | 425 | ||
427 | unlock_driver(ops); | 426 | unlock_driver(ops); |
@@ -443,7 +442,7 @@ static void remove_drivers(void) | |||
443 | down(&ops_mutex); | 442 | down(&ops_mutex); |
444 | head = opslist.next; | 443 | head = opslist.next; |
445 | while (head != &opslist) { | 444 | while (head != &opslist) { |
446 | ops_list_t *ops = list_entry(head, ops_list_t, list); | 445 | struct ops_list *ops = list_entry(head, struct ops_list, list); |
447 | if (! (ops->driver & DRIVER_LOADED) && | 446 | if (! (ops->driver & DRIVER_LOADED) && |
448 | ops->used == 0 && ops->num_devices == 0) { | 447 | ops->used == 0 && ops->num_devices == 0) { |
449 | head = head->next; | 448 | head = head->next; |
@@ -459,21 +458,23 @@ static void remove_drivers(void) | |||
459 | /* | 458 | /* |
460 | * initialize the device - call init_device operator | 459 | * initialize the device - call init_device operator |
461 | */ | 460 | */ |
462 | static int init_device(snd_seq_device_t *dev, ops_list_t *ops) | 461 | static int init_device(struct snd_seq_device *dev, struct ops_list *ops) |
463 | { | 462 | { |
464 | if (! (ops->driver & DRIVER_LOADED)) | 463 | if (! (ops->driver & DRIVER_LOADED)) |
465 | return 0; /* driver is not loaded yet */ | 464 | return 0; /* driver is not loaded yet */ |
466 | if (dev->status != SNDRV_SEQ_DEVICE_FREE) | 465 | if (dev->status != SNDRV_SEQ_DEVICE_FREE) |
467 | return 0; /* already initialized */ | 466 | return 0; /* already initialized */ |
468 | if (ops->argsize != dev->argsize) { | 467 | if (ops->argsize != dev->argsize) { |
469 | snd_printk(KERN_ERR "incompatible device '%s' for plug-in '%s' (%d %d)\n", dev->name, ops->id, ops->argsize, dev->argsize); | 468 | snd_printk(KERN_ERR "incompatible device '%s' for plug-in '%s' (%d %d)\n", |
469 | dev->name, ops->id, ops->argsize, dev->argsize); | ||
470 | return -EINVAL; | 470 | return -EINVAL; |
471 | } | 471 | } |
472 | if (ops->ops.init_device(dev) >= 0) { | 472 | if (ops->ops.init_device(dev) >= 0) { |
473 | dev->status = SNDRV_SEQ_DEVICE_REGISTERED; | 473 | dev->status = SNDRV_SEQ_DEVICE_REGISTERED; |
474 | ops->num_init_devices++; | 474 | ops->num_init_devices++; |
475 | } else { | 475 | } else { |
476 | snd_printk(KERN_ERR "init_device failed: %s: %s\n", dev->name, dev->id); | 476 | snd_printk(KERN_ERR "init_device failed: %s: %s\n", |
477 | dev->name, dev->id); | ||
477 | } | 478 | } |
478 | 479 | ||
479 | return 0; | 480 | return 0; |
@@ -482,7 +483,7 @@ static int init_device(snd_seq_device_t *dev, ops_list_t *ops) | |||
482 | /* | 483 | /* |
483 | * release the device - call free_device operator | 484 | * release the device - call free_device operator |
484 | */ | 485 | */ |
485 | static int free_device(snd_seq_device_t *dev, ops_list_t *ops) | 486 | static int free_device(struct snd_seq_device *dev, struct ops_list *ops) |
486 | { | 487 | { |
487 | int result; | 488 | int result; |
488 | 489 | ||
@@ -491,7 +492,8 @@ static int free_device(snd_seq_device_t *dev, ops_list_t *ops) | |||
491 | if (dev->status != SNDRV_SEQ_DEVICE_REGISTERED) | 492 | if (dev->status != SNDRV_SEQ_DEVICE_REGISTERED) |
492 | return 0; /* not registered */ | 493 | return 0; /* not registered */ |
493 | if (ops->argsize != dev->argsize) { | 494 | if (ops->argsize != dev->argsize) { |
494 | snd_printk(KERN_ERR "incompatible device '%s' for plug-in '%s' (%d %d)\n", dev->name, ops->id, ops->argsize, dev->argsize); | 495 | snd_printk(KERN_ERR "incompatible device '%s' for plug-in '%s' (%d %d)\n", |
496 | dev->name, ops->id, ops->argsize, dev->argsize); | ||
495 | return -EINVAL; | 497 | return -EINVAL; |
496 | } | 498 | } |
497 | if ((result = ops->ops.free_device(dev)) >= 0 || result == -ENXIO) { | 499 | if ((result = ops->ops.free_device(dev)) >= 0 || result == -ENXIO) { |
@@ -499,7 +501,8 @@ static int free_device(snd_seq_device_t *dev, ops_list_t *ops) | |||
499 | dev->driver_data = NULL; | 501 | dev->driver_data = NULL; |
500 | ops->num_init_devices--; | 502 | ops->num_init_devices--; |
501 | } else { | 503 | } else { |
502 | snd_printk(KERN_ERR "free_device failed: %s: %s\n", dev->name, dev->id); | 504 | snd_printk(KERN_ERR "free_device failed: %s: %s\n", |
505 | dev->name, dev->id); | ||
503 | } | 506 | } |
504 | 507 | ||
505 | return 0; | 508 | return 0; |
@@ -508,13 +511,13 @@ static int free_device(snd_seq_device_t *dev, ops_list_t *ops) | |||
508 | /* | 511 | /* |
509 | * find the matching driver with given id | 512 | * find the matching driver with given id |
510 | */ | 513 | */ |
511 | static ops_list_t * find_driver(char *id, int create_if_empty) | 514 | static struct ops_list * find_driver(char *id, int create_if_empty) |
512 | { | 515 | { |
513 | struct list_head *head; | 516 | struct list_head *head; |
514 | 517 | ||
515 | down(&ops_mutex); | 518 | down(&ops_mutex); |
516 | list_for_each(head, &opslist) { | 519 | list_for_each(head, &opslist) { |
517 | ops_list_t *ops = list_entry(head, ops_list_t, list); | 520 | struct ops_list *ops = list_entry(head, struct ops_list, list); |
518 | if (strcmp(ops->id, id) == 0) { | 521 | if (strcmp(ops->id, id) == 0) { |
519 | ops->used++; | 522 | ops->used++; |
520 | up(&ops_mutex); | 523 | up(&ops_mutex); |
@@ -527,7 +530,7 @@ static ops_list_t * find_driver(char *id, int create_if_empty) | |||
527 | return NULL; | 530 | return NULL; |
528 | } | 531 | } |
529 | 532 | ||
530 | static void unlock_driver(ops_list_t *ops) | 533 | static void unlock_driver(struct ops_list *ops) |
531 | { | 534 | { |
532 | down(&ops_mutex); | 535 | down(&ops_mutex); |
533 | ops->used--; | 536 | ops->used--; |
@@ -541,7 +544,8 @@ static void unlock_driver(ops_list_t *ops) | |||
541 | 544 | ||
542 | static int __init alsa_seq_device_init(void) | 545 | static int __init alsa_seq_device_init(void) |
543 | { | 546 | { |
544 | info_entry = snd_info_create_module_entry(THIS_MODULE, "drivers", snd_seq_root); | 547 | info_entry = snd_info_create_module_entry(THIS_MODULE, "drivers", |
548 | snd_seq_root); | ||
545 | if (info_entry == NULL) | 549 | if (info_entry == NULL) |
546 | return -ENOMEM; | 550 | return -ENOMEM; |
547 | info_entry->content = SNDRV_INFO_CONTENT_TEXT; | 551 | info_entry->content = SNDRV_INFO_CONTENT_TEXT; |
diff --git a/sound/core/seq/seq_dummy.c b/sound/core/seq/seq_dummy.c index 5dd0e6a19e50..8101a475e3e5 100644 --- a/sound/core/seq/seq_dummy.c +++ b/sound/core/seq/seq_dummy.c | |||
@@ -73,12 +73,12 @@ MODULE_PARM_DESC(ports, "number of ports to be created"); | |||
73 | module_param(duplex, bool, 0444); | 73 | module_param(duplex, bool, 0444); |
74 | MODULE_PARM_DESC(duplex, "create DUPLEX ports"); | 74 | MODULE_PARM_DESC(duplex, "create DUPLEX ports"); |
75 | 75 | ||
76 | typedef struct snd_seq_dummy_port { | 76 | struct snd_seq_dummy_port { |
77 | int client; | 77 | int client; |
78 | int port; | 78 | int port; |
79 | int duplex; | 79 | int duplex; |
80 | int connect; | 80 | int connect; |
81 | } snd_seq_dummy_port_t; | 81 | }; |
82 | 82 | ||
83 | static int my_client = -1; | 83 | static int my_client = -1; |
84 | 84 | ||
@@ -88,11 +88,11 @@ static int my_client = -1; | |||
88 | * Note: this callback is called only after all subscribers are removed. | 88 | * Note: this callback is called only after all subscribers are removed. |
89 | */ | 89 | */ |
90 | static int | 90 | static int |
91 | dummy_unuse(void *private_data, snd_seq_port_subscribe_t *info) | 91 | dummy_unuse(void *private_data, struct snd_seq_port_subscribe *info) |
92 | { | 92 | { |
93 | snd_seq_dummy_port_t *p; | 93 | struct snd_seq_dummy_port *p; |
94 | int i; | 94 | int i; |
95 | snd_seq_event_t ev; | 95 | struct snd_seq_event ev; |
96 | 96 | ||
97 | p = private_data; | 97 | p = private_data; |
98 | memset(&ev, 0, sizeof(ev)); | 98 | memset(&ev, 0, sizeof(ev)); |
@@ -116,10 +116,11 @@ dummy_unuse(void *private_data, snd_seq_port_subscribe_t *info) | |||
116 | * event input callback - just redirect events to subscribers | 116 | * event input callback - just redirect events to subscribers |
117 | */ | 117 | */ |
118 | static int | 118 | static int |
119 | dummy_input(snd_seq_event_t *ev, int direct, void *private_data, int atomic, int hop) | 119 | dummy_input(struct snd_seq_event *ev, int direct, void *private_data, |
120 | int atomic, int hop) | ||
120 | { | 121 | { |
121 | snd_seq_dummy_port_t *p; | 122 | struct snd_seq_dummy_port *p; |
122 | snd_seq_event_t tmpev; | 123 | struct snd_seq_event tmpev; |
123 | 124 | ||
124 | p = private_data; | 125 | p = private_data; |
125 | if (ev->source.client == SNDRV_SEQ_CLIENT_SYSTEM || | 126 | if (ev->source.client == SNDRV_SEQ_CLIENT_SYSTEM || |
@@ -146,12 +147,12 @@ dummy_free(void *private_data) | |||
146 | /* | 147 | /* |
147 | * create a port | 148 | * create a port |
148 | */ | 149 | */ |
149 | static snd_seq_dummy_port_t __init * | 150 | static struct snd_seq_dummy_port __init * |
150 | create_port(int idx, int type) | 151 | create_port(int idx, int type) |
151 | { | 152 | { |
152 | snd_seq_port_info_t pinfo; | 153 | struct snd_seq_port_info pinfo; |
153 | snd_seq_port_callback_t pcb; | 154 | struct snd_seq_port_callback pcb; |
154 | snd_seq_dummy_port_t *rec; | 155 | struct snd_seq_dummy_port *rec; |
155 | 156 | ||
156 | if ((rec = kzalloc(sizeof(*rec), GFP_KERNEL)) == NULL) | 157 | if ((rec = kzalloc(sizeof(*rec), GFP_KERNEL)) == NULL) |
157 | return NULL; | 158 | return NULL; |
@@ -192,9 +193,9 @@ create_port(int idx, int type) | |||
192 | static int __init | 193 | static int __init |
193 | register_client(void) | 194 | register_client(void) |
194 | { | 195 | { |
195 | snd_seq_client_callback_t cb; | 196 | struct snd_seq_client_callback cb; |
196 | snd_seq_client_info_t cinfo; | 197 | struct snd_seq_client_info cinfo; |
197 | snd_seq_dummy_port_t *rec1, *rec2; | 198 | struct snd_seq_dummy_port *rec1, *rec2; |
198 | int i; | 199 | int i; |
199 | 200 | ||
200 | if (ports < 1) { | 201 | if (ports < 1) { |
diff --git a/sound/core/seq/seq_fifo.c b/sound/core/seq/seq_fifo.c index 4767cfdc361f..6b055aed7a4b 100644 --- a/sound/core/seq/seq_fifo.c +++ b/sound/core/seq/seq_fifo.c | |||
@@ -29,9 +29,9 @@ | |||
29 | /* FIFO */ | 29 | /* FIFO */ |
30 | 30 | ||
31 | /* create new fifo */ | 31 | /* create new fifo */ |
32 | fifo_t *snd_seq_fifo_new(int poolsize) | 32 | struct snd_seq_fifo *snd_seq_fifo_new(int poolsize) |
33 | { | 33 | { |
34 | fifo_t *f; | 34 | struct snd_seq_fifo *f; |
35 | 35 | ||
36 | f = kzalloc(sizeof(*f), GFP_KERNEL); | 36 | f = kzalloc(sizeof(*f), GFP_KERNEL); |
37 | if (f == NULL) { | 37 | if (f == NULL) { |
@@ -62,9 +62,9 @@ fifo_t *snd_seq_fifo_new(int poolsize) | |||
62 | return f; | 62 | return f; |
63 | } | 63 | } |
64 | 64 | ||
65 | void snd_seq_fifo_delete(fifo_t **fifo) | 65 | void snd_seq_fifo_delete(struct snd_seq_fifo **fifo) |
66 | { | 66 | { |
67 | fifo_t *f; | 67 | struct snd_seq_fifo *f; |
68 | 68 | ||
69 | snd_assert(fifo != NULL, return); | 69 | snd_assert(fifo != NULL, return); |
70 | f = *fifo; | 70 | f = *fifo; |
@@ -88,12 +88,12 @@ void snd_seq_fifo_delete(fifo_t **fifo) | |||
88 | kfree(f); | 88 | kfree(f); |
89 | } | 89 | } |
90 | 90 | ||
91 | static snd_seq_event_cell_t *fifo_cell_out(fifo_t *f); | 91 | static struct snd_seq_event_cell *fifo_cell_out(struct snd_seq_fifo *f); |
92 | 92 | ||
93 | /* clear queue */ | 93 | /* clear queue */ |
94 | void snd_seq_fifo_clear(fifo_t *f) | 94 | void snd_seq_fifo_clear(struct snd_seq_fifo *f) |
95 | { | 95 | { |
96 | snd_seq_event_cell_t *cell; | 96 | struct snd_seq_event_cell *cell; |
97 | unsigned long flags; | 97 | unsigned long flags; |
98 | 98 | ||
99 | /* clear overflow flag */ | 99 | /* clear overflow flag */ |
@@ -110,9 +110,10 @@ void snd_seq_fifo_clear(fifo_t *f) | |||
110 | 110 | ||
111 | 111 | ||
112 | /* enqueue event to fifo */ | 112 | /* enqueue event to fifo */ |
113 | int snd_seq_fifo_event_in(fifo_t *f, snd_seq_event_t *event) | 113 | int snd_seq_fifo_event_in(struct snd_seq_fifo *f, |
114 | struct snd_seq_event *event) | ||
114 | { | 115 | { |
115 | snd_seq_event_cell_t *cell; | 116 | struct snd_seq_event_cell *cell; |
116 | unsigned long flags; | 117 | unsigned long flags; |
117 | int err; | 118 | int err; |
118 | 119 | ||
@@ -148,9 +149,9 @@ int snd_seq_fifo_event_in(fifo_t *f, snd_seq_event_t *event) | |||
148 | } | 149 | } |
149 | 150 | ||
150 | /* dequeue cell from fifo */ | 151 | /* dequeue cell from fifo */ |
151 | static snd_seq_event_cell_t *fifo_cell_out(fifo_t *f) | 152 | static struct snd_seq_event_cell *fifo_cell_out(struct snd_seq_fifo *f) |
152 | { | 153 | { |
153 | snd_seq_event_cell_t *cell; | 154 | struct snd_seq_event_cell *cell; |
154 | 155 | ||
155 | if ((cell = f->head) != NULL) { | 156 | if ((cell = f->head) != NULL) { |
156 | f->head = cell->next; | 157 | f->head = cell->next; |
@@ -167,9 +168,10 @@ static snd_seq_event_cell_t *fifo_cell_out(fifo_t *f) | |||
167 | } | 168 | } |
168 | 169 | ||
169 | /* dequeue cell from fifo and copy on user space */ | 170 | /* dequeue cell from fifo and copy on user space */ |
170 | int snd_seq_fifo_cell_out(fifo_t *f, snd_seq_event_cell_t **cellp, int nonblock) | 171 | int snd_seq_fifo_cell_out(struct snd_seq_fifo *f, |
172 | struct snd_seq_event_cell **cellp, int nonblock) | ||
171 | { | 173 | { |
172 | snd_seq_event_cell_t *cell; | 174 | struct snd_seq_event_cell *cell; |
173 | unsigned long flags; | 175 | unsigned long flags; |
174 | wait_queue_t wait; | 176 | wait_queue_t wait; |
175 | 177 | ||
@@ -202,7 +204,8 @@ int snd_seq_fifo_cell_out(fifo_t *f, snd_seq_event_cell_t **cellp, int nonblock) | |||
202 | } | 204 | } |
203 | 205 | ||
204 | 206 | ||
205 | void snd_seq_fifo_cell_putback(fifo_t *f, snd_seq_event_cell_t *cell) | 207 | void snd_seq_fifo_cell_putback(struct snd_seq_fifo *f, |
208 | struct snd_seq_event_cell *cell) | ||
206 | { | 209 | { |
207 | unsigned long flags; | 210 | unsigned long flags; |
208 | 211 | ||
@@ -217,18 +220,19 @@ void snd_seq_fifo_cell_putback(fifo_t *f, snd_seq_event_cell_t *cell) | |||
217 | 220 | ||
218 | 221 | ||
219 | /* polling; return non-zero if queue is available */ | 222 | /* polling; return non-zero if queue is available */ |
220 | int snd_seq_fifo_poll_wait(fifo_t *f, struct file *file, poll_table *wait) | 223 | int snd_seq_fifo_poll_wait(struct snd_seq_fifo *f, struct file *file, |
224 | poll_table *wait) | ||
221 | { | 225 | { |
222 | poll_wait(file, &f->input_sleep, wait); | 226 | poll_wait(file, &f->input_sleep, wait); |
223 | return (f->cells > 0); | 227 | return (f->cells > 0); |
224 | } | 228 | } |
225 | 229 | ||
226 | /* change the size of pool; all old events are removed */ | 230 | /* change the size of pool; all old events are removed */ |
227 | int snd_seq_fifo_resize(fifo_t *f, int poolsize) | 231 | int snd_seq_fifo_resize(struct snd_seq_fifo *f, int poolsize) |
228 | { | 232 | { |
229 | unsigned long flags; | 233 | unsigned long flags; |
230 | pool_t *newpool, *oldpool; | 234 | struct snd_seq_pool *newpool, *oldpool; |
231 | snd_seq_event_cell_t *cell, *next, *oldhead; | 235 | struct snd_seq_event_cell *cell, *next, *oldhead; |
232 | 236 | ||
233 | snd_assert(f != NULL && f->pool != NULL, return -EINVAL); | 237 | snd_assert(f != NULL && f->pool != NULL, return -EINVAL); |
234 | 238 | ||
diff --git a/sound/core/seq/seq_fifo.h b/sound/core/seq/seq_fifo.h index d677c261b0a4..062c446e7867 100644 --- a/sound/core/seq/seq_fifo.h +++ b/sound/core/seq/seq_fifo.h | |||
@@ -27,46 +27,46 @@ | |||
27 | 27 | ||
28 | /* === FIFO === */ | 28 | /* === FIFO === */ |
29 | 29 | ||
30 | typedef struct { | 30 | struct snd_seq_fifo { |
31 | pool_t *pool; /* FIFO pool */ | 31 | struct snd_seq_pool *pool; /* FIFO pool */ |
32 | snd_seq_event_cell_t* head; /* pointer to head of fifo */ | 32 | struct snd_seq_event_cell *head; /* pointer to head of fifo */ |
33 | snd_seq_event_cell_t* tail; /* pointer to tail of fifo */ | 33 | struct snd_seq_event_cell *tail; /* pointer to tail of fifo */ |
34 | int cells; | 34 | int cells; |
35 | spinlock_t lock; | 35 | spinlock_t lock; |
36 | snd_use_lock_t use_lock; | 36 | snd_use_lock_t use_lock; |
37 | wait_queue_head_t input_sleep; | 37 | wait_queue_head_t input_sleep; |
38 | atomic_t overflow; | 38 | atomic_t overflow; |
39 | 39 | ||
40 | } fifo_t; | 40 | }; |
41 | 41 | ||
42 | /* create new fifo (constructor) */ | 42 | /* create new fifo (constructor) */ |
43 | extern fifo_t *snd_seq_fifo_new(int poolsize); | 43 | struct snd_seq_fifo *snd_seq_fifo_new(int poolsize); |
44 | 44 | ||
45 | /* delete fifo (destructor) */ | 45 | /* delete fifo (destructor) */ |
46 | extern void snd_seq_fifo_delete(fifo_t **f); | 46 | void snd_seq_fifo_delete(struct snd_seq_fifo **f); |
47 | 47 | ||
48 | 48 | ||
49 | /* enqueue event to fifo */ | 49 | /* enqueue event to fifo */ |
50 | extern int snd_seq_fifo_event_in(fifo_t *f, snd_seq_event_t *event); | 50 | int snd_seq_fifo_event_in(struct snd_seq_fifo *f, struct snd_seq_event *event); |
51 | 51 | ||
52 | /* lock fifo from release */ | 52 | /* lock fifo from release */ |
53 | #define snd_seq_fifo_lock(fifo) snd_use_lock_use(&(fifo)->use_lock) | 53 | #define snd_seq_fifo_lock(fifo) snd_use_lock_use(&(fifo)->use_lock) |
54 | #define snd_seq_fifo_unlock(fifo) snd_use_lock_free(&(fifo)->use_lock) | 54 | #define snd_seq_fifo_unlock(fifo) snd_use_lock_free(&(fifo)->use_lock) |
55 | 55 | ||
56 | /* get a cell from fifo - fifo should be locked */ | 56 | /* get a cell from fifo - fifo should be locked */ |
57 | int snd_seq_fifo_cell_out(fifo_t *f, snd_seq_event_cell_t **cellp, int nonblock); | 57 | int snd_seq_fifo_cell_out(struct snd_seq_fifo *f, struct snd_seq_event_cell **cellp, int nonblock); |
58 | 58 | ||
59 | /* free dequeued cell - fifo should be locked */ | 59 | /* free dequeued cell - fifo should be locked */ |
60 | extern void snd_seq_fifo_cell_putback(fifo_t *f, snd_seq_event_cell_t *cell); | 60 | void snd_seq_fifo_cell_putback(struct snd_seq_fifo *f, struct snd_seq_event_cell *cell); |
61 | 61 | ||
62 | /* clean up queue */ | 62 | /* clean up queue */ |
63 | extern void snd_seq_fifo_clear(fifo_t *f); | 63 | void snd_seq_fifo_clear(struct snd_seq_fifo *f); |
64 | 64 | ||
65 | /* polling */ | 65 | /* polling */ |
66 | extern int snd_seq_fifo_poll_wait(fifo_t *f, struct file *file, poll_table *wait); | 66 | int snd_seq_fifo_poll_wait(struct snd_seq_fifo *f, struct file *file, poll_table *wait); |
67 | 67 | ||
68 | /* resize pool in fifo */ | 68 | /* resize pool in fifo */ |
69 | int snd_seq_fifo_resize(fifo_t *f, int poolsize); | 69 | int snd_seq_fifo_resize(struct snd_seq_fifo *f, int poolsize); |
70 | 70 | ||
71 | 71 | ||
72 | #endif | 72 | #endif |
diff --git a/sound/core/seq/seq_info.c b/sound/core/seq/seq_info.c index b50b695c41c4..3257cf4ec258 100644 --- a/sound/core/seq/seq_info.c +++ b/sound/core/seq/seq_info.c | |||
@@ -28,15 +28,16 @@ | |||
28 | #include "seq_timer.h" | 28 | #include "seq_timer.h" |
29 | 29 | ||
30 | 30 | ||
31 | static snd_info_entry_t *queues_entry; | 31 | static struct snd_info_entry *queues_entry; |
32 | static snd_info_entry_t *clients_entry; | 32 | static struct snd_info_entry *clients_entry; |
33 | static snd_info_entry_t *timer_entry; | 33 | static struct snd_info_entry *timer_entry; |
34 | 34 | ||
35 | 35 | ||
36 | static snd_info_entry_t * __init | 36 | static struct snd_info_entry * __init |
37 | create_info_entry(char *name, int size, void (*read)(snd_info_entry_t *, snd_info_buffer_t *)) | 37 | create_info_entry(char *name, int size, void (*read)(struct snd_info_entry *, |
38 | struct snd_info_buffer *)) | ||
38 | { | 39 | { |
39 | snd_info_entry_t *entry; | 40 | struct snd_info_entry *entry; |
40 | 41 | ||
41 | entry = snd_info_create_module_entry(THIS_MODULE, name, snd_seq_root); | 42 | entry = snd_info_create_module_entry(THIS_MODULE, name, snd_seq_root); |
42 | if (entry == NULL) | 43 | if (entry == NULL) |
diff --git a/sound/core/seq/seq_info.h b/sound/core/seq/seq_info.h index efd099a858e4..5a91ebce43a0 100644 --- a/sound/core/seq/seq_info.h +++ b/sound/core/seq/seq_info.h | |||
@@ -24,9 +24,9 @@ | |||
24 | #include <sound/info.h> | 24 | #include <sound/info.h> |
25 | #include <sound/seq_kernel.h> | 25 | #include <sound/seq_kernel.h> |
26 | 26 | ||
27 | void snd_seq_info_clients_read(snd_info_entry_t *entry, snd_info_buffer_t * buffer); | 27 | void snd_seq_info_clients_read(struct snd_info_entry *entry, struct snd_info_buffer *buffer); |
28 | void snd_seq_info_timer_read(snd_info_entry_t *entry, snd_info_buffer_t * buffer); | 28 | void snd_seq_info_timer_read(struct snd_info_entry *entry, struct snd_info_buffer *buffer); |
29 | void snd_seq_info_queues_read(snd_info_entry_t *entry, snd_info_buffer_t * buffer); | 29 | void snd_seq_info_queues_read(struct snd_info_entry *entry, struct snd_info_buffer *buffer); |
30 | 30 | ||
31 | 31 | ||
32 | int snd_seq_info_init( void ); | 32 | int snd_seq_info_init( void ); |
diff --git a/sound/core/seq/seq_instr.c b/sound/core/seq/seq_instr.c index 1d525b13ebb6..487452063965 100644 --- a/sound/core/seq/seq_instr.c +++ b/sound/core/seq/seq_instr.c | |||
@@ -31,7 +31,7 @@ MODULE_DESCRIPTION("Advanced Linux Sound Architecture sequencer instrument libra | |||
31 | MODULE_LICENSE("GPL"); | 31 | MODULE_LICENSE("GPL"); |
32 | 32 | ||
33 | 33 | ||
34 | static void snd_instr_lock_ops(snd_seq_kinstr_list_t *list) | 34 | static void snd_instr_lock_ops(struct snd_seq_kinstr_list *list) |
35 | { | 35 | { |
36 | if (!(list->flags & SNDRV_SEQ_INSTR_FLG_DIRECT)) { | 36 | if (!(list->flags & SNDRV_SEQ_INSTR_FLG_DIRECT)) { |
37 | spin_lock_irqsave(&list->ops_lock, list->ops_flags); | 37 | spin_lock_irqsave(&list->ops_lock, list->ops_flags); |
@@ -40,7 +40,7 @@ static void snd_instr_lock_ops(snd_seq_kinstr_list_t *list) | |||
40 | } | 40 | } |
41 | } | 41 | } |
42 | 42 | ||
43 | static void snd_instr_unlock_ops(snd_seq_kinstr_list_t *list) | 43 | static void snd_instr_unlock_ops(struct snd_seq_kinstr_list *list) |
44 | { | 44 | { |
45 | if (!(list->flags & SNDRV_SEQ_INSTR_FLG_DIRECT)) { | 45 | if (!(list->flags & SNDRV_SEQ_INSTR_FLG_DIRECT)) { |
46 | spin_unlock_irqrestore(&list->ops_lock, list->ops_flags); | 46 | spin_unlock_irqrestore(&list->ops_lock, list->ops_flags); |
@@ -49,18 +49,18 @@ static void snd_instr_unlock_ops(snd_seq_kinstr_list_t *list) | |||
49 | } | 49 | } |
50 | } | 50 | } |
51 | 51 | ||
52 | static snd_seq_kinstr_t *snd_seq_instr_new(int add_len, int atomic) | 52 | static struct snd_seq_kinstr *snd_seq_instr_new(int add_len, int atomic) |
53 | { | 53 | { |
54 | snd_seq_kinstr_t *instr; | 54 | struct snd_seq_kinstr *instr; |
55 | 55 | ||
56 | instr = kzalloc(sizeof(snd_seq_kinstr_t) + add_len, atomic ? GFP_ATOMIC : GFP_KERNEL); | 56 | instr = kzalloc(sizeof(struct snd_seq_kinstr) + add_len, atomic ? GFP_ATOMIC : GFP_KERNEL); |
57 | if (instr == NULL) | 57 | if (instr == NULL) |
58 | return NULL; | 58 | return NULL; |
59 | instr->add_len = add_len; | 59 | instr->add_len = add_len; |
60 | return instr; | 60 | return instr; |
61 | } | 61 | } |
62 | 62 | ||
63 | static int snd_seq_instr_free(snd_seq_kinstr_t *instr, int atomic) | 63 | static int snd_seq_instr_free(struct snd_seq_kinstr *instr, int atomic) |
64 | { | 64 | { |
65 | int result = 0; | 65 | int result = 0; |
66 | 66 | ||
@@ -73,11 +73,11 @@ static int snd_seq_instr_free(snd_seq_kinstr_t *instr, int atomic) | |||
73 | return result; | 73 | return result; |
74 | } | 74 | } |
75 | 75 | ||
76 | snd_seq_kinstr_list_t *snd_seq_instr_list_new(void) | 76 | struct snd_seq_kinstr_list *snd_seq_instr_list_new(void) |
77 | { | 77 | { |
78 | snd_seq_kinstr_list_t *list; | 78 | struct snd_seq_kinstr_list *list; |
79 | 79 | ||
80 | list = kzalloc(sizeof(snd_seq_kinstr_list_t), GFP_KERNEL); | 80 | list = kzalloc(sizeof(struct snd_seq_kinstr_list), GFP_KERNEL); |
81 | if (list == NULL) | 81 | if (list == NULL) |
82 | return NULL; | 82 | return NULL; |
83 | spin_lock_init(&list->lock); | 83 | spin_lock_init(&list->lock); |
@@ -87,11 +87,11 @@ snd_seq_kinstr_list_t *snd_seq_instr_list_new(void) | |||
87 | return list; | 87 | return list; |
88 | } | 88 | } |
89 | 89 | ||
90 | void snd_seq_instr_list_free(snd_seq_kinstr_list_t **list_ptr) | 90 | void snd_seq_instr_list_free(struct snd_seq_kinstr_list **list_ptr) |
91 | { | 91 | { |
92 | snd_seq_kinstr_list_t *list; | 92 | struct snd_seq_kinstr_list *list; |
93 | snd_seq_kinstr_t *instr; | 93 | struct snd_seq_kinstr *instr; |
94 | snd_seq_kcluster_t *cluster; | 94 | struct snd_seq_kcluster *cluster; |
95 | int idx; | 95 | int idx; |
96 | unsigned long flags; | 96 | unsigned long flags; |
97 | 97 | ||
@@ -125,8 +125,8 @@ void snd_seq_instr_list_free(snd_seq_kinstr_list_t **list_ptr) | |||
125 | kfree(list); | 125 | kfree(list); |
126 | } | 126 | } |
127 | 127 | ||
128 | static int instr_free_compare(snd_seq_kinstr_t *instr, | 128 | static int instr_free_compare(struct snd_seq_kinstr *instr, |
129 | snd_seq_instr_header_t *ifree, | 129 | struct snd_seq_instr_header *ifree, |
130 | unsigned int client) | 130 | unsigned int client) |
131 | { | 131 | { |
132 | switch (ifree->cmd) { | 132 | switch (ifree->cmd) { |
@@ -160,12 +160,12 @@ static int instr_free_compare(snd_seq_kinstr_t *instr, | |||
160 | return 1; | 160 | return 1; |
161 | } | 161 | } |
162 | 162 | ||
163 | int snd_seq_instr_list_free_cond(snd_seq_kinstr_list_t *list, | 163 | int snd_seq_instr_list_free_cond(struct snd_seq_kinstr_list *list, |
164 | snd_seq_instr_header_t *ifree, | 164 | struct snd_seq_instr_header *ifree, |
165 | int client, | 165 | int client, |
166 | int atomic) | 166 | int atomic) |
167 | { | 167 | { |
168 | snd_seq_kinstr_t *instr, *prev, *next, *flist; | 168 | struct snd_seq_kinstr *instr, *prev, *next, *flist; |
169 | int idx; | 169 | int idx; |
170 | unsigned long flags; | 170 | unsigned long flags; |
171 | 171 | ||
@@ -209,7 +209,7 @@ int snd_seq_instr_list_free_cond(snd_seq_kinstr_list_t *list, | |||
209 | return 0; | 209 | return 0; |
210 | } | 210 | } |
211 | 211 | ||
212 | static int compute_hash_instr_key(snd_seq_instr_t *instr) | 212 | static int compute_hash_instr_key(struct snd_seq_instr *instr) |
213 | { | 213 | { |
214 | int result; | 214 | int result; |
215 | 215 | ||
@@ -233,7 +233,7 @@ static int compute_hash_cluster_key(snd_seq_instr_cluster_t cluster) | |||
233 | } | 233 | } |
234 | #endif | 234 | #endif |
235 | 235 | ||
236 | static int compare_instr(snd_seq_instr_t *i1, snd_seq_instr_t *i2, int exact) | 236 | static int compare_instr(struct snd_seq_instr *i1, struct snd_seq_instr *i2, int exact) |
237 | { | 237 | { |
238 | if (exact) { | 238 | if (exact) { |
239 | if (i1->cluster != i2->cluster || | 239 | if (i1->cluster != i2->cluster || |
@@ -262,14 +262,14 @@ static int compare_instr(snd_seq_instr_t *i1, snd_seq_instr_t *i2, int exact) | |||
262 | } | 262 | } |
263 | } | 263 | } |
264 | 264 | ||
265 | snd_seq_kinstr_t *snd_seq_instr_find(snd_seq_kinstr_list_t *list, | 265 | struct snd_seq_kinstr *snd_seq_instr_find(struct snd_seq_kinstr_list *list, |
266 | snd_seq_instr_t *instr, | 266 | struct snd_seq_instr *instr, |
267 | int exact, | 267 | int exact, |
268 | int follow_alias) | 268 | int follow_alias) |
269 | { | 269 | { |
270 | unsigned long flags; | 270 | unsigned long flags; |
271 | int depth = 0; | 271 | int depth = 0; |
272 | snd_seq_kinstr_t *result; | 272 | struct snd_seq_kinstr *result; |
273 | 273 | ||
274 | if (list == NULL || instr == NULL) | 274 | if (list == NULL || instr == NULL) |
275 | return NULL; | 275 | return NULL; |
@@ -279,7 +279,7 @@ snd_seq_kinstr_t *snd_seq_instr_find(snd_seq_kinstr_list_t *list, | |||
279 | while (result) { | 279 | while (result) { |
280 | if (!compare_instr(&result->instr, instr, exact)) { | 280 | if (!compare_instr(&result->instr, instr, exact)) { |
281 | if (follow_alias && (result->type == SNDRV_SEQ_INSTR_ATYPE_ALIAS)) { | 281 | if (follow_alias && (result->type == SNDRV_SEQ_INSTR_ATYPE_ALIAS)) { |
282 | instr = (snd_seq_instr_t *)KINSTR_DATA(result); | 282 | instr = (struct snd_seq_instr *)KINSTR_DATA(result); |
283 | if (++depth > 10) | 283 | if (++depth > 10) |
284 | goto __not_found; | 284 | goto __not_found; |
285 | goto __again; | 285 | goto __again; |
@@ -295,8 +295,8 @@ snd_seq_kinstr_t *snd_seq_instr_find(snd_seq_kinstr_list_t *list, | |||
295 | return NULL; | 295 | return NULL; |
296 | } | 296 | } |
297 | 297 | ||
298 | void snd_seq_instr_free_use(snd_seq_kinstr_list_t *list, | 298 | void snd_seq_instr_free_use(struct snd_seq_kinstr_list *list, |
299 | snd_seq_kinstr_t *instr) | 299 | struct snd_seq_kinstr *instr) |
300 | { | 300 | { |
301 | unsigned long flags; | 301 | unsigned long flags; |
302 | 302 | ||
@@ -311,7 +311,8 @@ void snd_seq_instr_free_use(snd_seq_kinstr_list_t *list, | |||
311 | spin_unlock_irqrestore(&list->lock, flags); | 311 | spin_unlock_irqrestore(&list->lock, flags); |
312 | } | 312 | } |
313 | 313 | ||
314 | static snd_seq_kinstr_ops_t *instr_ops(snd_seq_kinstr_ops_t *ops, char *instr_type) | 314 | static struct snd_seq_kinstr_ops *instr_ops(struct snd_seq_kinstr_ops *ops, |
315 | char *instr_type) | ||
315 | { | 316 | { |
316 | while (ops) { | 317 | while (ops) { |
317 | if (!strcmp(ops->instr_type, instr_type)) | 318 | if (!strcmp(ops->instr_type, instr_type)) |
@@ -321,11 +322,11 @@ static snd_seq_kinstr_ops_t *instr_ops(snd_seq_kinstr_ops_t *ops, char *instr_ty | |||
321 | return NULL; | 322 | return NULL; |
322 | } | 323 | } |
323 | 324 | ||
324 | static int instr_result(snd_seq_event_t *ev, | 325 | static int instr_result(struct snd_seq_event *ev, |
325 | int type, int result, | 326 | int type, int result, |
326 | int atomic) | 327 | int atomic) |
327 | { | 328 | { |
328 | snd_seq_event_t sev; | 329 | struct snd_seq_event sev; |
329 | 330 | ||
330 | memset(&sev, 0, sizeof(sev)); | 331 | memset(&sev, 0, sizeof(sev)); |
331 | sev.type = SNDRV_SEQ_EVENT_RESULT; | 332 | sev.type = SNDRV_SEQ_EVENT_RESULT; |
@@ -345,9 +346,9 @@ static int instr_result(snd_seq_event_t *ev, | |||
345 | return snd_seq_kernel_client_dispatch(sev.source.client, &sev, atomic, 0); | 346 | return snd_seq_kernel_client_dispatch(sev.source.client, &sev, atomic, 0); |
346 | } | 347 | } |
347 | 348 | ||
348 | static int instr_begin(snd_seq_kinstr_ops_t *ops, | 349 | static int instr_begin(struct snd_seq_kinstr_ops *ops, |
349 | snd_seq_kinstr_list_t *list, | 350 | struct snd_seq_kinstr_list *list, |
350 | snd_seq_event_t *ev, | 351 | struct snd_seq_event *ev, |
351 | int atomic, int hop) | 352 | int atomic, int hop) |
352 | { | 353 | { |
353 | unsigned long flags; | 354 | unsigned long flags; |
@@ -362,9 +363,9 @@ static int instr_begin(snd_seq_kinstr_ops_t *ops, | |||
362 | return instr_result(ev, SNDRV_SEQ_EVENT_INSTR_BEGIN, 0, atomic); | 363 | return instr_result(ev, SNDRV_SEQ_EVENT_INSTR_BEGIN, 0, atomic); |
363 | } | 364 | } |
364 | 365 | ||
365 | static int instr_end(snd_seq_kinstr_ops_t *ops, | 366 | static int instr_end(struct snd_seq_kinstr_ops *ops, |
366 | snd_seq_kinstr_list_t *list, | 367 | struct snd_seq_kinstr_list *list, |
367 | snd_seq_event_t *ev, | 368 | struct snd_seq_event *ev, |
368 | int atomic, int hop) | 369 | int atomic, int hop) |
369 | { | 370 | { |
370 | unsigned long flags; | 371 | unsigned long flags; |
@@ -380,54 +381,55 @@ static int instr_end(snd_seq_kinstr_ops_t *ops, | |||
380 | return instr_result(ev, SNDRV_SEQ_EVENT_INSTR_END, -EINVAL, atomic); | 381 | return instr_result(ev, SNDRV_SEQ_EVENT_INSTR_END, -EINVAL, atomic); |
381 | } | 382 | } |
382 | 383 | ||
383 | static int instr_info(snd_seq_kinstr_ops_t *ops, | 384 | static int instr_info(struct snd_seq_kinstr_ops *ops, |
384 | snd_seq_kinstr_list_t *list, | 385 | struct snd_seq_kinstr_list *list, |
385 | snd_seq_event_t *ev, | 386 | struct snd_seq_event *ev, |
386 | int atomic, int hop) | 387 | int atomic, int hop) |
387 | { | 388 | { |
388 | return -ENXIO; | 389 | return -ENXIO; |
389 | } | 390 | } |
390 | 391 | ||
391 | static int instr_format_info(snd_seq_kinstr_ops_t *ops, | 392 | static int instr_format_info(struct snd_seq_kinstr_ops *ops, |
392 | snd_seq_kinstr_list_t *list, | 393 | struct snd_seq_kinstr_list *list, |
393 | snd_seq_event_t *ev, | 394 | struct snd_seq_event *ev, |
394 | int atomic, int hop) | 395 | int atomic, int hop) |
395 | { | 396 | { |
396 | return -ENXIO; | 397 | return -ENXIO; |
397 | } | 398 | } |
398 | 399 | ||
399 | static int instr_reset(snd_seq_kinstr_ops_t *ops, | 400 | static int instr_reset(struct snd_seq_kinstr_ops *ops, |
400 | snd_seq_kinstr_list_t *list, | 401 | struct snd_seq_kinstr_list *list, |
401 | snd_seq_event_t *ev, | 402 | struct snd_seq_event *ev, |
402 | int atomic, int hop) | 403 | int atomic, int hop) |
403 | { | 404 | { |
404 | return -ENXIO; | 405 | return -ENXIO; |
405 | } | 406 | } |
406 | 407 | ||
407 | static int instr_status(snd_seq_kinstr_ops_t *ops, | 408 | static int instr_status(struct snd_seq_kinstr_ops *ops, |
408 | snd_seq_kinstr_list_t *list, | 409 | struct snd_seq_kinstr_list *list, |
409 | snd_seq_event_t *ev, | 410 | struct snd_seq_event *ev, |
410 | int atomic, int hop) | 411 | int atomic, int hop) |
411 | { | 412 | { |
412 | return -ENXIO; | 413 | return -ENXIO; |
413 | } | 414 | } |
414 | 415 | ||
415 | static int instr_put(snd_seq_kinstr_ops_t *ops, | 416 | static int instr_put(struct snd_seq_kinstr_ops *ops, |
416 | snd_seq_kinstr_list_t *list, | 417 | struct snd_seq_kinstr_list *list, |
417 | snd_seq_event_t *ev, | 418 | struct snd_seq_event *ev, |
418 | int atomic, int hop) | 419 | int atomic, int hop) |
419 | { | 420 | { |
420 | unsigned long flags; | 421 | unsigned long flags; |
421 | snd_seq_instr_header_t put; | 422 | struct snd_seq_instr_header put; |
422 | snd_seq_kinstr_t *instr; | 423 | struct snd_seq_kinstr *instr; |
423 | int result = -EINVAL, len, key; | 424 | int result = -EINVAL, len, key; |
424 | 425 | ||
425 | if ((ev->flags & SNDRV_SEQ_EVENT_LENGTH_MASK) != SNDRV_SEQ_EVENT_LENGTH_VARUSR) | 426 | if ((ev->flags & SNDRV_SEQ_EVENT_LENGTH_MASK) != SNDRV_SEQ_EVENT_LENGTH_VARUSR) |
426 | goto __return; | 427 | goto __return; |
427 | 428 | ||
428 | if (ev->data.ext.len < sizeof(snd_seq_instr_header_t)) | 429 | if (ev->data.ext.len < sizeof(struct snd_seq_instr_header)) |
429 | goto __return; | 430 | goto __return; |
430 | if (copy_from_user(&put, (void __user *)ev->data.ext.ptr, sizeof(snd_seq_instr_header_t))) { | 431 | if (copy_from_user(&put, (void __user *)ev->data.ext.ptr, |
432 | sizeof(struct snd_seq_instr_header))) { | ||
431 | result = -EFAULT; | 433 | result = -EFAULT; |
432 | goto __return; | 434 | goto __return; |
433 | } | 435 | } |
@@ -449,7 +451,7 @@ static int instr_put(snd_seq_kinstr_ops_t *ops, | |||
449 | } | 451 | } |
450 | len = ops->add_len; | 452 | len = ops->add_len; |
451 | if (put.data.type == SNDRV_SEQ_INSTR_ATYPE_ALIAS) | 453 | if (put.data.type == SNDRV_SEQ_INSTR_ATYPE_ALIAS) |
452 | len = sizeof(snd_seq_instr_t); | 454 | len = sizeof(struct snd_seq_instr); |
453 | instr = snd_seq_instr_new(len, atomic); | 455 | instr = snd_seq_instr_new(len, atomic); |
454 | if (instr == NULL) { | 456 | if (instr == NULL) { |
455 | snd_instr_unlock_ops(list); | 457 | snd_instr_unlock_ops(list); |
@@ -463,8 +465,8 @@ static int instr_put(snd_seq_kinstr_ops_t *ops, | |||
463 | if (instr->type == SNDRV_SEQ_INSTR_ATYPE_DATA) { | 465 | if (instr->type == SNDRV_SEQ_INSTR_ATYPE_DATA) { |
464 | result = ops->put(ops->private_data, | 466 | result = ops->put(ops->private_data, |
465 | instr, | 467 | instr, |
466 | (void __user *)ev->data.ext.ptr + sizeof(snd_seq_instr_header_t), | 468 | (void __user *)ev->data.ext.ptr + sizeof(struct snd_seq_instr_header), |
467 | ev->data.ext.len - sizeof(snd_seq_instr_header_t), | 469 | ev->data.ext.len - sizeof(struct snd_seq_instr_header), |
468 | atomic, | 470 | atomic, |
469 | put.cmd); | 471 | put.cmd); |
470 | if (result < 0) { | 472 | if (result < 0) { |
@@ -486,21 +488,21 @@ static int instr_put(snd_seq_kinstr_ops_t *ops, | |||
486 | return result; | 488 | return result; |
487 | } | 489 | } |
488 | 490 | ||
489 | static int instr_get(snd_seq_kinstr_ops_t *ops, | 491 | static int instr_get(struct snd_seq_kinstr_ops *ops, |
490 | snd_seq_kinstr_list_t *list, | 492 | struct snd_seq_kinstr_list *list, |
491 | snd_seq_event_t *ev, | 493 | struct snd_seq_event *ev, |
492 | int atomic, int hop) | 494 | int atomic, int hop) |
493 | { | 495 | { |
494 | return -ENXIO; | 496 | return -ENXIO; |
495 | } | 497 | } |
496 | 498 | ||
497 | static int instr_free(snd_seq_kinstr_ops_t *ops, | 499 | static int instr_free(struct snd_seq_kinstr_ops *ops, |
498 | snd_seq_kinstr_list_t *list, | 500 | struct snd_seq_kinstr_list *list, |
499 | snd_seq_event_t *ev, | 501 | struct snd_seq_event *ev, |
500 | int atomic, int hop) | 502 | int atomic, int hop) |
501 | { | 503 | { |
502 | snd_seq_instr_header_t ifree; | 504 | struct snd_seq_instr_header ifree; |
503 | snd_seq_kinstr_t *instr, *prev; | 505 | struct snd_seq_kinstr *instr, *prev; |
504 | int result = -EINVAL; | 506 | int result = -EINVAL; |
505 | unsigned long flags; | 507 | unsigned long flags; |
506 | unsigned int hash; | 508 | unsigned int hash; |
@@ -508,9 +510,10 @@ static int instr_free(snd_seq_kinstr_ops_t *ops, | |||
508 | if ((ev->flags & SNDRV_SEQ_EVENT_LENGTH_MASK) != SNDRV_SEQ_EVENT_LENGTH_VARUSR) | 510 | if ((ev->flags & SNDRV_SEQ_EVENT_LENGTH_MASK) != SNDRV_SEQ_EVENT_LENGTH_VARUSR) |
509 | goto __return; | 511 | goto __return; |
510 | 512 | ||
511 | if (ev->data.ext.len < sizeof(snd_seq_instr_header_t)) | 513 | if (ev->data.ext.len < sizeof(struct snd_seq_instr_header)) |
512 | goto __return; | 514 | goto __return; |
513 | if (copy_from_user(&ifree, (void __user *)ev->data.ext.ptr, sizeof(snd_seq_instr_header_t))) { | 515 | if (copy_from_user(&ifree, (void __user *)ev->data.ext.ptr, |
516 | sizeof(struct snd_seq_instr_header))) { | ||
514 | result = -EFAULT; | 517 | result = -EFAULT; |
515 | goto __return; | 518 | goto __return; |
516 | } | 519 | } |
@@ -548,7 +551,8 @@ static int instr_free(snd_seq_kinstr_ops_t *ops, | |||
548 | list->hash[hash] = instr->next; | 551 | list->hash[hash] = instr->next; |
549 | } | 552 | } |
550 | if (instr->ops && instr->ops->notify) | 553 | if (instr->ops && instr->ops->notify) |
551 | instr->ops->notify(instr->ops->private_data, instr, SNDRV_SEQ_INSTR_NOTIFY_REMOVE); | 554 | instr->ops->notify(instr->ops->private_data, instr, |
555 | SNDRV_SEQ_INSTR_NOTIFY_REMOVE); | ||
552 | while (instr->use) { | 556 | while (instr->use) { |
553 | spin_unlock_irqrestore(&list->lock, flags); | 557 | spin_unlock_irqrestore(&list->lock, flags); |
554 | schedule_timeout_interruptible(1); | 558 | schedule_timeout_interruptible(1); |
@@ -565,25 +569,25 @@ static int instr_free(snd_seq_kinstr_ops_t *ops, | |||
565 | return result; | 569 | return result; |
566 | } | 570 | } |
567 | 571 | ||
568 | static int instr_list(snd_seq_kinstr_ops_t *ops, | 572 | static int instr_list(struct snd_seq_kinstr_ops *ops, |
569 | snd_seq_kinstr_list_t *list, | 573 | struct snd_seq_kinstr_list *list, |
570 | snd_seq_event_t *ev, | 574 | struct snd_seq_event *ev, |
571 | int atomic, int hop) | 575 | int atomic, int hop) |
572 | { | 576 | { |
573 | return -ENXIO; | 577 | return -ENXIO; |
574 | } | 578 | } |
575 | 579 | ||
576 | static int instr_cluster(snd_seq_kinstr_ops_t *ops, | 580 | static int instr_cluster(struct snd_seq_kinstr_ops *ops, |
577 | snd_seq_kinstr_list_t *list, | 581 | struct snd_seq_kinstr_list *list, |
578 | snd_seq_event_t *ev, | 582 | struct snd_seq_event *ev, |
579 | int atomic, int hop) | 583 | int atomic, int hop) |
580 | { | 584 | { |
581 | return -ENXIO; | 585 | return -ENXIO; |
582 | } | 586 | } |
583 | 587 | ||
584 | int snd_seq_instr_event(snd_seq_kinstr_ops_t *ops, | 588 | int snd_seq_instr_event(struct snd_seq_kinstr_ops *ops, |
585 | snd_seq_kinstr_list_t *list, | 589 | struct snd_seq_kinstr_list *list, |
586 | snd_seq_event_t *ev, | 590 | struct snd_seq_event *ev, |
587 | int client, | 591 | int client, |
588 | int atomic, | 592 | int atomic, |
589 | int hop) | 593 | int hop) |
diff --git a/sound/core/seq/seq_memory.c b/sound/core/seq/seq_memory.c index 8416bcffa091..9ee6c177db0c 100644 --- a/sound/core/seq/seq_memory.c +++ b/sound/core/seq/seq_memory.c | |||
@@ -36,12 +36,12 @@ | |||
36 | #define semaphore_of(fp) ((fp)->f_dentry->d_inode->i_sem) | 36 | #define semaphore_of(fp) ((fp)->f_dentry->d_inode->i_sem) |
37 | 37 | ||
38 | 38 | ||
39 | static inline int snd_seq_pool_available(pool_t *pool) | 39 | static inline int snd_seq_pool_available(struct snd_seq_pool *pool) |
40 | { | 40 | { |
41 | return pool->total_elements - atomic_read(&pool->counter); | 41 | return pool->total_elements - atomic_read(&pool->counter); |
42 | } | 42 | } |
43 | 43 | ||
44 | static inline int snd_seq_output_ok(pool_t *pool) | 44 | static inline int snd_seq_output_ok(struct snd_seq_pool *pool) |
45 | { | 45 | { |
46 | return snd_seq_pool_available(pool) >= pool->room; | 46 | return snd_seq_pool_available(pool) >= pool->room; |
47 | } | 47 | } |
@@ -72,7 +72,7 @@ static inline int snd_seq_output_ok(pool_t *pool) | |||
72 | * call dump function to expand external data. | 72 | * call dump function to expand external data. |
73 | */ | 73 | */ |
74 | 74 | ||
75 | static int get_var_len(const snd_seq_event_t *event) | 75 | static int get_var_len(const struct snd_seq_event *event) |
76 | { | 76 | { |
77 | if ((event->flags & SNDRV_SEQ_EVENT_LENGTH_MASK) != SNDRV_SEQ_EVENT_LENGTH_VARIABLE) | 77 | if ((event->flags & SNDRV_SEQ_EVENT_LENGTH_MASK) != SNDRV_SEQ_EVENT_LENGTH_VARIABLE) |
78 | return -EINVAL; | 78 | return -EINVAL; |
@@ -80,10 +80,11 @@ static int get_var_len(const snd_seq_event_t *event) | |||
80 | return event->data.ext.len & ~SNDRV_SEQ_EXT_MASK; | 80 | return event->data.ext.len & ~SNDRV_SEQ_EXT_MASK; |
81 | } | 81 | } |
82 | 82 | ||
83 | int snd_seq_dump_var_event(const snd_seq_event_t *event, snd_seq_dump_func_t func, void *private_data) | 83 | int snd_seq_dump_var_event(const struct snd_seq_event *event, |
84 | snd_seq_dump_func_t func, void *private_data) | ||
84 | { | 85 | { |
85 | int len, err; | 86 | int len, err; |
86 | snd_seq_event_cell_t *cell; | 87 | struct snd_seq_event_cell *cell; |
87 | 88 | ||
88 | if ((len = get_var_len(event)) <= 0) | 89 | if ((len = get_var_len(event)) <= 0) |
89 | return len; | 90 | return len; |
@@ -108,9 +109,9 @@ int snd_seq_dump_var_event(const snd_seq_event_t *event, snd_seq_dump_func_t fun | |||
108 | return func(private_data, event->data.ext.ptr, len); | 109 | return func(private_data, event->data.ext.ptr, len); |
109 | } | 110 | } |
110 | 111 | ||
111 | cell = (snd_seq_event_cell_t*)event->data.ext.ptr; | 112 | cell = (struct snd_seq_event_cell *)event->data.ext.ptr; |
112 | for (; len > 0 && cell; cell = cell->next) { | 113 | for (; len > 0 && cell; cell = cell->next) { |
113 | int size = sizeof(snd_seq_event_t); | 114 | int size = sizeof(struct snd_seq_event); |
114 | if (len < size) | 115 | if (len < size) |
115 | size = len; | 116 | size = len; |
116 | err = func(private_data, &cell->event, size); | 117 | err = func(private_data, &cell->event, size); |
@@ -142,7 +143,8 @@ static int seq_copy_in_user(char __user **bufptr, const void *src, int size) | |||
142 | return 0; | 143 | return 0; |
143 | } | 144 | } |
144 | 145 | ||
145 | int snd_seq_expand_var_event(const snd_seq_event_t *event, int count, char *buf, int in_kernel, int size_aligned) | 146 | int snd_seq_expand_var_event(const struct snd_seq_event *event, int count, char *buf, |
147 | int in_kernel, int size_aligned) | ||
146 | { | 148 | { |
147 | int len, newlen; | 149 | int len, newlen; |
148 | int err; | 150 | int err; |
@@ -174,17 +176,18 @@ int snd_seq_expand_var_event(const snd_seq_event_t *event, int count, char *buf, | |||
174 | * release this cell, free extended data if available | 176 | * release this cell, free extended data if available |
175 | */ | 177 | */ |
176 | 178 | ||
177 | static inline void free_cell(pool_t *pool, snd_seq_event_cell_t *cell) | 179 | static inline void free_cell(struct snd_seq_pool *pool, |
180 | struct snd_seq_event_cell *cell) | ||
178 | { | 181 | { |
179 | cell->next = pool->free; | 182 | cell->next = pool->free; |
180 | pool->free = cell; | 183 | pool->free = cell; |
181 | atomic_dec(&pool->counter); | 184 | atomic_dec(&pool->counter); |
182 | } | 185 | } |
183 | 186 | ||
184 | void snd_seq_cell_free(snd_seq_event_cell_t * cell) | 187 | void snd_seq_cell_free(struct snd_seq_event_cell * cell) |
185 | { | 188 | { |
186 | unsigned long flags; | 189 | unsigned long flags; |
187 | pool_t *pool; | 190 | struct snd_seq_pool *pool; |
188 | 191 | ||
189 | snd_assert(cell != NULL, return); | 192 | snd_assert(cell != NULL, return); |
190 | pool = cell->pool; | 193 | pool = cell->pool; |
@@ -194,7 +197,7 @@ void snd_seq_cell_free(snd_seq_event_cell_t * cell) | |||
194 | free_cell(pool, cell); | 197 | free_cell(pool, cell); |
195 | if (snd_seq_ev_is_variable(&cell->event)) { | 198 | if (snd_seq_ev_is_variable(&cell->event)) { |
196 | if (cell->event.data.ext.len & SNDRV_SEQ_EXT_CHAINED) { | 199 | if (cell->event.data.ext.len & SNDRV_SEQ_EXT_CHAINED) { |
197 | snd_seq_event_cell_t *curp, *nextptr; | 200 | struct snd_seq_event_cell *curp, *nextptr; |
198 | curp = cell->event.data.ext.ptr; | 201 | curp = cell->event.data.ext.ptr; |
199 | for (; curp; curp = nextptr) { | 202 | for (; curp; curp = nextptr) { |
200 | nextptr = curp->next; | 203 | nextptr = curp->next; |
@@ -215,9 +218,11 @@ void snd_seq_cell_free(snd_seq_event_cell_t * cell) | |||
215 | /* | 218 | /* |
216 | * allocate an event cell. | 219 | * allocate an event cell. |
217 | */ | 220 | */ |
218 | static int snd_seq_cell_alloc(pool_t *pool, snd_seq_event_cell_t **cellp, int nonblock, struct file *file) | 221 | static int snd_seq_cell_alloc(struct snd_seq_pool *pool, |
222 | struct snd_seq_event_cell **cellp, | ||
223 | int nonblock, struct file *file) | ||
219 | { | 224 | { |
220 | snd_seq_event_cell_t *cell; | 225 | struct snd_seq_event_cell *cell; |
221 | unsigned long flags; | 226 | unsigned long flags; |
222 | int err = -EAGAIN; | 227 | int err = -EAGAIN; |
223 | wait_queue_t wait; | 228 | wait_queue_t wait; |
@@ -280,11 +285,13 @@ __error: | |||
280 | * if the event has external data, the data is decomposed to additional | 285 | * if the event has external data, the data is decomposed to additional |
281 | * cells. | 286 | * cells. |
282 | */ | 287 | */ |
283 | int snd_seq_event_dup(pool_t *pool, snd_seq_event_t *event, snd_seq_event_cell_t **cellp, int nonblock, struct file *file) | 288 | int snd_seq_event_dup(struct snd_seq_pool *pool, struct snd_seq_event *event, |
289 | struct snd_seq_event_cell **cellp, int nonblock, | ||
290 | struct file *file) | ||
284 | { | 291 | { |
285 | int ncells, err; | 292 | int ncells, err; |
286 | unsigned int extlen; | 293 | unsigned int extlen; |
287 | snd_seq_event_cell_t *cell; | 294 | struct snd_seq_event_cell *cell; |
288 | 295 | ||
289 | *cellp = NULL; | 296 | *cellp = NULL; |
290 | 297 | ||
@@ -292,7 +299,7 @@ int snd_seq_event_dup(pool_t *pool, snd_seq_event_t *event, snd_seq_event_cell_t | |||
292 | extlen = 0; | 299 | extlen = 0; |
293 | if (snd_seq_ev_is_variable(event)) { | 300 | if (snd_seq_ev_is_variable(event)) { |
294 | extlen = event->data.ext.len & ~SNDRV_SEQ_EXT_MASK; | 301 | extlen = event->data.ext.len & ~SNDRV_SEQ_EXT_MASK; |
295 | ncells = (extlen + sizeof(snd_seq_event_t) - 1) / sizeof(snd_seq_event_t); | 302 | ncells = (extlen + sizeof(struct snd_seq_event) - 1) / sizeof(struct snd_seq_event); |
296 | } | 303 | } |
297 | if (ncells >= pool->total_elements) | 304 | if (ncells >= pool->total_elements) |
298 | return -ENOMEM; | 305 | return -ENOMEM; |
@@ -309,18 +316,18 @@ int snd_seq_event_dup(pool_t *pool, snd_seq_event_t *event, snd_seq_event_cell_t | |||
309 | int len = extlen; | 316 | int len = extlen; |
310 | int is_chained = event->data.ext.len & SNDRV_SEQ_EXT_CHAINED; | 317 | int is_chained = event->data.ext.len & SNDRV_SEQ_EXT_CHAINED; |
311 | int is_usrptr = event->data.ext.len & SNDRV_SEQ_EXT_USRPTR; | 318 | int is_usrptr = event->data.ext.len & SNDRV_SEQ_EXT_USRPTR; |
312 | snd_seq_event_cell_t *src, *tmp, *tail; | 319 | struct snd_seq_event_cell *src, *tmp, *tail; |
313 | char *buf; | 320 | char *buf; |
314 | 321 | ||
315 | cell->event.data.ext.len = extlen | SNDRV_SEQ_EXT_CHAINED; | 322 | cell->event.data.ext.len = extlen | SNDRV_SEQ_EXT_CHAINED; |
316 | cell->event.data.ext.ptr = NULL; | 323 | cell->event.data.ext.ptr = NULL; |
317 | 324 | ||
318 | src = (snd_seq_event_cell_t*)event->data.ext.ptr; | 325 | src = (struct snd_seq_event_cell *)event->data.ext.ptr; |
319 | buf = (char *)event->data.ext.ptr; | 326 | buf = (char *)event->data.ext.ptr; |
320 | tail = NULL; | 327 | tail = NULL; |
321 | 328 | ||
322 | while (ncells-- > 0) { | 329 | while (ncells-- > 0) { |
323 | int size = sizeof(snd_seq_event_t); | 330 | int size = sizeof(struct snd_seq_event); |
324 | if (len < size) | 331 | if (len < size) |
325 | size = len; | 332 | size = len; |
326 | err = snd_seq_cell_alloc(pool, &tmp, nonblock, file); | 333 | err = snd_seq_cell_alloc(pool, &tmp, nonblock, file); |
@@ -358,7 +365,8 @@ __error: | |||
358 | 365 | ||
359 | 366 | ||
360 | /* poll wait */ | 367 | /* poll wait */ |
361 | int snd_seq_pool_poll_wait(pool_t *pool, struct file *file, poll_table *wait) | 368 | int snd_seq_pool_poll_wait(struct snd_seq_pool *pool, struct file *file, |
369 | poll_table *wait) | ||
362 | { | 370 | { |
363 | poll_wait(file, &pool->output_sleep, wait); | 371 | poll_wait(file, &pool->output_sleep, wait); |
364 | return snd_seq_output_ok(pool); | 372 | return snd_seq_output_ok(pool); |
@@ -366,17 +374,17 @@ int snd_seq_pool_poll_wait(pool_t *pool, struct file *file, poll_table *wait) | |||
366 | 374 | ||
367 | 375 | ||
368 | /* allocate room specified number of events */ | 376 | /* allocate room specified number of events */ |
369 | int snd_seq_pool_init(pool_t *pool) | 377 | int snd_seq_pool_init(struct snd_seq_pool *pool) |
370 | { | 378 | { |
371 | int cell; | 379 | int cell; |
372 | snd_seq_event_cell_t *cellptr; | 380 | struct snd_seq_event_cell *cellptr; |
373 | unsigned long flags; | 381 | unsigned long flags; |
374 | 382 | ||
375 | snd_assert(pool != NULL, return -EINVAL); | 383 | snd_assert(pool != NULL, return -EINVAL); |
376 | if (pool->ptr) /* should be atomic? */ | 384 | if (pool->ptr) /* should be atomic? */ |
377 | return 0; | 385 | return 0; |
378 | 386 | ||
379 | pool->ptr = vmalloc(sizeof(snd_seq_event_cell_t) * pool->size); | 387 | pool->ptr = vmalloc(sizeof(struct snd_seq_event_cell) * pool->size); |
380 | if (pool->ptr == NULL) { | 388 | if (pool->ptr == NULL) { |
381 | snd_printd("seq: malloc for sequencer events failed\n"); | 389 | snd_printd("seq: malloc for sequencer events failed\n"); |
382 | return -ENOMEM; | 390 | return -ENOMEM; |
@@ -402,10 +410,10 @@ int snd_seq_pool_init(pool_t *pool) | |||
402 | } | 410 | } |
403 | 411 | ||
404 | /* remove events */ | 412 | /* remove events */ |
405 | int snd_seq_pool_done(pool_t *pool) | 413 | int snd_seq_pool_done(struct snd_seq_pool *pool) |
406 | { | 414 | { |
407 | unsigned long flags; | 415 | unsigned long flags; |
408 | snd_seq_event_cell_t *ptr; | 416 | struct snd_seq_event_cell *ptr; |
409 | int max_count = 5 * HZ; | 417 | int max_count = 5 * HZ; |
410 | 418 | ||
411 | snd_assert(pool != NULL, return -EINVAL); | 419 | snd_assert(pool != NULL, return -EINVAL); |
@@ -446,9 +454,9 @@ int snd_seq_pool_done(pool_t *pool) | |||
446 | 454 | ||
447 | 455 | ||
448 | /* init new memory pool */ | 456 | /* init new memory pool */ |
449 | pool_t *snd_seq_pool_new(int poolsize) | 457 | struct snd_seq_pool *snd_seq_pool_new(int poolsize) |
450 | { | 458 | { |
451 | pool_t *pool; | 459 | struct snd_seq_pool *pool; |
452 | 460 | ||
453 | /* create pool block */ | 461 | /* create pool block */ |
454 | pool = kzalloc(sizeof(*pool), GFP_KERNEL); | 462 | pool = kzalloc(sizeof(*pool), GFP_KERNEL); |
@@ -472,9 +480,9 @@ pool_t *snd_seq_pool_new(int poolsize) | |||
472 | } | 480 | } |
473 | 481 | ||
474 | /* remove memory pool */ | 482 | /* remove memory pool */ |
475 | int snd_seq_pool_delete(pool_t **ppool) | 483 | int snd_seq_pool_delete(struct snd_seq_pool **ppool) |
476 | { | 484 | { |
477 | pool_t *pool = *ppool; | 485 | struct snd_seq_pool *pool = *ppool; |
478 | 486 | ||
479 | *ppool = NULL; | 487 | *ppool = NULL; |
480 | if (pool == NULL) | 488 | if (pool == NULL) |
@@ -497,7 +505,8 @@ void __exit snd_sequencer_memory_done(void) | |||
497 | 505 | ||
498 | 506 | ||
499 | /* exported to seq_clientmgr.c */ | 507 | /* exported to seq_clientmgr.c */ |
500 | void snd_seq_info_pool(snd_info_buffer_t * buffer, pool_t *pool, char *space) | 508 | void snd_seq_info_pool(struct snd_info_buffer *buffer, |
509 | struct snd_seq_pool *pool, char *space) | ||
501 | { | 510 | { |
502 | if (pool == NULL) | 511 | if (pool == NULL) |
503 | return; | 512 | return; |
diff --git a/sound/core/seq/seq_memory.h b/sound/core/seq/seq_memory.h index 6c4dde5d3d6f..39c60d9e1efc 100644 --- a/sound/core/seq/seq_memory.h +++ b/sound/core/seq/seq_memory.h | |||
@@ -24,23 +24,21 @@ | |||
24 | #include <sound/seq_kernel.h> | 24 | #include <sound/seq_kernel.h> |
25 | #include <linux/poll.h> | 25 | #include <linux/poll.h> |
26 | 26 | ||
27 | typedef struct pool pool_t; | ||
28 | |||
29 | /* container for sequencer event (internal use) */ | 27 | /* container for sequencer event (internal use) */ |
30 | typedef struct snd_seq_event_cell_t { | 28 | struct snd_seq_event_cell { |
31 | snd_seq_event_t event; | 29 | struct snd_seq_event event; |
32 | pool_t *pool; /* used pool */ | 30 | struct snd_seq_pool *pool; /* used pool */ |
33 | struct snd_seq_event_cell_t *next; /* next cell */ | 31 | struct snd_seq_event_cell *next; /* next cell */ |
34 | } snd_seq_event_cell_t; | 32 | }; |
35 | 33 | ||
36 | /* design note: the pool is a contigious block of memory, if we dynamicly | 34 | /* design note: the pool is a contigious block of memory, if we dynamicly |
37 | want to add additional cells to the pool be better store this in another | 35 | want to add additional cells to the pool be better store this in another |
38 | pool as we need to know the base address of the pool when releasing | 36 | pool as we need to know the base address of the pool when releasing |
39 | memory. */ | 37 | memory. */ |
40 | 38 | ||
41 | struct pool { | 39 | struct snd_seq_pool { |
42 | snd_seq_event_cell_t *ptr; /* pointer to first event chunk */ | 40 | struct snd_seq_event_cell *ptr; /* pointer to first event chunk */ |
43 | snd_seq_event_cell_t *free; /* pointer to the head of the free list */ | 41 | struct snd_seq_event_cell *free; /* pointer to the head of the free list */ |
44 | 42 | ||
45 | int total_elements; /* pool size actually allocated */ | 43 | int total_elements; /* pool size actually allocated */ |
46 | atomic_t counter; /* cells free */ | 44 | atomic_t counter; /* cells free */ |
@@ -63,33 +61,34 @@ struct pool { | |||
63 | spinlock_t lock; | 61 | spinlock_t lock; |
64 | }; | 62 | }; |
65 | 63 | ||
66 | extern void snd_seq_cell_free(snd_seq_event_cell_t* cell); | 64 | void snd_seq_cell_free(struct snd_seq_event_cell *cell); |
67 | 65 | ||
68 | int snd_seq_event_dup(pool_t *pool, snd_seq_event_t *event, snd_seq_event_cell_t **cellp, int nonblock, struct file *file); | 66 | int snd_seq_event_dup(struct snd_seq_pool *pool, struct snd_seq_event *event, |
67 | struct snd_seq_event_cell **cellp, int nonblock, struct file *file); | ||
69 | 68 | ||
70 | /* return number of unused (free) cells */ | 69 | /* return number of unused (free) cells */ |
71 | static inline int snd_seq_unused_cells(pool_t *pool) | 70 | static inline int snd_seq_unused_cells(struct snd_seq_pool *pool) |
72 | { | 71 | { |
73 | return pool ? pool->total_elements - atomic_read(&pool->counter) : 0; | 72 | return pool ? pool->total_elements - atomic_read(&pool->counter) : 0; |
74 | } | 73 | } |
75 | 74 | ||
76 | /* return total number of allocated cells */ | 75 | /* return total number of allocated cells */ |
77 | static inline int snd_seq_total_cells(pool_t *pool) | 76 | static inline int snd_seq_total_cells(struct snd_seq_pool *pool) |
78 | { | 77 | { |
79 | return pool ? pool->total_elements : 0; | 78 | return pool ? pool->total_elements : 0; |
80 | } | 79 | } |
81 | 80 | ||
82 | /* init pool - allocate events */ | 81 | /* init pool - allocate events */ |
83 | int snd_seq_pool_init(pool_t *pool); | 82 | int snd_seq_pool_init(struct snd_seq_pool *pool); |
84 | 83 | ||
85 | /* done pool - free events */ | 84 | /* done pool - free events */ |
86 | int snd_seq_pool_done(pool_t *pool); | 85 | int snd_seq_pool_done(struct snd_seq_pool *pool); |
87 | 86 | ||
88 | /* create pool */ | 87 | /* create pool */ |
89 | pool_t *snd_seq_pool_new(int poolsize); | 88 | struct snd_seq_pool *snd_seq_pool_new(int poolsize); |
90 | 89 | ||
91 | /* remove pool */ | 90 | /* remove pool */ |
92 | int snd_seq_pool_delete(pool_t **pool); | 91 | int snd_seq_pool_delete(struct snd_seq_pool **pool); |
93 | 92 | ||
94 | /* init memory */ | 93 | /* init memory */ |
95 | int snd_sequencer_memory_init(void); | 94 | int snd_sequencer_memory_init(void); |
@@ -98,7 +97,7 @@ int snd_sequencer_memory_init(void); | |||
98 | void snd_sequencer_memory_done(void); | 97 | void snd_sequencer_memory_done(void); |
99 | 98 | ||
100 | /* polling */ | 99 | /* polling */ |
101 | int snd_seq_pool_poll_wait(pool_t *pool, struct file *file, poll_table *wait); | 100 | int snd_seq_pool_poll_wait(struct snd_seq_pool *pool, struct file *file, poll_table *wait); |
102 | 101 | ||
103 | 102 | ||
104 | #endif | 103 | #endif |
diff --git a/sound/core/seq/seq_midi.c b/sound/core/seq/seq_midi.c index f89f40f44876..f88d2e3ee66e 100644 --- a/sound/core/seq/seq_midi.c +++ b/sound/core/seq/seq_midi.c | |||
@@ -51,40 +51,40 @@ module_param(input_buffer_size, int, 0644); | |||
51 | MODULE_PARM_DESC(input_buffer_size, "Input buffer size in bytes."); | 51 | MODULE_PARM_DESC(input_buffer_size, "Input buffer size in bytes."); |
52 | 52 | ||
53 | /* data for this midi synth driver */ | 53 | /* data for this midi synth driver */ |
54 | typedef struct { | 54 | struct seq_midisynth { |
55 | snd_card_t *card; | 55 | struct snd_card *card; |
56 | int device; | 56 | int device; |
57 | int subdevice; | 57 | int subdevice; |
58 | snd_rawmidi_file_t input_rfile; | 58 | struct snd_rawmidi_file input_rfile; |
59 | snd_rawmidi_file_t output_rfile; | 59 | struct snd_rawmidi_file output_rfile; |
60 | int seq_client; | 60 | int seq_client; |
61 | int seq_port; | 61 | int seq_port; |
62 | snd_midi_event_t *parser; | 62 | struct snd_midi_event *parser; |
63 | } seq_midisynth_t; | 63 | }; |
64 | 64 | ||
65 | typedef struct { | 65 | struct seq_midisynth_client { |
66 | int seq_client; | 66 | int seq_client; |
67 | int num_ports; | 67 | int num_ports; |
68 | int ports_per_device[SNDRV_RAWMIDI_DEVICES]; | 68 | int ports_per_device[SNDRV_RAWMIDI_DEVICES]; |
69 | seq_midisynth_t *ports[SNDRV_RAWMIDI_DEVICES]; | 69 | struct seq_midisynth *ports[SNDRV_RAWMIDI_DEVICES]; |
70 | } seq_midisynth_client_t; | 70 | }; |
71 | 71 | ||
72 | static seq_midisynth_client_t *synths[SNDRV_CARDS]; | 72 | static struct seq_midisynth_client *synths[SNDRV_CARDS]; |
73 | static DECLARE_MUTEX(register_mutex); | 73 | static DECLARE_MUTEX(register_mutex); |
74 | 74 | ||
75 | /* handle rawmidi input event (MIDI v1.0 stream) */ | 75 | /* handle rawmidi input event (MIDI v1.0 stream) */ |
76 | static void snd_midi_input_event(snd_rawmidi_substream_t * substream) | 76 | static void snd_midi_input_event(struct snd_rawmidi_substream *substream) |
77 | { | 77 | { |
78 | snd_rawmidi_runtime_t *runtime; | 78 | struct snd_rawmidi_runtime *runtime; |
79 | seq_midisynth_t *msynth; | 79 | struct seq_midisynth *msynth; |
80 | snd_seq_event_t ev; | 80 | struct snd_seq_event ev; |
81 | char buf[16], *pbuf; | 81 | char buf[16], *pbuf; |
82 | long res, count; | 82 | long res, count; |
83 | 83 | ||
84 | if (substream == NULL) | 84 | if (substream == NULL) |
85 | return; | 85 | return; |
86 | runtime = substream->runtime; | 86 | runtime = substream->runtime; |
87 | msynth = (seq_midisynth_t *) runtime->private_data; | 87 | msynth = runtime->private_data; |
88 | if (msynth == NULL) | 88 | if (msynth == NULL) |
89 | return; | 89 | return; |
90 | memset(&ev, 0, sizeof(ev)); | 90 | memset(&ev, 0, sizeof(ev)); |
@@ -112,9 +112,9 @@ static void snd_midi_input_event(snd_rawmidi_substream_t * substream) | |||
112 | } | 112 | } |
113 | } | 113 | } |
114 | 114 | ||
115 | static int dump_midi(snd_rawmidi_substream_t *substream, const char *buf, int count) | 115 | static int dump_midi(struct snd_rawmidi_substream *substream, const char *buf, int count) |
116 | { | 116 | { |
117 | snd_rawmidi_runtime_t *runtime; | 117 | struct snd_rawmidi_runtime *runtime; |
118 | int tmp; | 118 | int tmp; |
119 | 119 | ||
120 | snd_assert(substream != NULL || buf != NULL, return -EINVAL); | 120 | snd_assert(substream != NULL || buf != NULL, return -EINVAL); |
@@ -128,12 +128,12 @@ static int dump_midi(snd_rawmidi_substream_t *substream, const char *buf, int co | |||
128 | return 0; | 128 | return 0; |
129 | } | 129 | } |
130 | 130 | ||
131 | static int event_process_midi(snd_seq_event_t * ev, int direct, | 131 | static int event_process_midi(struct snd_seq_event *ev, int direct, |
132 | void *private_data, int atomic, int hop) | 132 | void *private_data, int atomic, int hop) |
133 | { | 133 | { |
134 | seq_midisynth_t *msynth = (seq_midisynth_t *) private_data; | 134 | struct seq_midisynth *msynth = private_data; |
135 | unsigned char msg[10]; /* buffer for constructing midi messages */ | 135 | unsigned char msg[10]; /* buffer for constructing midi messages */ |
136 | snd_rawmidi_substream_t *substream; | 136 | struct snd_rawmidi_substream *substream; |
137 | int len; | 137 | int len; |
138 | 138 | ||
139 | snd_assert(msynth != NULL, return -EINVAL); | 139 | snd_assert(msynth != NULL, return -EINVAL); |
@@ -161,8 +161,8 @@ static int event_process_midi(snd_seq_event_t * ev, int direct, | |||
161 | } | 161 | } |
162 | 162 | ||
163 | 163 | ||
164 | static int snd_seq_midisynth_new(seq_midisynth_t *msynth, | 164 | static int snd_seq_midisynth_new(struct seq_midisynth *msynth, |
165 | snd_card_t *card, | 165 | struct snd_card *card, |
166 | int device, | 166 | int device, |
167 | int subdevice) | 167 | int subdevice) |
168 | { | 168 | { |
@@ -175,12 +175,12 @@ static int snd_seq_midisynth_new(seq_midisynth_t *msynth, | |||
175 | } | 175 | } |
176 | 176 | ||
177 | /* open associated midi device for input */ | 177 | /* open associated midi device for input */ |
178 | static int midisynth_subscribe(void *private_data, snd_seq_port_subscribe_t *info) | 178 | static int midisynth_subscribe(void *private_data, struct snd_seq_port_subscribe *info) |
179 | { | 179 | { |
180 | int err; | 180 | int err; |
181 | seq_midisynth_t *msynth = (seq_midisynth_t *)private_data; | 181 | struct seq_midisynth *msynth = private_data; |
182 | snd_rawmidi_runtime_t *runtime; | 182 | struct snd_rawmidi_runtime *runtime; |
183 | snd_rawmidi_params_t params; | 183 | struct snd_rawmidi_params params; |
184 | 184 | ||
185 | /* open midi port */ | 185 | /* open midi port */ |
186 | if ((err = snd_rawmidi_kernel_open(msynth->card->number, msynth->device, msynth->subdevice, SNDRV_RAWMIDI_LFLG_INPUT, &msynth->input_rfile)) < 0) { | 186 | if ((err = snd_rawmidi_kernel_open(msynth->card->number, msynth->device, msynth->subdevice, SNDRV_RAWMIDI_LFLG_INPUT, &msynth->input_rfile)) < 0) { |
@@ -203,10 +203,10 @@ static int midisynth_subscribe(void *private_data, snd_seq_port_subscribe_t *inf | |||
203 | } | 203 | } |
204 | 204 | ||
205 | /* close associated midi device for input */ | 205 | /* close associated midi device for input */ |
206 | static int midisynth_unsubscribe(void *private_data, snd_seq_port_subscribe_t *info) | 206 | static int midisynth_unsubscribe(void *private_data, struct snd_seq_port_subscribe *info) |
207 | { | 207 | { |
208 | int err; | 208 | int err; |
209 | seq_midisynth_t *msynth = (seq_midisynth_t *)private_data; | 209 | struct seq_midisynth *msynth = private_data; |
210 | 210 | ||
211 | snd_assert(msynth->input_rfile.input != NULL, return -EINVAL); | 211 | snd_assert(msynth->input_rfile.input != NULL, return -EINVAL); |
212 | err = snd_rawmidi_kernel_release(&msynth->input_rfile); | 212 | err = snd_rawmidi_kernel_release(&msynth->input_rfile); |
@@ -214,11 +214,11 @@ static int midisynth_unsubscribe(void *private_data, snd_seq_port_subscribe_t *i | |||
214 | } | 214 | } |
215 | 215 | ||
216 | /* open associated midi device for output */ | 216 | /* open associated midi device for output */ |
217 | static int midisynth_use(void *private_data, snd_seq_port_subscribe_t *info) | 217 | static int midisynth_use(void *private_data, struct snd_seq_port_subscribe *info) |
218 | { | 218 | { |
219 | int err; | 219 | int err; |
220 | seq_midisynth_t *msynth = (seq_midisynth_t *)private_data; | 220 | struct seq_midisynth *msynth = private_data; |
221 | snd_rawmidi_params_t params; | 221 | struct snd_rawmidi_params params; |
222 | 222 | ||
223 | /* open midi port */ | 223 | /* open midi port */ |
224 | if ((err = snd_rawmidi_kernel_open(msynth->card->number, msynth->device, msynth->subdevice, SNDRV_RAWMIDI_LFLG_OUTPUT, &msynth->output_rfile)) < 0) { | 224 | if ((err = snd_rawmidi_kernel_open(msynth->card->number, msynth->device, msynth->subdevice, SNDRV_RAWMIDI_LFLG_OUTPUT, &msynth->output_rfile)) < 0) { |
@@ -237,9 +237,9 @@ static int midisynth_use(void *private_data, snd_seq_port_subscribe_t *info) | |||
237 | } | 237 | } |
238 | 238 | ||
239 | /* close associated midi device for output */ | 239 | /* close associated midi device for output */ |
240 | static int midisynth_unuse(void *private_data, snd_seq_port_subscribe_t *info) | 240 | static int midisynth_unuse(void *private_data, struct snd_seq_port_subscribe *info) |
241 | { | 241 | { |
242 | seq_midisynth_t *msynth = (seq_midisynth_t *)private_data; | 242 | struct seq_midisynth *msynth = private_data; |
243 | unsigned char buf = 0xff; /* MIDI reset */ | 243 | unsigned char buf = 0xff; /* MIDI reset */ |
244 | 244 | ||
245 | snd_assert(msynth->output_rfile.output != NULL, return -EINVAL); | 245 | snd_assert(msynth->output_rfile.output != NULL, return -EINVAL); |
@@ -250,7 +250,7 @@ static int midisynth_unuse(void *private_data, snd_seq_port_subscribe_t *info) | |||
250 | } | 250 | } |
251 | 251 | ||
252 | /* delete given midi synth port */ | 252 | /* delete given midi synth port */ |
253 | static void snd_seq_midisynth_delete(seq_midisynth_t *msynth) | 253 | static void snd_seq_midisynth_delete(struct seq_midisynth *msynth) |
254 | { | 254 | { |
255 | if (msynth == NULL) | 255 | if (msynth == NULL) |
256 | return; | 256 | return; |
@@ -265,10 +265,10 @@ static void snd_seq_midisynth_delete(seq_midisynth_t *msynth) | |||
265 | } | 265 | } |
266 | 266 | ||
267 | /* set our client name */ | 267 | /* set our client name */ |
268 | static int set_client_name(seq_midisynth_client_t *client, snd_card_t *card, | 268 | static int set_client_name(struct seq_midisynth_client *client, struct snd_card *card, |
269 | snd_rawmidi_info_t *rmidi) | 269 | struct snd_rawmidi_info *rmidi) |
270 | { | 270 | { |
271 | snd_seq_client_info_t cinfo; | 271 | struct snd_seq_client_info cinfo; |
272 | const char *name; | 272 | const char *name; |
273 | 273 | ||
274 | memset(&cinfo, 0, sizeof(cinfo)); | 274 | memset(&cinfo, 0, sizeof(cinfo)); |
@@ -281,17 +281,17 @@ static int set_client_name(seq_midisynth_client_t *client, snd_card_t *card, | |||
281 | 281 | ||
282 | /* register new midi synth port */ | 282 | /* register new midi synth port */ |
283 | static int | 283 | static int |
284 | snd_seq_midisynth_register_port(snd_seq_device_t *dev) | 284 | snd_seq_midisynth_register_port(struct snd_seq_device *dev) |
285 | { | 285 | { |
286 | seq_midisynth_client_t *client; | 286 | struct seq_midisynth_client *client; |
287 | seq_midisynth_t *msynth, *ms; | 287 | struct seq_midisynth *msynth, *ms; |
288 | snd_seq_port_info_t *port; | 288 | struct snd_seq_port_info *port; |
289 | snd_rawmidi_info_t *info; | 289 | struct snd_rawmidi_info *info; |
290 | int newclient = 0; | 290 | int newclient = 0; |
291 | unsigned int p, ports; | 291 | unsigned int p, ports; |
292 | snd_seq_client_callback_t callbacks; | 292 | struct snd_seq_client_callback callbacks; |
293 | snd_seq_port_callback_t pcallbacks; | 293 | struct snd_seq_port_callback pcallbacks; |
294 | snd_card_t *card = dev->card; | 294 | struct snd_card *card = dev->card; |
295 | int device = dev->device; | 295 | int device = dev->device; |
296 | unsigned int input_count = 0, output_count = 0; | 296 | unsigned int input_count = 0, output_count = 0; |
297 | 297 | ||
@@ -342,7 +342,7 @@ snd_seq_midisynth_register_port(snd_seq_device_t *dev) | |||
342 | } else if (device == 0) | 342 | } else if (device == 0) |
343 | set_client_name(client, card, info); /* use the first device's name */ | 343 | set_client_name(client, card, info); /* use the first device's name */ |
344 | 344 | ||
345 | msynth = kcalloc(ports, sizeof(seq_midisynth_t), GFP_KERNEL); | 345 | msynth = kcalloc(ports, sizeof(struct seq_midisynth), GFP_KERNEL); |
346 | port = kmalloc(sizeof(*port), GFP_KERNEL); | 346 | port = kmalloc(sizeof(*port), GFP_KERNEL); |
347 | if (msynth == NULL || port == NULL) | 347 | if (msynth == NULL || port == NULL) |
348 | goto __nomem; | 348 | goto __nomem; |
@@ -432,11 +432,11 @@ snd_seq_midisynth_register_port(snd_seq_device_t *dev) | |||
432 | 432 | ||
433 | /* release midi synth port */ | 433 | /* release midi synth port */ |
434 | static int | 434 | static int |
435 | snd_seq_midisynth_unregister_port(snd_seq_device_t *dev) | 435 | snd_seq_midisynth_unregister_port(struct snd_seq_device *dev) |
436 | { | 436 | { |
437 | seq_midisynth_client_t *client; | 437 | struct seq_midisynth_client *client; |
438 | seq_midisynth_t *msynth; | 438 | struct seq_midisynth *msynth; |
439 | snd_card_t *card = dev->card; | 439 | struct snd_card *card = dev->card; |
440 | int device = dev->device, p, ports; | 440 | int device = dev->device, p, ports; |
441 | 441 | ||
442 | down(®ister_mutex); | 442 | down(®ister_mutex); |
@@ -465,7 +465,7 @@ snd_seq_midisynth_unregister_port(snd_seq_device_t *dev) | |||
465 | 465 | ||
466 | static int __init alsa_seq_midi_init(void) | 466 | static int __init alsa_seq_midi_init(void) |
467 | { | 467 | { |
468 | static snd_seq_dev_ops_t ops = { | 468 | static struct snd_seq_dev_ops ops = { |
469 | snd_seq_midisynth_register_port, | 469 | snd_seq_midisynth_register_port, |
470 | snd_seq_midisynth_unregister_port, | 470 | snd_seq_midisynth_unregister_port, |
471 | }; | 471 | }; |
diff --git a/sound/core/seq/seq_midi_emul.c b/sound/core/seq/seq_midi_emul.c index 35fe8a7e34bf..d7c4fb86b9eb 100644 --- a/sound/core/seq/seq_midi_emul.c +++ b/sound/core/seq/seq_midi_emul.c | |||
@@ -44,17 +44,25 @@ MODULE_DESCRIPTION("Advanced Linux Sound Architecture sequencer MIDI emulation." | |||
44 | MODULE_LICENSE("GPL"); | 44 | MODULE_LICENSE("GPL"); |
45 | 45 | ||
46 | /* Prototypes for static functions */ | 46 | /* Prototypes for static functions */ |
47 | static void note_off(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan, int note, int vel); | 47 | static void note_off(struct snd_midi_op *ops, void *drv, |
48 | static void do_control(snd_midi_op_t *ops, void *private, | 48 | struct snd_midi_channel *chan, |
49 | snd_midi_channel_set_t *chset, snd_midi_channel_t *chan, | 49 | int note, int vel); |
50 | static void do_control(struct snd_midi_op *ops, void *private, | ||
51 | struct snd_midi_channel_set *chset, | ||
52 | struct snd_midi_channel *chan, | ||
50 | int control, int value); | 53 | int control, int value); |
51 | static void rpn(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan, snd_midi_channel_set_t *chset); | 54 | static void rpn(struct snd_midi_op *ops, void *drv, struct snd_midi_channel *chan, |
52 | static void nrpn(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan, snd_midi_channel_set_t *chset); | 55 | struct snd_midi_channel_set *chset); |
53 | static void sysex(snd_midi_op_t *ops, void *private, unsigned char *sysex, int len, snd_midi_channel_set_t *chset); | 56 | static void nrpn(struct snd_midi_op *ops, void *drv, struct snd_midi_channel *chan, |
54 | static void all_sounds_off(snd_midi_op_t *ops, void *private, snd_midi_channel_t *chan); | 57 | struct snd_midi_channel_set *chset); |
55 | static void all_notes_off(snd_midi_op_t *ops, void *private, snd_midi_channel_t *chan); | 58 | static void sysex(struct snd_midi_op *ops, void *private, unsigned char *sysex, |
56 | static void snd_midi_reset_controllers(snd_midi_channel_t *chan); | 59 | int len, struct snd_midi_channel_set *chset); |
57 | static void reset_all_channels(snd_midi_channel_set_t *chset); | 60 | static void all_sounds_off(struct snd_midi_op *ops, void *private, |
61 | struct snd_midi_channel *chan); | ||
62 | static void all_notes_off(struct snd_midi_op *ops, void *private, | ||
63 | struct snd_midi_channel *chan); | ||
64 | static void snd_midi_reset_controllers(struct snd_midi_channel *chan); | ||
65 | static void reset_all_channels(struct snd_midi_channel_set *chset); | ||
58 | 66 | ||
59 | 67 | ||
60 | /* | 68 | /* |
@@ -72,10 +80,11 @@ static void reset_all_channels(snd_midi_channel_set_t *chset); | |||
72 | * be interpreted. | 80 | * be interpreted. |
73 | */ | 81 | */ |
74 | void | 82 | void |
75 | snd_midi_process_event(snd_midi_op_t *ops, | 83 | snd_midi_process_event(struct snd_midi_op *ops, |
76 | snd_seq_event_t *ev, snd_midi_channel_set_t *chanset) | 84 | struct snd_seq_event *ev, |
85 | struct snd_midi_channel_set *chanset) | ||
77 | { | 86 | { |
78 | snd_midi_channel_t *chan; | 87 | struct snd_midi_channel *chan; |
79 | void *drv; | 88 | void *drv; |
80 | int dest_channel = 0; | 89 | int dest_channel = 0; |
81 | 90 | ||
@@ -89,7 +98,8 @@ snd_midi_process_event(snd_midi_op_t *ops, | |||
89 | if (snd_seq_ev_is_channel_type(ev)) { | 98 | if (snd_seq_ev_is_channel_type(ev)) { |
90 | dest_channel = ev->data.note.channel; | 99 | dest_channel = ev->data.note.channel; |
91 | if (dest_channel >= chanset->max_channels) { | 100 | if (dest_channel >= chanset->max_channels) { |
92 | snd_printd("dest channel is %d, max is %d\n", dest_channel, chanset->max_channels); | 101 | snd_printd("dest channel is %d, max is %d\n", |
102 | dest_channel, chanset->max_channels); | ||
93 | return; | 103 | return; |
94 | } | 104 | } |
95 | } | 105 | } |
@@ -239,7 +249,8 @@ snd_midi_process_event(snd_midi_op_t *ops, | |||
239 | * release note | 249 | * release note |
240 | */ | 250 | */ |
241 | static void | 251 | static void |
242 | note_off(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan, int note, int vel) | 252 | note_off(struct snd_midi_op *ops, void *drv, struct snd_midi_channel *chan, |
253 | int note, int vel) | ||
243 | { | 254 | { |
244 | if (chan->gm_hold) { | 255 | if (chan->gm_hold) { |
245 | /* Hold this note until pedal is turned off */ | 256 | /* Hold this note until pedal is turned off */ |
@@ -260,8 +271,8 @@ note_off(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan, int note, int | |||
260 | * events that need to take place immediately to the driver. | 271 | * events that need to take place immediately to the driver. |
261 | */ | 272 | */ |
262 | static void | 273 | static void |
263 | do_control(snd_midi_op_t *ops, void *drv, snd_midi_channel_set_t *chset, | 274 | do_control(struct snd_midi_op *ops, void *drv, struct snd_midi_channel_set *chset, |
264 | snd_midi_channel_t *chan, int control, int value) | 275 | struct snd_midi_channel *chan, int control, int value) |
265 | { | 276 | { |
266 | int i; | 277 | int i; |
267 | 278 | ||
@@ -376,7 +387,7 @@ do_control(snd_midi_op_t *ops, void *drv, snd_midi_channel_set_t *chset, | |||
376 | * initialize the MIDI status | 387 | * initialize the MIDI status |
377 | */ | 388 | */ |
378 | void | 389 | void |
379 | snd_midi_channel_set_clear(snd_midi_channel_set_t *chset) | 390 | snd_midi_channel_set_clear(struct snd_midi_channel_set *chset) |
380 | { | 391 | { |
381 | int i; | 392 | int i; |
382 | 393 | ||
@@ -384,7 +395,7 @@ snd_midi_channel_set_clear(snd_midi_channel_set_t *chset) | |||
384 | chset->gs_master_volume = 127; | 395 | chset->gs_master_volume = 127; |
385 | 396 | ||
386 | for (i = 0; i < chset->max_channels; i++) { | 397 | for (i = 0; i < chset->max_channels; i++) { |
387 | snd_midi_channel_t *chan = chset->channels + i; | 398 | struct snd_midi_channel *chan = chset->channels + i; |
388 | memset(chan->note, 0, sizeof(chan->note)); | 399 | memset(chan->note, 0, sizeof(chan->note)); |
389 | 400 | ||
390 | chan->midi_aftertouch = 0; | 401 | chan->midi_aftertouch = 0; |
@@ -407,8 +418,8 @@ snd_midi_channel_set_clear(snd_midi_channel_set_t *chset) | |||
407 | * Process a rpn message. | 418 | * Process a rpn message. |
408 | */ | 419 | */ |
409 | static void | 420 | static void |
410 | rpn(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan, | 421 | rpn(struct snd_midi_op *ops, void *drv, struct snd_midi_channel *chan, |
411 | snd_midi_channel_set_t *chset) | 422 | struct snd_midi_channel_set *chset) |
412 | { | 423 | { |
413 | int type; | 424 | int type; |
414 | int val; | 425 | int val; |
@@ -447,8 +458,8 @@ rpn(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan, | |||
447 | * Process an nrpn message. | 458 | * Process an nrpn message. |
448 | */ | 459 | */ |
449 | static void | 460 | static void |
450 | nrpn(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan, | 461 | nrpn(struct snd_midi_op *ops, void *drv, struct snd_midi_channel *chan, |
451 | snd_midi_channel_set_t *chset) | 462 | struct snd_midi_channel_set *chset) |
452 | { | 463 | { |
453 | /* parse XG NRPNs here if possible */ | 464 | /* parse XG NRPNs here if possible */ |
454 | if (ops->nrpn) | 465 | if (ops->nrpn) |
@@ -475,7 +486,8 @@ get_channel(unsigned char cmd) | |||
475 | * Process a sysex message. | 486 | * Process a sysex message. |
476 | */ | 487 | */ |
477 | static void | 488 | static void |
478 | sysex(snd_midi_op_t *ops, void *private, unsigned char *buf, int len, snd_midi_channel_set_t *chset) | 489 | sysex(struct snd_midi_op *ops, void *private, unsigned char *buf, int len, |
490 | struct snd_midi_channel_set *chset) | ||
479 | { | 491 | { |
480 | /* GM on */ | 492 | /* GM on */ |
481 | static unsigned char gm_on_macro[] = { | 493 | static unsigned char gm_on_macro[] = { |
@@ -588,7 +600,7 @@ sysex(snd_midi_op_t *ops, void *private, unsigned char *buf, int len, snd_midi_c | |||
588 | * all sound off | 600 | * all sound off |
589 | */ | 601 | */ |
590 | static void | 602 | static void |
591 | all_sounds_off(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan) | 603 | all_sounds_off(struct snd_midi_op *ops, void *drv, struct snd_midi_channel *chan) |
592 | { | 604 | { |
593 | int n; | 605 | int n; |
594 | 606 | ||
@@ -606,7 +618,7 @@ all_sounds_off(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan) | |||
606 | * all notes off | 618 | * all notes off |
607 | */ | 619 | */ |
608 | static void | 620 | static void |
609 | all_notes_off(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan) | 621 | all_notes_off(struct snd_midi_op *ops, void *drv, struct snd_midi_channel *chan) |
610 | { | 622 | { |
611 | int n; | 623 | int n; |
612 | 624 | ||
@@ -621,12 +633,12 @@ all_notes_off(snd_midi_op_t *ops, void *drv, snd_midi_channel_t *chan) | |||
621 | /* | 633 | /* |
622 | * Initialise a single midi channel control block. | 634 | * Initialise a single midi channel control block. |
623 | */ | 635 | */ |
624 | static void snd_midi_channel_init(snd_midi_channel_t *p, int n) | 636 | static void snd_midi_channel_init(struct snd_midi_channel *p, int n) |
625 | { | 637 | { |
626 | if (p == NULL) | 638 | if (p == NULL) |
627 | return; | 639 | return; |
628 | 640 | ||
629 | memset(p, 0, sizeof(snd_midi_channel_t)); | 641 | memset(p, 0, sizeof(struct snd_midi_channel)); |
630 | p->private = NULL; | 642 | p->private = NULL; |
631 | p->number = n; | 643 | p->number = n; |
632 | 644 | ||
@@ -642,12 +654,12 @@ static void snd_midi_channel_init(snd_midi_channel_t *p, int n) | |||
642 | /* | 654 | /* |
643 | * Allocate and initialise a set of midi channel control blocks. | 655 | * Allocate and initialise a set of midi channel control blocks. |
644 | */ | 656 | */ |
645 | static snd_midi_channel_t *snd_midi_channel_init_set(int n) | 657 | static struct snd_midi_channel *snd_midi_channel_init_set(int n) |
646 | { | 658 | { |
647 | snd_midi_channel_t *chan; | 659 | struct snd_midi_channel *chan; |
648 | int i; | 660 | int i; |
649 | 661 | ||
650 | chan = kmalloc(n * sizeof(snd_midi_channel_t), GFP_KERNEL); | 662 | chan = kmalloc(n * sizeof(struct snd_midi_channel), GFP_KERNEL); |
651 | if (chan) { | 663 | if (chan) { |
652 | for (i = 0; i < n; i++) | 664 | for (i = 0; i < n; i++) |
653 | snd_midi_channel_init(chan+i, i); | 665 | snd_midi_channel_init(chan+i, i); |
@@ -660,11 +672,11 @@ static snd_midi_channel_t *snd_midi_channel_init_set(int n) | |||
660 | * reset all midi channels | 672 | * reset all midi channels |
661 | */ | 673 | */ |
662 | static void | 674 | static void |
663 | reset_all_channels(snd_midi_channel_set_t *chset) | 675 | reset_all_channels(struct snd_midi_channel_set *chset) |
664 | { | 676 | { |
665 | int ch; | 677 | int ch; |
666 | for (ch = 0; ch < chset->max_channels; ch++) { | 678 | for (ch = 0; ch < chset->max_channels; ch++) { |
667 | snd_midi_channel_t *chan = chset->channels + ch; | 679 | struct snd_midi_channel *chan = chset->channels + ch; |
668 | snd_midi_reset_controllers(chan); | 680 | snd_midi_reset_controllers(chan); |
669 | chan->gm_rpn_pitch_bend_range = 256; /* 2 semitones */ | 681 | chan->gm_rpn_pitch_bend_range = 256; /* 2 semitones */ |
670 | chan->gm_rpn_fine_tuning = 0; | 682 | chan->gm_rpn_fine_tuning = 0; |
@@ -681,9 +693,9 @@ reset_all_channels(snd_midi_channel_set_t *chset) | |||
681 | /* | 693 | /* |
682 | * Allocate and initialise a midi channel set. | 694 | * Allocate and initialise a midi channel set. |
683 | */ | 695 | */ |
684 | snd_midi_channel_set_t *snd_midi_channel_alloc_set(int n) | 696 | struct snd_midi_channel_set *snd_midi_channel_alloc_set(int n) |
685 | { | 697 | { |
686 | snd_midi_channel_set_t *chset; | 698 | struct snd_midi_channel_set *chset; |
687 | 699 | ||
688 | chset = kmalloc(sizeof(*chset), GFP_KERNEL); | 700 | chset = kmalloc(sizeof(*chset), GFP_KERNEL); |
689 | if (chset) { | 701 | if (chset) { |
@@ -697,7 +709,7 @@ snd_midi_channel_set_t *snd_midi_channel_alloc_set(int n) | |||
697 | /* | 709 | /* |
698 | * Reset the midi controllers on a particular channel to default values. | 710 | * Reset the midi controllers on a particular channel to default values. |
699 | */ | 711 | */ |
700 | static void snd_midi_reset_controllers(snd_midi_channel_t *chan) | 712 | static void snd_midi_reset_controllers(struct snd_midi_channel *chan) |
701 | { | 713 | { |
702 | memset(chan->control, 0, sizeof(chan->control)); | 714 | memset(chan->control, 0, sizeof(chan->control)); |
703 | chan->gm_volume = 127; | 715 | chan->gm_volume = 127; |
@@ -709,7 +721,7 @@ static void snd_midi_reset_controllers(snd_midi_channel_t *chan) | |||
709 | /* | 721 | /* |
710 | * Free a midi channel set. | 722 | * Free a midi channel set. |
711 | */ | 723 | */ |
712 | void snd_midi_channel_free_set(snd_midi_channel_set_t *chset) | 724 | void snd_midi_channel_free_set(struct snd_midi_channel_set *chset) |
713 | { | 725 | { |
714 | if (chset == NULL) | 726 | if (chset == NULL) |
715 | return; | 727 | return; |
diff --git a/sound/core/seq/seq_midi_event.c b/sound/core/seq/seq_midi_event.c index 2dc1aecfb426..5ff80b776906 100644 --- a/sound/core/seq/seq_midi_event.c +++ b/sound/core/seq/seq_midi_event.c | |||
@@ -41,33 +41,29 @@ MODULE_LICENSE("GPL"); | |||
41 | /* from 8 to 15 are events for 0xf0-0xf7 */ | 41 | /* from 8 to 15 are events for 0xf0-0xf7 */ |
42 | 42 | ||
43 | 43 | ||
44 | /* status event types */ | ||
45 | typedef void (*event_encode_t)(snd_midi_event_t *dev, snd_seq_event_t *ev); | ||
46 | typedef void (*event_decode_t)(snd_seq_event_t *ev, unsigned char *buf); | ||
47 | |||
48 | /* | 44 | /* |
49 | * prototypes | 45 | * prototypes |
50 | */ | 46 | */ |
51 | static void note_event(snd_midi_event_t *dev, snd_seq_event_t *ev); | 47 | static void note_event(struct snd_midi_event *dev, struct snd_seq_event *ev); |
52 | static void one_param_ctrl_event(snd_midi_event_t *dev, snd_seq_event_t *ev); | 48 | static void one_param_ctrl_event(struct snd_midi_event *dev, struct snd_seq_event *ev); |
53 | static void pitchbend_ctrl_event(snd_midi_event_t *dev, snd_seq_event_t *ev); | 49 | static void pitchbend_ctrl_event(struct snd_midi_event *dev, struct snd_seq_event *ev); |
54 | static void two_param_ctrl_event(snd_midi_event_t *dev, snd_seq_event_t *ev); | 50 | static void two_param_ctrl_event(struct snd_midi_event *dev, struct snd_seq_event *ev); |
55 | static void one_param_event(snd_midi_event_t *dev, snd_seq_event_t *ev); | 51 | static void one_param_event(struct snd_midi_event *dev, struct snd_seq_event *ev); |
56 | static void songpos_event(snd_midi_event_t *dev, snd_seq_event_t *ev); | 52 | static void songpos_event(struct snd_midi_event *dev, struct snd_seq_event *ev); |
57 | static void note_decode(snd_seq_event_t *ev, unsigned char *buf); | 53 | static void note_decode(struct snd_seq_event *ev, unsigned char *buf); |
58 | static void one_param_decode(snd_seq_event_t *ev, unsigned char *buf); | 54 | static void one_param_decode(struct snd_seq_event *ev, unsigned char *buf); |
59 | static void pitchbend_decode(snd_seq_event_t *ev, unsigned char *buf); | 55 | static void pitchbend_decode(struct snd_seq_event *ev, unsigned char *buf); |
60 | static void two_param_decode(snd_seq_event_t *ev, unsigned char *buf); | 56 | static void two_param_decode(struct snd_seq_event *ev, unsigned char *buf); |
61 | static void songpos_decode(snd_seq_event_t *ev, unsigned char *buf); | 57 | static void songpos_decode(struct snd_seq_event *ev, unsigned char *buf); |
62 | 58 | ||
63 | /* | 59 | /* |
64 | * event list | 60 | * event list |
65 | */ | 61 | */ |
66 | static struct status_event_list_t { | 62 | static struct status_event_list { |
67 | int event; | 63 | int event; |
68 | int qlen; | 64 | int qlen; |
69 | event_encode_t encode; | 65 | void (*encode)(struct snd_midi_event *dev, struct snd_seq_event *ev); |
70 | event_decode_t decode; | 66 | void (*decode)(struct snd_seq_event *ev, unsigned char *buf); |
71 | } status_event[] = { | 67 | } status_event[] = { |
72 | /* 0x80 - 0xf0 */ | 68 | /* 0x80 - 0xf0 */ |
73 | {SNDRV_SEQ_EVENT_NOTEOFF, 2, note_event, note_decode}, | 69 | {SNDRV_SEQ_EVENT_NOTEOFF, 2, note_event, note_decode}, |
@@ -97,12 +93,15 @@ static struct status_event_list_t { | |||
97 | {SNDRV_SEQ_EVENT_RESET, 0, NULL, NULL}, /* 0xff */ | 93 | {SNDRV_SEQ_EVENT_RESET, 0, NULL, NULL}, /* 0xff */ |
98 | }; | 94 | }; |
99 | 95 | ||
100 | static int extra_decode_ctrl14(snd_midi_event_t *dev, unsigned char *buf, int len, snd_seq_event_t *ev); | 96 | static int extra_decode_ctrl14(struct snd_midi_event *dev, unsigned char *buf, int len, |
101 | static int extra_decode_xrpn(snd_midi_event_t *dev, unsigned char *buf, int count, snd_seq_event_t *ev); | 97 | struct snd_seq_event *ev); |
98 | static int extra_decode_xrpn(struct snd_midi_event *dev, unsigned char *buf, int count, | ||
99 | struct snd_seq_event *ev); | ||
102 | 100 | ||
103 | static struct extra_event_list_t { | 101 | static struct extra_event_list { |
104 | int event; | 102 | int event; |
105 | int (*decode)(snd_midi_event_t *dev, unsigned char *buf, int len, snd_seq_event_t *ev); | 103 | int (*decode)(struct snd_midi_event *dev, unsigned char *buf, int len, |
104 | struct snd_seq_event *ev); | ||
106 | } extra_event[] = { | 105 | } extra_event[] = { |
107 | {SNDRV_SEQ_EVENT_CONTROL14, extra_decode_ctrl14}, | 106 | {SNDRV_SEQ_EVENT_CONTROL14, extra_decode_ctrl14}, |
108 | {SNDRV_SEQ_EVENT_NONREGPARAM, extra_decode_xrpn}, | 107 | {SNDRV_SEQ_EVENT_NONREGPARAM, extra_decode_xrpn}, |
@@ -113,9 +112,9 @@ static struct extra_event_list_t { | |||
113 | * new/delete record | 112 | * new/delete record |
114 | */ | 113 | */ |
115 | 114 | ||
116 | int snd_midi_event_new(int bufsize, snd_midi_event_t **rdev) | 115 | int snd_midi_event_new(int bufsize, struct snd_midi_event **rdev) |
117 | { | 116 | { |
118 | snd_midi_event_t *dev; | 117 | struct snd_midi_event *dev; |
119 | 118 | ||
120 | *rdev = NULL; | 119 | *rdev = NULL; |
121 | dev = kzalloc(sizeof(*dev), GFP_KERNEL); | 120 | dev = kzalloc(sizeof(*dev), GFP_KERNEL); |
@@ -135,7 +134,7 @@ int snd_midi_event_new(int bufsize, snd_midi_event_t **rdev) | |||
135 | return 0; | 134 | return 0; |
136 | } | 135 | } |
137 | 136 | ||
138 | void snd_midi_event_free(snd_midi_event_t *dev) | 137 | void snd_midi_event_free(struct snd_midi_event *dev) |
139 | { | 138 | { |
140 | if (dev != NULL) { | 139 | if (dev != NULL) { |
141 | kfree(dev->buf); | 140 | kfree(dev->buf); |
@@ -146,14 +145,14 @@ void snd_midi_event_free(snd_midi_event_t *dev) | |||
146 | /* | 145 | /* |
147 | * initialize record | 146 | * initialize record |
148 | */ | 147 | */ |
149 | static inline void reset_encode(snd_midi_event_t *dev) | 148 | static inline void reset_encode(struct snd_midi_event *dev) |
150 | { | 149 | { |
151 | dev->read = 0; | 150 | dev->read = 0; |
152 | dev->qlen = 0; | 151 | dev->qlen = 0; |
153 | dev->type = 0; | 152 | dev->type = 0; |
154 | } | 153 | } |
155 | 154 | ||
156 | void snd_midi_event_reset_encode(snd_midi_event_t *dev) | 155 | void snd_midi_event_reset_encode(struct snd_midi_event *dev) |
157 | { | 156 | { |
158 | unsigned long flags; | 157 | unsigned long flags; |
159 | 158 | ||
@@ -162,7 +161,7 @@ void snd_midi_event_reset_encode(snd_midi_event_t *dev) | |||
162 | spin_unlock_irqrestore(&dev->lock, flags); | 161 | spin_unlock_irqrestore(&dev->lock, flags); |
163 | } | 162 | } |
164 | 163 | ||
165 | void snd_midi_event_reset_decode(snd_midi_event_t *dev) | 164 | void snd_midi_event_reset_decode(struct snd_midi_event *dev) |
166 | { | 165 | { |
167 | unsigned long flags; | 166 | unsigned long flags; |
168 | 167 | ||
@@ -172,14 +171,14 @@ void snd_midi_event_reset_decode(snd_midi_event_t *dev) | |||
172 | } | 171 | } |
173 | 172 | ||
174 | #if 0 | 173 | #if 0 |
175 | void snd_midi_event_init(snd_midi_event_t *dev) | 174 | void snd_midi_event_init(struct snd_midi_event *dev) |
176 | { | 175 | { |
177 | snd_midi_event_reset_encode(dev); | 176 | snd_midi_event_reset_encode(dev); |
178 | snd_midi_event_reset_decode(dev); | 177 | snd_midi_event_reset_decode(dev); |
179 | } | 178 | } |
180 | #endif /* 0 */ | 179 | #endif /* 0 */ |
181 | 180 | ||
182 | void snd_midi_event_no_status(snd_midi_event_t *dev, int on) | 181 | void snd_midi_event_no_status(struct snd_midi_event *dev, int on) |
183 | { | 182 | { |
184 | dev->nostat = on ? 1 : 0; | 183 | dev->nostat = on ? 1 : 0; |
185 | } | 184 | } |
@@ -188,7 +187,7 @@ void snd_midi_event_no_status(snd_midi_event_t *dev, int on) | |||
188 | * resize buffer | 187 | * resize buffer |
189 | */ | 188 | */ |
190 | #if 0 | 189 | #if 0 |
191 | int snd_midi_event_resize_buffer(snd_midi_event_t *dev, int bufsize) | 190 | int snd_midi_event_resize_buffer(struct snd_midi_event *dev, int bufsize) |
192 | { | 191 | { |
193 | unsigned char *new_buf, *old_buf; | 192 | unsigned char *new_buf, *old_buf; |
194 | unsigned long flags; | 193 | unsigned long flags; |
@@ -213,7 +212,8 @@ int snd_midi_event_resize_buffer(snd_midi_event_t *dev, int bufsize) | |||
213 | * read bytes and encode to sequencer event if finished | 212 | * read bytes and encode to sequencer event if finished |
214 | * return the size of encoded bytes | 213 | * return the size of encoded bytes |
215 | */ | 214 | */ |
216 | long snd_midi_event_encode(snd_midi_event_t *dev, unsigned char *buf, long count, snd_seq_event_t *ev) | 215 | long snd_midi_event_encode(struct snd_midi_event *dev, unsigned char *buf, long count, |
216 | struct snd_seq_event *ev) | ||
217 | { | 217 | { |
218 | long result = 0; | 218 | long result = 0; |
219 | int rc; | 219 | int rc; |
@@ -238,7 +238,8 @@ long snd_midi_event_encode(snd_midi_event_t *dev, unsigned char *buf, long count | |||
238 | * 0 data is not finished | 238 | * 0 data is not finished |
239 | * negative for error | 239 | * negative for error |
240 | */ | 240 | */ |
241 | int snd_midi_event_encode_byte(snd_midi_event_t *dev, int c, snd_seq_event_t *ev) | 241 | int snd_midi_event_encode_byte(struct snd_midi_event *dev, int c, |
242 | struct snd_seq_event *ev) | ||
242 | { | 243 | { |
243 | int rc = 0; | 244 | int rc = 0; |
244 | unsigned long flags; | 245 | unsigned long flags; |
@@ -303,7 +304,7 @@ int snd_midi_event_encode_byte(snd_midi_event_t *dev, int c, snd_seq_event_t *ev | |||
303 | } | 304 | } |
304 | 305 | ||
305 | /* encode note event */ | 306 | /* encode note event */ |
306 | static void note_event(snd_midi_event_t *dev, snd_seq_event_t *ev) | 307 | static void note_event(struct snd_midi_event *dev, struct snd_seq_event *ev) |
307 | { | 308 | { |
308 | ev->data.note.channel = dev->buf[0] & 0x0f; | 309 | ev->data.note.channel = dev->buf[0] & 0x0f; |
309 | ev->data.note.note = dev->buf[1]; | 310 | ev->data.note.note = dev->buf[1]; |
@@ -311,21 +312,21 @@ static void note_event(snd_midi_event_t *dev, snd_seq_event_t *ev) | |||
311 | } | 312 | } |
312 | 313 | ||
313 | /* encode one parameter controls */ | 314 | /* encode one parameter controls */ |
314 | static void one_param_ctrl_event(snd_midi_event_t *dev, snd_seq_event_t *ev) | 315 | static void one_param_ctrl_event(struct snd_midi_event *dev, struct snd_seq_event *ev) |
315 | { | 316 | { |
316 | ev->data.control.channel = dev->buf[0] & 0x0f; | 317 | ev->data.control.channel = dev->buf[0] & 0x0f; |
317 | ev->data.control.value = dev->buf[1]; | 318 | ev->data.control.value = dev->buf[1]; |
318 | } | 319 | } |
319 | 320 | ||
320 | /* encode pitch wheel change */ | 321 | /* encode pitch wheel change */ |
321 | static void pitchbend_ctrl_event(snd_midi_event_t *dev, snd_seq_event_t *ev) | 322 | static void pitchbend_ctrl_event(struct snd_midi_event *dev, struct snd_seq_event *ev) |
322 | { | 323 | { |
323 | ev->data.control.channel = dev->buf[0] & 0x0f; | 324 | ev->data.control.channel = dev->buf[0] & 0x0f; |
324 | ev->data.control.value = (int)dev->buf[2] * 128 + (int)dev->buf[1] - 8192; | 325 | ev->data.control.value = (int)dev->buf[2] * 128 + (int)dev->buf[1] - 8192; |
325 | } | 326 | } |
326 | 327 | ||
327 | /* encode midi control change */ | 328 | /* encode midi control change */ |
328 | static void two_param_ctrl_event(snd_midi_event_t *dev, snd_seq_event_t *ev) | 329 | static void two_param_ctrl_event(struct snd_midi_event *dev, struct snd_seq_event *ev) |
329 | { | 330 | { |
330 | ev->data.control.channel = dev->buf[0] & 0x0f; | 331 | ev->data.control.channel = dev->buf[0] & 0x0f; |
331 | ev->data.control.param = dev->buf[1]; | 332 | ev->data.control.param = dev->buf[1]; |
@@ -333,13 +334,13 @@ static void two_param_ctrl_event(snd_midi_event_t *dev, snd_seq_event_t *ev) | |||
333 | } | 334 | } |
334 | 335 | ||
335 | /* encode one parameter value*/ | 336 | /* encode one parameter value*/ |
336 | static void one_param_event(snd_midi_event_t *dev, snd_seq_event_t *ev) | 337 | static void one_param_event(struct snd_midi_event *dev, struct snd_seq_event *ev) |
337 | { | 338 | { |
338 | ev->data.control.value = dev->buf[1]; | 339 | ev->data.control.value = dev->buf[1]; |
339 | } | 340 | } |
340 | 341 | ||
341 | /* encode song position */ | 342 | /* encode song position */ |
342 | static void songpos_event(snd_midi_event_t *dev, snd_seq_event_t *ev) | 343 | static void songpos_event(struct snd_midi_event *dev, struct snd_seq_event *ev) |
343 | { | 344 | { |
344 | ev->data.control.value = (int)dev->buf[2] * 128 + (int)dev->buf[1]; | 345 | ev->data.control.value = (int)dev->buf[2] * 128 + (int)dev->buf[1]; |
345 | } | 346 | } |
@@ -348,7 +349,8 @@ static void songpos_event(snd_midi_event_t *dev, snd_seq_event_t *ev) | |||
348 | * decode from a sequencer event to midi bytes | 349 | * decode from a sequencer event to midi bytes |
349 | * return the size of decoded midi events | 350 | * return the size of decoded midi events |
350 | */ | 351 | */ |
351 | long snd_midi_event_decode(snd_midi_event_t *dev, unsigned char *buf, long count, snd_seq_event_t *ev) | 352 | long snd_midi_event_decode(struct snd_midi_event *dev, unsigned char *buf, long count, |
353 | struct snd_seq_event *ev) | ||
352 | { | 354 | { |
353 | unsigned int cmd, type; | 355 | unsigned int cmd, type; |
354 | 356 | ||
@@ -404,20 +406,20 @@ long snd_midi_event_decode(snd_midi_event_t *dev, unsigned char *buf, long count | |||
404 | 406 | ||
405 | 407 | ||
406 | /* decode note event */ | 408 | /* decode note event */ |
407 | static void note_decode(snd_seq_event_t *ev, unsigned char *buf) | 409 | static void note_decode(struct snd_seq_event *ev, unsigned char *buf) |
408 | { | 410 | { |
409 | buf[0] = ev->data.note.note & 0x7f; | 411 | buf[0] = ev->data.note.note & 0x7f; |
410 | buf[1] = ev->data.note.velocity & 0x7f; | 412 | buf[1] = ev->data.note.velocity & 0x7f; |
411 | } | 413 | } |
412 | 414 | ||
413 | /* decode one parameter controls */ | 415 | /* decode one parameter controls */ |
414 | static void one_param_decode(snd_seq_event_t *ev, unsigned char *buf) | 416 | static void one_param_decode(struct snd_seq_event *ev, unsigned char *buf) |
415 | { | 417 | { |
416 | buf[0] = ev->data.control.value & 0x7f; | 418 | buf[0] = ev->data.control.value & 0x7f; |
417 | } | 419 | } |
418 | 420 | ||
419 | /* decode pitch wheel change */ | 421 | /* decode pitch wheel change */ |
420 | static void pitchbend_decode(snd_seq_event_t *ev, unsigned char *buf) | 422 | static void pitchbend_decode(struct snd_seq_event *ev, unsigned char *buf) |
421 | { | 423 | { |
422 | int value = ev->data.control.value + 8192; | 424 | int value = ev->data.control.value + 8192; |
423 | buf[0] = value & 0x7f; | 425 | buf[0] = value & 0x7f; |
@@ -425,21 +427,22 @@ static void pitchbend_decode(snd_seq_event_t *ev, unsigned char *buf) | |||
425 | } | 427 | } |
426 | 428 | ||
427 | /* decode midi control change */ | 429 | /* decode midi control change */ |
428 | static void two_param_decode(snd_seq_event_t *ev, unsigned char *buf) | 430 | static void two_param_decode(struct snd_seq_event *ev, unsigned char *buf) |
429 | { | 431 | { |
430 | buf[0] = ev->data.control.param & 0x7f; | 432 | buf[0] = ev->data.control.param & 0x7f; |
431 | buf[1] = ev->data.control.value & 0x7f; | 433 | buf[1] = ev->data.control.value & 0x7f; |
432 | } | 434 | } |
433 | 435 | ||
434 | /* decode song position */ | 436 | /* decode song position */ |
435 | static void songpos_decode(snd_seq_event_t *ev, unsigned char *buf) | 437 | static void songpos_decode(struct snd_seq_event *ev, unsigned char *buf) |
436 | { | 438 | { |
437 | buf[0] = ev->data.control.value & 0x7f; | 439 | buf[0] = ev->data.control.value & 0x7f; |
438 | buf[1] = (ev->data.control.value >> 7) & 0x7f; | 440 | buf[1] = (ev->data.control.value >> 7) & 0x7f; |
439 | } | 441 | } |
440 | 442 | ||
441 | /* decode 14bit control */ | 443 | /* decode 14bit control */ |
442 | static int extra_decode_ctrl14(snd_midi_event_t *dev, unsigned char *buf, int count, snd_seq_event_t *ev) | 444 | static int extra_decode_ctrl14(struct snd_midi_event *dev, unsigned char *buf, |
445 | int count, struct snd_seq_event *ev) | ||
443 | { | 446 | { |
444 | unsigned char cmd; | 447 | unsigned char cmd; |
445 | int idx = 0; | 448 | int idx = 0; |
@@ -476,7 +479,8 @@ static int extra_decode_ctrl14(snd_midi_event_t *dev, unsigned char *buf, int co | |||
476 | } | 479 | } |
477 | 480 | ||
478 | /* decode reg/nonreg param */ | 481 | /* decode reg/nonreg param */ |
479 | static int extra_decode_xrpn(snd_midi_event_t *dev, unsigned char *buf, int count, snd_seq_event_t *ev) | 482 | static int extra_decode_xrpn(struct snd_midi_event *dev, unsigned char *buf, |
483 | int count, struct snd_seq_event *ev) | ||
480 | { | 484 | { |
481 | unsigned char cmd; | 485 | unsigned char cmd; |
482 | char *cbytes; | 486 | char *cbytes; |
diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c index 57ec31df0d15..2b384fd7967f 100644 --- a/sound/core/seq/seq_ports.c +++ b/sound/core/seq/seq_ports.c | |||
@@ -56,16 +56,17 @@ much elements are in array. | |||
56 | */ | 56 | */ |
57 | 57 | ||
58 | /* return pointer to port structure - port is locked if found */ | 58 | /* return pointer to port structure - port is locked if found */ |
59 | client_port_t *snd_seq_port_use_ptr(client_t *client, int num) | 59 | struct snd_seq_client_port *snd_seq_port_use_ptr(struct snd_seq_client *client, |
60 | int num) | ||
60 | { | 61 | { |
61 | struct list_head *p; | 62 | struct list_head *p; |
62 | client_port_t *port; | 63 | struct snd_seq_client_port *port; |
63 | 64 | ||
64 | if (client == NULL) | 65 | if (client == NULL) |
65 | return NULL; | 66 | return NULL; |
66 | read_lock(&client->ports_lock); | 67 | read_lock(&client->ports_lock); |
67 | list_for_each(p, &client->ports_list_head) { | 68 | list_for_each(p, &client->ports_list_head) { |
68 | port = list_entry(p, client_port_t, list); | 69 | port = list_entry(p, struct snd_seq_client_port, list); |
69 | if (port->addr.port == num) { | 70 | if (port->addr.port == num) { |
70 | if (port->closing) | 71 | if (port->closing) |
71 | break; /* deleting now */ | 72 | break; /* deleting now */ |
@@ -80,17 +81,18 @@ client_port_t *snd_seq_port_use_ptr(client_t *client, int num) | |||
80 | 81 | ||
81 | 82 | ||
82 | /* search for the next port - port is locked if found */ | 83 | /* search for the next port - port is locked if found */ |
83 | client_port_t *snd_seq_port_query_nearest(client_t *client, snd_seq_port_info_t *pinfo) | 84 | struct snd_seq_client_port *snd_seq_port_query_nearest(struct snd_seq_client *client, |
85 | struct snd_seq_port_info *pinfo) | ||
84 | { | 86 | { |
85 | int num; | 87 | int num; |
86 | struct list_head *p; | 88 | struct list_head *p; |
87 | client_port_t *port, *found; | 89 | struct snd_seq_client_port *port, *found; |
88 | 90 | ||
89 | num = pinfo->addr.port; | 91 | num = pinfo->addr.port; |
90 | found = NULL; | 92 | found = NULL; |
91 | read_lock(&client->ports_lock); | 93 | read_lock(&client->ports_lock); |
92 | list_for_each(p, &client->ports_list_head) { | 94 | list_for_each(p, &client->ports_list_head) { |
93 | port = list_entry(p, client_port_t, list); | 95 | port = list_entry(p, struct snd_seq_client_port, list); |
94 | if (port->addr.port < num) | 96 | if (port->addr.port < num) |
95 | continue; | 97 | continue; |
96 | if (port->addr.port == num) { | 98 | if (port->addr.port == num) { |
@@ -111,8 +113,8 @@ client_port_t *snd_seq_port_query_nearest(client_t *client, snd_seq_port_info_t | |||
111 | } | 113 | } |
112 | 114 | ||
113 | 115 | ||
114 | /* initialize port_subs_info_t */ | 116 | /* initialize snd_seq_port_subs_info */ |
115 | static void port_subs_info_init(port_subs_info_t *grp) | 117 | static void port_subs_info_init(struct snd_seq_port_subs_info *grp) |
116 | { | 118 | { |
117 | INIT_LIST_HEAD(&grp->list_head); | 119 | INIT_LIST_HEAD(&grp->list_head); |
118 | grp->count = 0; | 120 | grp->count = 0; |
@@ -125,10 +127,11 @@ static void port_subs_info_init(port_subs_info_t *grp) | |||
125 | 127 | ||
126 | 128 | ||
127 | /* create a port, port number is returned (-1 on failure) */ | 129 | /* create a port, port number is returned (-1 on failure) */ |
128 | client_port_t *snd_seq_create_port(client_t *client, int port) | 130 | struct snd_seq_client_port *snd_seq_create_port(struct snd_seq_client *client, |
131 | int port) | ||
129 | { | 132 | { |
130 | unsigned long flags; | 133 | unsigned long flags; |
131 | client_port_t *new_port; | 134 | struct snd_seq_client_port *new_port; |
132 | struct list_head *l; | 135 | struct list_head *l; |
133 | int num = -1; | 136 | int num = -1; |
134 | 137 | ||
@@ -159,7 +162,7 @@ client_port_t *snd_seq_create_port(client_t *client, int port) | |||
159 | down(&client->ports_mutex); | 162 | down(&client->ports_mutex); |
160 | write_lock_irqsave(&client->ports_lock, flags); | 163 | write_lock_irqsave(&client->ports_lock, flags); |
161 | list_for_each(l, &client->ports_list_head) { | 164 | list_for_each(l, &client->ports_list_head) { |
162 | client_port_t *p = list_entry(l, client_port_t, list); | 165 | struct snd_seq_client_port *p = list_entry(l, struct snd_seq_client_port, list); |
163 | if (p->addr.port > num) | 166 | if (p->addr.port > num) |
164 | break; | 167 | break; |
165 | if (port < 0) /* auto-probe mode */ | 168 | if (port < 0) /* auto-probe mode */ |
@@ -177,17 +180,24 @@ client_port_t *snd_seq_create_port(client_t *client, int port) | |||
177 | } | 180 | } |
178 | 181 | ||
179 | /* */ | 182 | /* */ |
180 | enum group_type_t { | 183 | enum group_type { |
181 | SRC_LIST, DEST_LIST | 184 | SRC_LIST, DEST_LIST |
182 | }; | 185 | }; |
183 | 186 | ||
184 | static int subscribe_port(client_t *client, client_port_t *port, port_subs_info_t *grp, snd_seq_port_subscribe_t *info, int send_ack); | 187 | static int subscribe_port(struct snd_seq_client *client, |
185 | static int unsubscribe_port(client_t *client, client_port_t *port, port_subs_info_t *grp, snd_seq_port_subscribe_t *info, int send_ack); | 188 | struct snd_seq_client_port *port, |
189 | struct snd_seq_port_subs_info *grp, | ||
190 | struct snd_seq_port_subscribe *info, int send_ack); | ||
191 | static int unsubscribe_port(struct snd_seq_client *client, | ||
192 | struct snd_seq_client_port *port, | ||
193 | struct snd_seq_port_subs_info *grp, | ||
194 | struct snd_seq_port_subscribe *info, int send_ack); | ||
186 | 195 | ||
187 | 196 | ||
188 | static client_port_t *get_client_port(snd_seq_addr_t *addr, client_t **cp) | 197 | static struct snd_seq_client_port *get_client_port(struct snd_seq_addr *addr, |
198 | struct snd_seq_client **cp) | ||
189 | { | 199 | { |
190 | client_port_t *p; | 200 | struct snd_seq_client_port *p; |
191 | *cp = snd_seq_client_use_ptr(addr->client); | 201 | *cp = snd_seq_client_use_ptr(addr->client); |
192 | if (*cp) { | 202 | if (*cp) { |
193 | p = snd_seq_port_use_ptr(*cp, addr->port); | 203 | p = snd_seq_port_use_ptr(*cp, addr->port); |
@@ -204,22 +214,24 @@ static client_port_t *get_client_port(snd_seq_addr_t *addr, client_t **cp) | |||
204 | * remove all subscribers on the list | 214 | * remove all subscribers on the list |
205 | * this is called from port_delete, for each src and dest list. | 215 | * this is called from port_delete, for each src and dest list. |
206 | */ | 216 | */ |
207 | static void clear_subscriber_list(client_t *client, client_port_t *port, | 217 | static void clear_subscriber_list(struct snd_seq_client *client, |
208 | port_subs_info_t *grp, int grptype) | 218 | struct snd_seq_client_port *port, |
219 | struct snd_seq_port_subs_info *grp, | ||
220 | int grptype) | ||
209 | { | 221 | { |
210 | struct list_head *p, *n; | 222 | struct list_head *p, *n; |
211 | 223 | ||
212 | down_write(&grp->list_mutex); | 224 | down_write(&grp->list_mutex); |
213 | list_for_each_safe(p, n, &grp->list_head) { | 225 | list_for_each_safe(p, n, &grp->list_head) { |
214 | subscribers_t *subs; | 226 | struct snd_seq_subscribers *subs; |
215 | client_t *c; | 227 | struct snd_seq_client *c; |
216 | client_port_t *aport; | 228 | struct snd_seq_client_port *aport; |
217 | 229 | ||
218 | if (grptype == SRC_LIST) { | 230 | if (grptype == SRC_LIST) { |
219 | subs = list_entry(p, subscribers_t, src_list); | 231 | subs = list_entry(p, struct snd_seq_subscribers, src_list); |
220 | aport = get_client_port(&subs->info.dest, &c); | 232 | aport = get_client_port(&subs->info.dest, &c); |
221 | } else { | 233 | } else { |
222 | subs = list_entry(p, subscribers_t, dest_list); | 234 | subs = list_entry(p, struct snd_seq_subscribers, dest_list); |
223 | aport = get_client_port(&subs->info.sender, &c); | 235 | aport = get_client_port(&subs->info.sender, &c); |
224 | } | 236 | } |
225 | list_del(p); | 237 | list_del(p); |
@@ -233,7 +245,7 @@ static void clear_subscriber_list(client_t *client, client_port_t *port, | |||
233 | kfree(subs); | 245 | kfree(subs); |
234 | } else { | 246 | } else { |
235 | /* ok we got the connected port */ | 247 | /* ok we got the connected port */ |
236 | port_subs_info_t *agrp; | 248 | struct snd_seq_port_subs_info *agrp; |
237 | agrp = (grptype == SRC_LIST) ? &aport->c_dest : &aport->c_src; | 249 | agrp = (grptype == SRC_LIST) ? &aport->c_dest : &aport->c_src; |
238 | down_write(&agrp->list_mutex); | 250 | down_write(&agrp->list_mutex); |
239 | if (grptype == SRC_LIST) | 251 | if (grptype == SRC_LIST) |
@@ -251,7 +263,8 @@ static void clear_subscriber_list(client_t *client, client_port_t *port, | |||
251 | } | 263 | } |
252 | 264 | ||
253 | /* delete port data */ | 265 | /* delete port data */ |
254 | static int port_delete(client_t *client, client_port_t *port) | 266 | static int port_delete(struct snd_seq_client *client, |
267 | struct snd_seq_client_port *port) | ||
255 | { | 268 | { |
256 | /* set closing flag and wait for all port access are gone */ | 269 | /* set closing flag and wait for all port access are gone */ |
257 | port->closing = 1; | 270 | port->closing = 1; |
@@ -273,16 +286,16 @@ static int port_delete(client_t *client, client_port_t *port) | |||
273 | 286 | ||
274 | 287 | ||
275 | /* delete a port with the given port id */ | 288 | /* delete a port with the given port id */ |
276 | int snd_seq_delete_port(client_t *client, int port) | 289 | int snd_seq_delete_port(struct snd_seq_client *client, int port) |
277 | { | 290 | { |
278 | unsigned long flags; | 291 | unsigned long flags; |
279 | struct list_head *l; | 292 | struct list_head *l; |
280 | client_port_t *found = NULL; | 293 | struct snd_seq_client_port *found = NULL; |
281 | 294 | ||
282 | down(&client->ports_mutex); | 295 | down(&client->ports_mutex); |
283 | write_lock_irqsave(&client->ports_lock, flags); | 296 | write_lock_irqsave(&client->ports_lock, flags); |
284 | list_for_each(l, &client->ports_list_head) { | 297 | list_for_each(l, &client->ports_list_head) { |
285 | client_port_t *p = list_entry(l, client_port_t, list); | 298 | struct snd_seq_client_port *p = list_entry(l, struct snd_seq_client_port, list); |
286 | if (p->addr.port == port) { | 299 | if (p->addr.port == port) { |
287 | /* ok found. delete from the list at first */ | 300 | /* ok found. delete from the list at first */ |
288 | list_del(l); | 301 | list_del(l); |
@@ -300,7 +313,7 @@ int snd_seq_delete_port(client_t *client, int port) | |||
300 | } | 313 | } |
301 | 314 | ||
302 | /* delete the all ports belonging to the given client */ | 315 | /* delete the all ports belonging to the given client */ |
303 | int snd_seq_delete_all_ports(client_t *client) | 316 | int snd_seq_delete_all_ports(struct snd_seq_client *client) |
304 | { | 317 | { |
305 | unsigned long flags; | 318 | unsigned long flags; |
306 | struct list_head deleted_list, *p, *n; | 319 | struct list_head deleted_list, *p, *n; |
@@ -323,7 +336,7 @@ int snd_seq_delete_all_ports(client_t *client) | |||
323 | 336 | ||
324 | /* remove each port in deleted_list */ | 337 | /* remove each port in deleted_list */ |
325 | list_for_each_safe(p, n, &deleted_list) { | 338 | list_for_each_safe(p, n, &deleted_list) { |
326 | client_port_t *port = list_entry(p, client_port_t, list); | 339 | struct snd_seq_client_port *port = list_entry(p, struct snd_seq_client_port, list); |
327 | list_del(p); | 340 | list_del(p); |
328 | snd_seq_system_client_ev_port_exit(port->addr.client, port->addr.port); | 341 | snd_seq_system_client_ev_port_exit(port->addr.client, port->addr.port); |
329 | port_delete(client, port); | 342 | port_delete(client, port); |
@@ -333,7 +346,8 @@ int snd_seq_delete_all_ports(client_t *client) | |||
333 | } | 346 | } |
334 | 347 | ||
335 | /* set port info fields */ | 348 | /* set port info fields */ |
336 | int snd_seq_set_port_info(client_port_t * port, snd_seq_port_info_t * info) | 349 | int snd_seq_set_port_info(struct snd_seq_client_port * port, |
350 | struct snd_seq_port_info * info) | ||
337 | { | 351 | { |
338 | snd_assert(port && info, return -EINVAL); | 352 | snd_assert(port && info, return -EINVAL); |
339 | 353 | ||
@@ -361,7 +375,8 @@ int snd_seq_set_port_info(client_port_t * port, snd_seq_port_info_t * info) | |||
361 | } | 375 | } |
362 | 376 | ||
363 | /* get port info fields */ | 377 | /* get port info fields */ |
364 | int snd_seq_get_port_info(client_port_t * port, snd_seq_port_info_t * info) | 378 | int snd_seq_get_port_info(struct snd_seq_client_port * port, |
379 | struct snd_seq_port_info * info) | ||
365 | { | 380 | { |
366 | snd_assert(port && info, return -EINVAL); | 381 | snd_assert(port && info, return -EINVAL); |
367 | 382 | ||
@@ -410,8 +425,11 @@ int snd_seq_get_port_info(client_port_t * port, snd_seq_port_info_t * info) | |||
410 | * at each connnection/disconnection. | 425 | * at each connnection/disconnection. |
411 | */ | 426 | */ |
412 | 427 | ||
413 | static int subscribe_port(client_t *client, client_port_t *port, port_subs_info_t *grp, | 428 | static int subscribe_port(struct snd_seq_client *client, |
414 | snd_seq_port_subscribe_t *info, int send_ack) | 429 | struct snd_seq_client_port *port, |
430 | struct snd_seq_port_subs_info *grp, | ||
431 | struct snd_seq_port_subscribe *info, | ||
432 | int send_ack) | ||
415 | { | 433 | { |
416 | int err = 0; | 434 | int err = 0; |
417 | 435 | ||
@@ -432,9 +450,11 @@ static int subscribe_port(client_t *client, client_port_t *port, port_subs_info_ | |||
432 | return err; | 450 | return err; |
433 | } | 451 | } |
434 | 452 | ||
435 | static int unsubscribe_port(client_t *client, client_port_t *port, | 453 | static int unsubscribe_port(struct snd_seq_client *client, |
436 | port_subs_info_t *grp, | 454 | struct snd_seq_client_port *port, |
437 | snd_seq_port_subscribe_t *info, int send_ack) | 455 | struct snd_seq_port_subs_info *grp, |
456 | struct snd_seq_port_subscribe *info, | ||
457 | int send_ack) | ||
438 | { | 458 | { |
439 | int err = 0; | 459 | int err = 0; |
440 | 460 | ||
@@ -453,15 +473,15 @@ static int unsubscribe_port(client_t *client, client_port_t *port, | |||
453 | 473 | ||
454 | 474 | ||
455 | /* check if both addresses are identical */ | 475 | /* check if both addresses are identical */ |
456 | static inline int addr_match(snd_seq_addr_t *r, snd_seq_addr_t *s) | 476 | static inline int addr_match(struct snd_seq_addr *r, struct snd_seq_addr *s) |
457 | { | 477 | { |
458 | return (r->client == s->client) && (r->port == s->port); | 478 | return (r->client == s->client) && (r->port == s->port); |
459 | } | 479 | } |
460 | 480 | ||
461 | /* check the two subscribe info match */ | 481 | /* check the two subscribe info match */ |
462 | /* if flags is zero, checks only sender and destination addresses */ | 482 | /* if flags is zero, checks only sender and destination addresses */ |
463 | static int match_subs_info(snd_seq_port_subscribe_t *r, | 483 | static int match_subs_info(struct snd_seq_port_subscribe *r, |
464 | snd_seq_port_subscribe_t *s) | 484 | struct snd_seq_port_subscribe *s) |
465 | { | 485 | { |
466 | if (addr_match(&r->sender, &s->sender) && | 486 | if (addr_match(&r->sender, &s->sender) && |
467 | addr_match(&r->dest, &s->dest)) { | 487 | addr_match(&r->dest, &s->dest)) { |
@@ -475,14 +495,16 @@ static int match_subs_info(snd_seq_port_subscribe_t *r, | |||
475 | 495 | ||
476 | 496 | ||
477 | /* connect two ports */ | 497 | /* connect two ports */ |
478 | int snd_seq_port_connect(client_t *connector, | 498 | int snd_seq_port_connect(struct snd_seq_client *connector, |
479 | client_t *src_client, client_port_t *src_port, | 499 | struct snd_seq_client *src_client, |
480 | client_t *dest_client, client_port_t *dest_port, | 500 | struct snd_seq_client_port *src_port, |
481 | snd_seq_port_subscribe_t *info) | 501 | struct snd_seq_client *dest_client, |
502 | struct snd_seq_client_port *dest_port, | ||
503 | struct snd_seq_port_subscribe *info) | ||
482 | { | 504 | { |
483 | port_subs_info_t *src = &src_port->c_src; | 505 | struct snd_seq_port_subs_info *src = &src_port->c_src; |
484 | port_subs_info_t *dest = &dest_port->c_dest; | 506 | struct snd_seq_port_subs_info *dest = &dest_port->c_dest; |
485 | subscribers_t *subs; | 507 | struct snd_seq_subscribers *subs; |
486 | struct list_head *p; | 508 | struct list_head *p; |
487 | int err, src_called = 0; | 509 | int err, src_called = 0; |
488 | unsigned long flags; | 510 | unsigned long flags; |
@@ -508,12 +530,12 @@ int snd_seq_port_connect(client_t *connector, | |||
508 | goto __error; | 530 | goto __error; |
509 | /* check whether already exists */ | 531 | /* check whether already exists */ |
510 | list_for_each(p, &src->list_head) { | 532 | list_for_each(p, &src->list_head) { |
511 | subscribers_t *s = list_entry(p, subscribers_t, src_list); | 533 | struct snd_seq_subscribers *s = list_entry(p, struct snd_seq_subscribers, src_list); |
512 | if (match_subs_info(info, &s->info)) | 534 | if (match_subs_info(info, &s->info)) |
513 | goto __error; | 535 | goto __error; |
514 | } | 536 | } |
515 | list_for_each(p, &dest->list_head) { | 537 | list_for_each(p, &dest->list_head) { |
516 | subscribers_t *s = list_entry(p, subscribers_t, dest_list); | 538 | struct snd_seq_subscribers *s = list_entry(p, struct snd_seq_subscribers, dest_list); |
517 | if (match_subs_info(info, &s->info)) | 539 | if (match_subs_info(info, &s->info)) |
518 | goto __error; | 540 | goto __error; |
519 | } | 541 | } |
@@ -554,14 +576,16 @@ int snd_seq_port_connect(client_t *connector, | |||
554 | 576 | ||
555 | 577 | ||
556 | /* remove the connection */ | 578 | /* remove the connection */ |
557 | int snd_seq_port_disconnect(client_t *connector, | 579 | int snd_seq_port_disconnect(struct snd_seq_client *connector, |
558 | client_t *src_client, client_port_t *src_port, | 580 | struct snd_seq_client *src_client, |
559 | client_t *dest_client, client_port_t *dest_port, | 581 | struct snd_seq_client_port *src_port, |
560 | snd_seq_port_subscribe_t *info) | 582 | struct snd_seq_client *dest_client, |
583 | struct snd_seq_client_port *dest_port, | ||
584 | struct snd_seq_port_subscribe *info) | ||
561 | { | 585 | { |
562 | port_subs_info_t *src = &src_port->c_src; | 586 | struct snd_seq_port_subs_info *src = &src_port->c_src; |
563 | port_subs_info_t *dest = &dest_port->c_dest; | 587 | struct snd_seq_port_subs_info *dest = &dest_port->c_dest; |
564 | subscribers_t *subs; | 588 | struct snd_seq_subscribers *subs; |
565 | struct list_head *p; | 589 | struct list_head *p; |
566 | int err = -ENOENT; | 590 | int err = -ENOENT; |
567 | unsigned long flags; | 591 | unsigned long flags; |
@@ -571,7 +595,7 @@ int snd_seq_port_disconnect(client_t *connector, | |||
571 | 595 | ||
572 | /* look for the connection */ | 596 | /* look for the connection */ |
573 | list_for_each(p, &src->list_head) { | 597 | list_for_each(p, &src->list_head) { |
574 | subs = list_entry(p, subscribers_t, src_list); | 598 | subs = list_entry(p, struct snd_seq_subscribers, src_list); |
575 | if (match_subs_info(info, &subs->info)) { | 599 | if (match_subs_info(info, &subs->info)) { |
576 | write_lock_irqsave(&src->list_lock, flags); | 600 | write_lock_irqsave(&src->list_lock, flags); |
577 | // write_lock(&dest->list_lock); // no lock yet | 601 | // write_lock(&dest->list_lock); // no lock yet |
@@ -597,15 +621,15 @@ int snd_seq_port_disconnect(client_t *connector, | |||
597 | 621 | ||
598 | 622 | ||
599 | /* get matched subscriber */ | 623 | /* get matched subscriber */ |
600 | subscribers_t *snd_seq_port_get_subscription(port_subs_info_t *src_grp, | 624 | struct snd_seq_subscribers *snd_seq_port_get_subscription(struct snd_seq_port_subs_info *src_grp, |
601 | snd_seq_addr_t *dest_addr) | 625 | struct snd_seq_addr *dest_addr) |
602 | { | 626 | { |
603 | struct list_head *p; | 627 | struct list_head *p; |
604 | subscribers_t *s, *found = NULL; | 628 | struct snd_seq_subscribers *s, *found = NULL; |
605 | 629 | ||
606 | down_read(&src_grp->list_mutex); | 630 | down_read(&src_grp->list_mutex); |
607 | list_for_each(p, &src_grp->list_head) { | 631 | list_for_each(p, &src_grp->list_head) { |
608 | s = list_entry(p, subscribers_t, src_list); | 632 | s = list_entry(p, struct snd_seq_subscribers, src_list); |
609 | if (addr_match(dest_addr, &s->info.dest)) { | 633 | if (addr_match(dest_addr, &s->info.dest)) { |
610 | found = s; | 634 | found = s; |
611 | break; | 635 | break; |
@@ -623,11 +647,11 @@ subscribers_t *snd_seq_port_get_subscription(port_subs_info_t *src_grp, | |||
623 | */ | 647 | */ |
624 | /* exported */ | 648 | /* exported */ |
625 | int snd_seq_event_port_attach(int client, | 649 | int snd_seq_event_port_attach(int client, |
626 | snd_seq_port_callback_t *pcbp, | 650 | struct snd_seq_port_callback *pcbp, |
627 | int cap, int type, int midi_channels, | 651 | int cap, int type, int midi_channels, |
628 | int midi_voices, char *portname) | 652 | int midi_voices, char *portname) |
629 | { | 653 | { |
630 | snd_seq_port_info_t portinfo; | 654 | struct snd_seq_port_info portinfo; |
631 | int ret; | 655 | int ret; |
632 | 656 | ||
633 | /* Set up the port */ | 657 | /* Set up the port */ |
@@ -660,7 +684,7 @@ int snd_seq_event_port_attach(int client, | |||
660 | /* exported */ | 684 | /* exported */ |
661 | int snd_seq_event_port_detach(int client, int port) | 685 | int snd_seq_event_port_detach(int client, int port) |
662 | { | 686 | { |
663 | snd_seq_port_info_t portinfo; | 687 | struct snd_seq_port_info portinfo; |
664 | int err; | 688 | int err; |
665 | 689 | ||
666 | memset(&portinfo, 0, sizeof(portinfo)); | 690 | memset(&portinfo, 0, sizeof(portinfo)); |
diff --git a/sound/core/seq/seq_ports.h b/sound/core/seq/seq_ports.h index 89fd4416f6fa..9d7117118ba4 100644 --- a/sound/core/seq/seq_ports.h +++ b/sound/core/seq/seq_ports.h | |||
@@ -40,37 +40,38 @@ | |||
40 | 40 | ||
41 | */ | 41 | */ |
42 | 42 | ||
43 | typedef struct subscribers_t { | 43 | struct snd_seq_subscribers { |
44 | snd_seq_port_subscribe_t info; /* additional info */ | 44 | struct snd_seq_port_subscribe info; /* additional info */ |
45 | struct list_head src_list; /* link of sources */ | 45 | struct list_head src_list; /* link of sources */ |
46 | struct list_head dest_list; /* link of destinations */ | 46 | struct list_head dest_list; /* link of destinations */ |
47 | atomic_t ref_count; | 47 | atomic_t ref_count; |
48 | } subscribers_t; | 48 | }; |
49 | 49 | ||
50 | typedef struct port_subs_info_t { | 50 | struct snd_seq_port_subs_info { |
51 | struct list_head list_head; /* list of subscribed ports */ | 51 | struct list_head list_head; /* list of subscribed ports */ |
52 | unsigned int count; /* count of subscribers */ | 52 | unsigned int count; /* count of subscribers */ |
53 | unsigned int exclusive: 1; /* exclusive mode */ | 53 | unsigned int exclusive: 1; /* exclusive mode */ |
54 | struct rw_semaphore list_mutex; | 54 | struct rw_semaphore list_mutex; |
55 | rwlock_t list_lock; | 55 | rwlock_t list_lock; |
56 | snd_seq_kernel_port_open_t *open; | 56 | int (*open)(void *private_data, struct snd_seq_port_subscribe *info); |
57 | snd_seq_kernel_port_close_t *close; | 57 | int (*close)(void *private_data, struct snd_seq_port_subscribe *info); |
58 | } port_subs_info_t; | 58 | }; |
59 | 59 | ||
60 | typedef struct client_port_t { | 60 | struct snd_seq_client_port { |
61 | 61 | ||
62 | snd_seq_addr_t addr; /* client/port number */ | 62 | struct snd_seq_addr addr; /* client/port number */ |
63 | struct module *owner; /* owner of this port */ | 63 | struct module *owner; /* owner of this port */ |
64 | char name[64]; /* port name */ | 64 | char name[64]; /* port name */ |
65 | struct list_head list; /* port list */ | 65 | struct list_head list; /* port list */ |
66 | snd_use_lock_t use_lock; | 66 | snd_use_lock_t use_lock; |
67 | 67 | ||
68 | /* subscribers */ | 68 | /* subscribers */ |
69 | port_subs_info_t c_src; /* read (sender) list */ | 69 | struct snd_seq_port_subs_info c_src; /* read (sender) list */ |
70 | port_subs_info_t c_dest; /* write (dest) list */ | 70 | struct snd_seq_port_subs_info c_dest; /* write (dest) list */ |
71 | 71 | ||
72 | snd_seq_kernel_port_input_t *event_input; | 72 | int (*event_input)(struct snd_seq_event *ev, int direct, void *private_data, |
73 | snd_seq_kernel_port_private_free_t *private_free; | 73 | int atomic, int hop); |
74 | void (*private_free)(void *private_data); | ||
74 | void *private_data; | 75 | void *private_data; |
75 | unsigned int callback_all : 1; | 76 | unsigned int callback_all : 1; |
76 | unsigned int closing : 1; | 77 | unsigned int closing : 1; |
@@ -87,42 +88,55 @@ typedef struct client_port_t { | |||
87 | int midi_voices; | 88 | int midi_voices; |
88 | int synth_voices; | 89 | int synth_voices; |
89 | 90 | ||
90 | } client_port_t; | 91 | }; |
92 | |||
93 | struct snd_seq_client; | ||
91 | 94 | ||
92 | /* return pointer to port structure and lock port */ | 95 | /* return pointer to port structure and lock port */ |
93 | client_port_t *snd_seq_port_use_ptr(client_t *client, int num); | 96 | struct snd_seq_client_port *snd_seq_port_use_ptr(struct snd_seq_client *client, int num); |
94 | 97 | ||
95 | /* search for next port - port is locked if found */ | 98 | /* search for next port - port is locked if found */ |
96 | client_port_t *snd_seq_port_query_nearest(client_t *client, snd_seq_port_info_t *pinfo); | 99 | struct snd_seq_client_port *snd_seq_port_query_nearest(struct snd_seq_client *client, |
100 | struct snd_seq_port_info *pinfo); | ||
97 | 101 | ||
98 | /* unlock the port */ | 102 | /* unlock the port */ |
99 | #define snd_seq_port_unlock(port) snd_use_lock_free(&(port)->use_lock) | 103 | #define snd_seq_port_unlock(port) snd_use_lock_free(&(port)->use_lock) |
100 | 104 | ||
101 | /* create a port, port number is returned (-1 on failure) */ | 105 | /* create a port, port number is returned (-1 on failure) */ |
102 | client_port_t *snd_seq_create_port(client_t *client, int port_index); | 106 | struct snd_seq_client_port *snd_seq_create_port(struct snd_seq_client *client, int port_index); |
103 | 107 | ||
104 | /* delete a port */ | 108 | /* delete a port */ |
105 | int snd_seq_delete_port(client_t *client, int port); | 109 | int snd_seq_delete_port(struct snd_seq_client *client, int port); |
106 | 110 | ||
107 | /* delete all ports */ | 111 | /* delete all ports */ |
108 | int snd_seq_delete_all_ports(client_t *client); | 112 | int snd_seq_delete_all_ports(struct snd_seq_client *client); |
109 | 113 | ||
110 | /* set port info fields */ | 114 | /* set port info fields */ |
111 | int snd_seq_set_port_info(client_port_t *port, snd_seq_port_info_t *info); | 115 | int snd_seq_set_port_info(struct snd_seq_client_port *port, |
116 | struct snd_seq_port_info *info); | ||
112 | 117 | ||
113 | /* get port info fields */ | 118 | /* get port info fields */ |
114 | int snd_seq_get_port_info(client_port_t *port, snd_seq_port_info_t *info); | 119 | int snd_seq_get_port_info(struct snd_seq_client_port *port, |
120 | struct snd_seq_port_info *info); | ||
115 | 121 | ||
116 | /* add subscriber to subscription list */ | 122 | /* add subscriber to subscription list */ |
117 | int snd_seq_port_connect(client_t *caller, client_t *s, client_port_t *sp, client_t *d, client_port_t *dp, snd_seq_port_subscribe_t *info); | 123 | int snd_seq_port_connect(struct snd_seq_client *caller, |
124 | struct snd_seq_client *s, struct snd_seq_client_port *sp, | ||
125 | struct snd_seq_client *d, struct snd_seq_client_port *dp, | ||
126 | struct snd_seq_port_subscribe *info); | ||
118 | 127 | ||
119 | /* remove subscriber from subscription list */ | 128 | /* remove subscriber from subscription list */ |
120 | int snd_seq_port_disconnect(client_t *caller, client_t *s, client_port_t *sp, client_t *d, client_port_t *dp, snd_seq_port_subscribe_t *info); | 129 | int snd_seq_port_disconnect(struct snd_seq_client *caller, |
130 | struct snd_seq_client *s, struct snd_seq_client_port *sp, | ||
131 | struct snd_seq_client *d, struct snd_seq_client_port *dp, | ||
132 | struct snd_seq_port_subscribe *info); | ||
121 | 133 | ||
122 | /* subscribe port */ | 134 | /* subscribe port */ |
123 | int snd_seq_port_subscribe(client_port_t *port, snd_seq_port_subscribe_t *info); | 135 | int snd_seq_port_subscribe(struct snd_seq_client_port *port, |
136 | struct snd_seq_port_subscribe *info); | ||
124 | 137 | ||
125 | /* get matched subscriber */ | 138 | /* get matched subscriber */ |
126 | subscribers_t *snd_seq_port_get_subscription(port_subs_info_t *src_grp, snd_seq_addr_t *dest_addr); | 139 | struct snd_seq_subscribers *snd_seq_port_get_subscription(struct snd_seq_port_subs_info *src_grp, |
140 | struct snd_seq_addr *dest_addr); | ||
127 | 141 | ||
128 | #endif | 142 | #endif |
diff --git a/sound/core/seq/seq_prioq.c b/sound/core/seq/seq_prioq.c index cd641bca9945..074418617ee9 100644 --- a/sound/core/seq/seq_prioq.c +++ b/sound/core/seq/seq_prioq.c | |||
@@ -55,9 +55,9 @@ | |||
55 | 55 | ||
56 | 56 | ||
57 | /* create new prioq (constructor) */ | 57 | /* create new prioq (constructor) */ |
58 | prioq_t *snd_seq_prioq_new(void) | 58 | struct snd_seq_prioq *snd_seq_prioq_new(void) |
59 | { | 59 | { |
60 | prioq_t *f; | 60 | struct snd_seq_prioq *f; |
61 | 61 | ||
62 | f = kzalloc(sizeof(*f), GFP_KERNEL); | 62 | f = kzalloc(sizeof(*f), GFP_KERNEL); |
63 | if (f == NULL) { | 63 | if (f == NULL) { |
@@ -74,9 +74,9 @@ prioq_t *snd_seq_prioq_new(void) | |||
74 | } | 74 | } |
75 | 75 | ||
76 | /* delete prioq (destructor) */ | 76 | /* delete prioq (destructor) */ |
77 | void snd_seq_prioq_delete(prioq_t **fifo) | 77 | void snd_seq_prioq_delete(struct snd_seq_prioq **fifo) |
78 | { | 78 | { |
79 | prioq_t *f = *fifo; | 79 | struct snd_seq_prioq *f = *fifo; |
80 | *fifo = NULL; | 80 | *fifo = NULL; |
81 | 81 | ||
82 | if (f == NULL) { | 82 | if (f == NULL) { |
@@ -101,7 +101,8 @@ void snd_seq_prioq_delete(prioq_t **fifo) | |||
101 | 101 | ||
102 | /* compare timestamp between events */ | 102 | /* compare timestamp between events */ |
103 | /* return 1 if a >= b; 0 */ | 103 | /* return 1 if a >= b; 0 */ |
104 | static inline int compare_timestamp(snd_seq_event_t * a, snd_seq_event_t * b) | 104 | static inline int compare_timestamp(struct snd_seq_event *a, |
105 | struct snd_seq_event *b) | ||
105 | { | 106 | { |
106 | if ((a->flags & SNDRV_SEQ_TIME_STAMP_MASK) == SNDRV_SEQ_TIME_STAMP_TICK) { | 107 | if ((a->flags & SNDRV_SEQ_TIME_STAMP_MASK) == SNDRV_SEQ_TIME_STAMP_TICK) { |
107 | /* compare ticks */ | 108 | /* compare ticks */ |
@@ -117,7 +118,8 @@ static inline int compare_timestamp(snd_seq_event_t * a, snd_seq_event_t * b) | |||
117 | * zero if a = b; | 118 | * zero if a = b; |
118 | * positive if a > b; | 119 | * positive if a > b; |
119 | */ | 120 | */ |
120 | static inline int compare_timestamp_rel(snd_seq_event_t *a, snd_seq_event_t *b) | 121 | static inline int compare_timestamp_rel(struct snd_seq_event *a, |
122 | struct snd_seq_event *b) | ||
121 | { | 123 | { |
122 | if ((a->flags & SNDRV_SEQ_TIME_STAMP_MASK) == SNDRV_SEQ_TIME_STAMP_TICK) { | 124 | if ((a->flags & SNDRV_SEQ_TIME_STAMP_MASK) == SNDRV_SEQ_TIME_STAMP_TICK) { |
123 | /* compare ticks */ | 125 | /* compare ticks */ |
@@ -144,9 +146,10 @@ static inline int compare_timestamp_rel(snd_seq_event_t *a, snd_seq_event_t *b) | |||
144 | } | 146 | } |
145 | 147 | ||
146 | /* enqueue cell to prioq */ | 148 | /* enqueue cell to prioq */ |
147 | int snd_seq_prioq_cell_in(prioq_t * f, snd_seq_event_cell_t * cell) | 149 | int snd_seq_prioq_cell_in(struct snd_seq_prioq * f, |
150 | struct snd_seq_event_cell * cell) | ||
148 | { | 151 | { |
149 | snd_seq_event_cell_t *cur, *prev; | 152 | struct snd_seq_event_cell *cur, *prev; |
150 | unsigned long flags; | 153 | unsigned long flags; |
151 | int count; | 154 | int count; |
152 | int prior; | 155 | int prior; |
@@ -215,9 +218,9 @@ int snd_seq_prioq_cell_in(prioq_t * f, snd_seq_event_cell_t * cell) | |||
215 | } | 218 | } |
216 | 219 | ||
217 | /* dequeue cell from prioq */ | 220 | /* dequeue cell from prioq */ |
218 | snd_seq_event_cell_t *snd_seq_prioq_cell_out(prioq_t * f) | 221 | struct snd_seq_event_cell *snd_seq_prioq_cell_out(struct snd_seq_prioq *f) |
219 | { | 222 | { |
220 | snd_seq_event_cell_t *cell; | 223 | struct snd_seq_event_cell *cell; |
221 | unsigned long flags; | 224 | unsigned long flags; |
222 | 225 | ||
223 | if (f == NULL) { | 226 | if (f == NULL) { |
@@ -243,7 +246,7 @@ snd_seq_event_cell_t *snd_seq_prioq_cell_out(prioq_t * f) | |||
243 | } | 246 | } |
244 | 247 | ||
245 | /* return number of events available in prioq */ | 248 | /* return number of events available in prioq */ |
246 | int snd_seq_prioq_avail(prioq_t * f) | 249 | int snd_seq_prioq_avail(struct snd_seq_prioq * f) |
247 | { | 250 | { |
248 | if (f == NULL) { | 251 | if (f == NULL) { |
249 | snd_printd("oops: snd_seq_prioq_cell_in() called with NULL prioq\n"); | 252 | snd_printd("oops: snd_seq_prioq_cell_in() called with NULL prioq\n"); |
@@ -254,7 +257,7 @@ int snd_seq_prioq_avail(prioq_t * f) | |||
254 | 257 | ||
255 | 258 | ||
256 | /* peek at cell at the head of the prioq */ | 259 | /* peek at cell at the head of the prioq */ |
257 | snd_seq_event_cell_t *snd_seq_prioq_cell_peek(prioq_t * f) | 260 | struct snd_seq_event_cell *snd_seq_prioq_cell_peek(struct snd_seq_prioq * f) |
258 | { | 261 | { |
259 | if (f == NULL) { | 262 | if (f == NULL) { |
260 | snd_printd("oops: snd_seq_prioq_cell_in() called with NULL prioq\n"); | 263 | snd_printd("oops: snd_seq_prioq_cell_in() called with NULL prioq\n"); |
@@ -264,7 +267,8 @@ snd_seq_event_cell_t *snd_seq_prioq_cell_peek(prioq_t * f) | |||
264 | } | 267 | } |
265 | 268 | ||
266 | 269 | ||
267 | static inline int prioq_match(snd_seq_event_cell_t *cell, int client, int timestamp) | 270 | static inline int prioq_match(struct snd_seq_event_cell *cell, |
271 | int client, int timestamp) | ||
268 | { | 272 | { |
269 | if (cell->event.source.client == client || | 273 | if (cell->event.source.client == client || |
270 | cell->event.dest.client == client) | 274 | cell->event.dest.client == client) |
@@ -286,12 +290,12 @@ static inline int prioq_match(snd_seq_event_cell_t *cell, int client, int timest | |||
286 | } | 290 | } |
287 | 291 | ||
288 | /* remove cells for left client */ | 292 | /* remove cells for left client */ |
289 | void snd_seq_prioq_leave(prioq_t * f, int client, int timestamp) | 293 | void snd_seq_prioq_leave(struct snd_seq_prioq * f, int client, int timestamp) |
290 | { | 294 | { |
291 | register snd_seq_event_cell_t *cell, *next; | 295 | register struct snd_seq_event_cell *cell, *next; |
292 | unsigned long flags; | 296 | unsigned long flags; |
293 | snd_seq_event_cell_t *prev = NULL; | 297 | struct snd_seq_event_cell *prev = NULL; |
294 | snd_seq_event_cell_t *freefirst = NULL, *freeprev = NULL, *freenext; | 298 | struct snd_seq_event_cell *freefirst = NULL, *freeprev = NULL, *freenext; |
295 | 299 | ||
296 | /* collect all removed cells */ | 300 | /* collect all removed cells */ |
297 | spin_lock_irqsave(&f->lock, flags); | 301 | spin_lock_irqsave(&f->lock, flags); |
@@ -338,8 +342,8 @@ void snd_seq_prioq_leave(prioq_t * f, int client, int timestamp) | |||
338 | } | 342 | } |
339 | } | 343 | } |
340 | 344 | ||
341 | static int prioq_remove_match(snd_seq_remove_events_t *info, | 345 | static int prioq_remove_match(struct snd_seq_remove_events *info, |
342 | snd_seq_event_t *ev) | 346 | struct snd_seq_event *ev) |
343 | { | 347 | { |
344 | int res; | 348 | int res; |
345 | 349 | ||
@@ -394,13 +398,13 @@ static int prioq_remove_match(snd_seq_remove_events_t *info, | |||
394 | } | 398 | } |
395 | 399 | ||
396 | /* remove cells matching remove criteria */ | 400 | /* remove cells matching remove criteria */ |
397 | void snd_seq_prioq_remove_events(prioq_t * f, int client, | 401 | void snd_seq_prioq_remove_events(struct snd_seq_prioq * f, int client, |
398 | snd_seq_remove_events_t *info) | 402 | struct snd_seq_remove_events *info) |
399 | { | 403 | { |
400 | register snd_seq_event_cell_t *cell, *next; | 404 | struct snd_seq_event_cell *cell, *next; |
401 | unsigned long flags; | 405 | unsigned long flags; |
402 | snd_seq_event_cell_t *prev = NULL; | 406 | struct snd_seq_event_cell *prev = NULL; |
403 | snd_seq_event_cell_t *freefirst = NULL, *freeprev = NULL, *freenext; | 407 | struct snd_seq_event_cell *freefirst = NULL, *freeprev = NULL, *freenext; |
404 | 408 | ||
405 | /* collect all removed cells */ | 409 | /* collect all removed cells */ |
406 | spin_lock_irqsave(&f->lock, flags); | 410 | spin_lock_irqsave(&f->lock, flags); |
diff --git a/sound/core/seq/seq_prioq.h b/sound/core/seq/seq_prioq.h index f12af79308b8..d38bb78d9345 100644 --- a/sound/core/seq/seq_prioq.h +++ b/sound/core/seq/seq_prioq.h | |||
@@ -26,37 +26,37 @@ | |||
26 | 26 | ||
27 | /* === PRIOQ === */ | 27 | /* === PRIOQ === */ |
28 | 28 | ||
29 | typedef struct { | 29 | struct snd_seq_prioq { |
30 | snd_seq_event_cell_t* head; /* pointer to head of prioq */ | 30 | struct snd_seq_event_cell *head; /* pointer to head of prioq */ |
31 | snd_seq_event_cell_t* tail; /* pointer to tail of prioq */ | 31 | struct snd_seq_event_cell *tail; /* pointer to tail of prioq */ |
32 | int cells; | 32 | int cells; |
33 | spinlock_t lock; | 33 | spinlock_t lock; |
34 | } prioq_t; | 34 | }; |
35 | 35 | ||
36 | 36 | ||
37 | /* create new prioq (constructor) */ | 37 | /* create new prioq (constructor) */ |
38 | extern prioq_t *snd_seq_prioq_new(void); | 38 | struct snd_seq_prioq *snd_seq_prioq_new(void); |
39 | 39 | ||
40 | /* delete prioq (destructor) */ | 40 | /* delete prioq (destructor) */ |
41 | extern void snd_seq_prioq_delete(prioq_t **fifo); | 41 | void snd_seq_prioq_delete(struct snd_seq_prioq **fifo); |
42 | 42 | ||
43 | /* enqueue cell to prioq */ | 43 | /* enqueue cell to prioq */ |
44 | extern int snd_seq_prioq_cell_in(prioq_t *f, snd_seq_event_cell_t *cell); | 44 | int snd_seq_prioq_cell_in(struct snd_seq_prioq *f, struct snd_seq_event_cell *cell); |
45 | 45 | ||
46 | /* dequeue cell from prioq */ | 46 | /* dequeue cell from prioq */ |
47 | extern snd_seq_event_cell_t *snd_seq_prioq_cell_out(prioq_t *f); | 47 | struct snd_seq_event_cell *snd_seq_prioq_cell_out(struct snd_seq_prioq *f); |
48 | 48 | ||
49 | /* return number of events available in prioq */ | 49 | /* return number of events available in prioq */ |
50 | extern int snd_seq_prioq_avail(prioq_t *f); | 50 | int snd_seq_prioq_avail(struct snd_seq_prioq *f); |
51 | 51 | ||
52 | /* peek at cell at the head of the prioq */ | 52 | /* peek at cell at the head of the prioq */ |
53 | extern snd_seq_event_cell_t *snd_seq_prioq_cell_peek(prioq_t *f); | 53 | struct snd_seq_event_cell *snd_seq_prioq_cell_peek(struct snd_seq_prioq *f); |
54 | 54 | ||
55 | /* client left queue */ | 55 | /* client left queue */ |
56 | extern void snd_seq_prioq_leave(prioq_t *f, int client, int timestamp); | 56 | void snd_seq_prioq_leave(struct snd_seq_prioq *f, int client, int timestamp); |
57 | 57 | ||
58 | /* Remove events */ | 58 | /* Remove events */ |
59 | void snd_seq_prioq_remove_events(prioq_t * f, int client, | 59 | void snd_seq_prioq_remove_events(struct snd_seq_prioq *f, int client, |
60 | snd_seq_remove_events_t *info); | 60 | struct snd_seq_remove_events *info); |
61 | 61 | ||
62 | #endif | 62 | #endif |
diff --git a/sound/core/seq/seq_queue.c b/sound/core/seq/seq_queue.c index 5f5c3cb37cbf..b537a71e1e19 100644 --- a/sound/core/seq/seq_queue.c +++ b/sound/core/seq/seq_queue.c | |||
@@ -29,7 +29,7 @@ | |||
29 | * Aug. 30, 2000 Takashi Iwai | 29 | * Aug. 30, 2000 Takashi Iwai |
30 | * - Queues are managed in static array again, but with better way. | 30 | * - Queues are managed in static array again, but with better way. |
31 | * The API itself is identical. | 31 | * The API itself is identical. |
32 | * - The queue is locked when queue_t pinter is returned via | 32 | * - The queue is locked when struct snd_seq_queue pointer is returned via |
33 | * queueptr(). This pointer *MUST* be released afterward by | 33 | * queueptr(). This pointer *MUST* be released afterward by |
34 | * queuefree(ptr). | 34 | * queuefree(ptr). |
35 | * - Addition of experimental sync support. | 35 | * - Addition of experimental sync support. |
@@ -48,7 +48,7 @@ | |||
48 | #include "seq_info.h" | 48 | #include "seq_info.h" |
49 | 49 | ||
50 | /* list of allocated queues */ | 50 | /* list of allocated queues */ |
51 | static queue_t *queue_list[SNDRV_SEQ_MAX_QUEUES]; | 51 | static struct snd_seq_queue *queue_list[SNDRV_SEQ_MAX_QUEUES]; |
52 | static DEFINE_SPINLOCK(queue_list_lock); | 52 | static DEFINE_SPINLOCK(queue_list_lock); |
53 | /* number of queues allocated */ | 53 | /* number of queues allocated */ |
54 | static int num_queues; | 54 | static int num_queues; |
@@ -61,7 +61,7 @@ int snd_seq_queue_get_cur_queues(void) | |||
61 | /*----------------------------------------------------------------*/ | 61 | /*----------------------------------------------------------------*/ |
62 | 62 | ||
63 | /* assign queue id and insert to list */ | 63 | /* assign queue id and insert to list */ |
64 | static int queue_list_add(queue_t *q) | 64 | static int queue_list_add(struct snd_seq_queue *q) |
65 | { | 65 | { |
66 | int i; | 66 | int i; |
67 | unsigned long flags; | 67 | unsigned long flags; |
@@ -80,9 +80,9 @@ static int queue_list_add(queue_t *q) | |||
80 | return -1; | 80 | return -1; |
81 | } | 81 | } |
82 | 82 | ||
83 | static queue_t *queue_list_remove(int id, int client) | 83 | static struct snd_seq_queue *queue_list_remove(int id, int client) |
84 | { | 84 | { |
85 | queue_t *q; | 85 | struct snd_seq_queue *q; |
86 | unsigned long flags; | 86 | unsigned long flags; |
87 | 87 | ||
88 | spin_lock_irqsave(&queue_list_lock, flags); | 88 | spin_lock_irqsave(&queue_list_lock, flags); |
@@ -107,9 +107,9 @@ static queue_t *queue_list_remove(int id, int client) | |||
107 | /*----------------------------------------------------------------*/ | 107 | /*----------------------------------------------------------------*/ |
108 | 108 | ||
109 | /* create new queue (constructor) */ | 109 | /* create new queue (constructor) */ |
110 | static queue_t *queue_new(int owner, int locked) | 110 | static struct snd_seq_queue *queue_new(int owner, int locked) |
111 | { | 111 | { |
112 | queue_t *q; | 112 | struct snd_seq_queue *q; |
113 | 113 | ||
114 | q = kzalloc(sizeof(*q), GFP_KERNEL); | 114 | q = kzalloc(sizeof(*q), GFP_KERNEL); |
115 | if (q == NULL) { | 115 | if (q == NULL) { |
@@ -142,7 +142,7 @@ static queue_t *queue_new(int owner, int locked) | |||
142 | } | 142 | } |
143 | 143 | ||
144 | /* delete queue (destructor) */ | 144 | /* delete queue (destructor) */ |
145 | static void queue_delete(queue_t *q) | 145 | static void queue_delete(struct snd_seq_queue *q) |
146 | { | 146 | { |
147 | /* stop and release the timer */ | 147 | /* stop and release the timer */ |
148 | snd_seq_timer_stop(q->timer); | 148 | snd_seq_timer_stop(q->timer); |
@@ -187,7 +187,7 @@ void __exit snd_seq_queues_delete(void) | |||
187 | */ | 187 | */ |
188 | int snd_seq_queue_alloc(int client, int locked, unsigned int info_flags) | 188 | int snd_seq_queue_alloc(int client, int locked, unsigned int info_flags) |
189 | { | 189 | { |
190 | queue_t *q; | 190 | struct snd_seq_queue *q; |
191 | 191 | ||
192 | q = queue_new(client, locked); | 192 | q = queue_new(client, locked); |
193 | if (q == NULL) | 193 | if (q == NULL) |
@@ -204,7 +204,7 @@ int snd_seq_queue_alloc(int client, int locked, unsigned int info_flags) | |||
204 | /* delete a queue - queue must be owned by the client */ | 204 | /* delete a queue - queue must be owned by the client */ |
205 | int snd_seq_queue_delete(int client, int queueid) | 205 | int snd_seq_queue_delete(int client, int queueid) |
206 | { | 206 | { |
207 | queue_t *q; | 207 | struct snd_seq_queue *q; |
208 | 208 | ||
209 | if (queueid < 0 || queueid >= SNDRV_SEQ_MAX_QUEUES) | 209 | if (queueid < 0 || queueid >= SNDRV_SEQ_MAX_QUEUES) |
210 | return -EINVAL; | 210 | return -EINVAL; |
@@ -218,9 +218,9 @@ int snd_seq_queue_delete(int client, int queueid) | |||
218 | 218 | ||
219 | 219 | ||
220 | /* return pointer to queue structure for specified id */ | 220 | /* return pointer to queue structure for specified id */ |
221 | queue_t *queueptr(int queueid) | 221 | struct snd_seq_queue *queueptr(int queueid) |
222 | { | 222 | { |
223 | queue_t *q; | 223 | struct snd_seq_queue *q; |
224 | unsigned long flags; | 224 | unsigned long flags; |
225 | 225 | ||
226 | if (queueid < 0 || queueid >= SNDRV_SEQ_MAX_QUEUES) | 226 | if (queueid < 0 || queueid >= SNDRV_SEQ_MAX_QUEUES) |
@@ -234,10 +234,10 @@ queue_t *queueptr(int queueid) | |||
234 | } | 234 | } |
235 | 235 | ||
236 | /* return the (first) queue matching with the specified name */ | 236 | /* return the (first) queue matching with the specified name */ |
237 | queue_t *snd_seq_queue_find_name(char *name) | 237 | struct snd_seq_queue *snd_seq_queue_find_name(char *name) |
238 | { | 238 | { |
239 | int i; | 239 | int i; |
240 | queue_t *q; | 240 | struct snd_seq_queue *q; |
241 | 241 | ||
242 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { | 242 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { |
243 | if ((q = queueptr(i)) != NULL) { | 243 | if ((q = queueptr(i)) != NULL) { |
@@ -252,10 +252,10 @@ queue_t *snd_seq_queue_find_name(char *name) | |||
252 | 252 | ||
253 | /* -------------------------------------------------------- */ | 253 | /* -------------------------------------------------------- */ |
254 | 254 | ||
255 | void snd_seq_check_queue(queue_t *q, int atomic, int hop) | 255 | void snd_seq_check_queue(struct snd_seq_queue *q, int atomic, int hop) |
256 | { | 256 | { |
257 | unsigned long flags; | 257 | unsigned long flags; |
258 | snd_seq_event_cell_t *cell; | 258 | struct snd_seq_event_cell *cell; |
259 | 259 | ||
260 | if (q == NULL) | 260 | if (q == NULL) |
261 | return; | 261 | return; |
@@ -273,7 +273,8 @@ void snd_seq_check_queue(queue_t *q, int atomic, int hop) | |||
273 | __again: | 273 | __again: |
274 | /* Process tick queue... */ | 274 | /* Process tick queue... */ |
275 | while ((cell = snd_seq_prioq_cell_peek(q->tickq)) != NULL) { | 275 | while ((cell = snd_seq_prioq_cell_peek(q->tickq)) != NULL) { |
276 | if (snd_seq_compare_tick_time(&q->timer->tick.cur_tick, &cell->event.time.tick)) { | 276 | if (snd_seq_compare_tick_time(&q->timer->tick.cur_tick, |
277 | &cell->event.time.tick)) { | ||
277 | cell = snd_seq_prioq_cell_out(q->tickq); | 278 | cell = snd_seq_prioq_cell_out(q->tickq); |
278 | if (cell) | 279 | if (cell) |
279 | snd_seq_dispatch_event(cell, atomic, hop); | 280 | snd_seq_dispatch_event(cell, atomic, hop); |
@@ -286,7 +287,8 @@ void snd_seq_check_queue(queue_t *q, int atomic, int hop) | |||
286 | 287 | ||
287 | /* Process time queue... */ | 288 | /* Process time queue... */ |
288 | while ((cell = snd_seq_prioq_cell_peek(q->timeq)) != NULL) { | 289 | while ((cell = snd_seq_prioq_cell_peek(q->timeq)) != NULL) { |
289 | if (snd_seq_compare_real_time(&q->timer->cur_time, &cell->event.time.time)) { | 290 | if (snd_seq_compare_real_time(&q->timer->cur_time, |
291 | &cell->event.time.time)) { | ||
290 | cell = snd_seq_prioq_cell_out(q->timeq); | 292 | cell = snd_seq_prioq_cell_out(q->timeq); |
291 | if (cell) | 293 | if (cell) |
292 | snd_seq_dispatch_event(cell, atomic, hop); | 294 | snd_seq_dispatch_event(cell, atomic, hop); |
@@ -309,10 +311,10 @@ void snd_seq_check_queue(queue_t *q, int atomic, int hop) | |||
309 | 311 | ||
310 | 312 | ||
311 | /* enqueue a event to singe queue */ | 313 | /* enqueue a event to singe queue */ |
312 | int snd_seq_enqueue_event(snd_seq_event_cell_t *cell, int atomic, int hop) | 314 | int snd_seq_enqueue_event(struct snd_seq_event_cell *cell, int atomic, int hop) |
313 | { | 315 | { |
314 | int dest, err; | 316 | int dest, err; |
315 | queue_t *q; | 317 | struct snd_seq_queue *q; |
316 | 318 | ||
317 | snd_assert(cell != NULL, return -EINVAL); | 319 | snd_assert(cell != NULL, return -EINVAL); |
318 | dest = cell->event.queue; /* destination queue */ | 320 | dest = cell->event.queue; /* destination queue */ |
@@ -327,7 +329,8 @@ int snd_seq_enqueue_event(snd_seq_event_cell_t *cell, int atomic, int hop) | |||
327 | break; | 329 | break; |
328 | 330 | ||
329 | case SNDRV_SEQ_TIME_STAMP_REAL: | 331 | case SNDRV_SEQ_TIME_STAMP_REAL: |
330 | snd_seq_inc_real_time(&cell->event.time.time, &q->timer->cur_time); | 332 | snd_seq_inc_real_time(&cell->event.time.time, |
333 | &q->timer->cur_time); | ||
331 | break; | 334 | break; |
332 | } | 335 | } |
333 | cell->event.flags &= ~SNDRV_SEQ_TIME_MODE_MASK; | 336 | cell->event.flags &= ~SNDRV_SEQ_TIME_MODE_MASK; |
@@ -361,7 +364,7 @@ int snd_seq_enqueue_event(snd_seq_event_cell_t *cell, int atomic, int hop) | |||
361 | 364 | ||
362 | /*----------------------------------------------------------------*/ | 365 | /*----------------------------------------------------------------*/ |
363 | 366 | ||
364 | static inline int check_access(queue_t *q, int client) | 367 | static inline int check_access(struct snd_seq_queue *q, int client) |
365 | { | 368 | { |
366 | return (q->owner == client) || (!q->locked && !q->klocked); | 369 | return (q->owner == client) || (!q->locked && !q->klocked); |
367 | } | 370 | } |
@@ -369,7 +372,7 @@ static inline int check_access(queue_t *q, int client) | |||
369 | /* check if the client has permission to modify queue parameters. | 372 | /* check if the client has permission to modify queue parameters. |
370 | * if it does, lock the queue | 373 | * if it does, lock the queue |
371 | */ | 374 | */ |
372 | static int queue_access_lock(queue_t *q, int client) | 375 | static int queue_access_lock(struct snd_seq_queue *q, int client) |
373 | { | 376 | { |
374 | unsigned long flags; | 377 | unsigned long flags; |
375 | int access_ok; | 378 | int access_ok; |
@@ -383,7 +386,7 @@ static int queue_access_lock(queue_t *q, int client) | |||
383 | } | 386 | } |
384 | 387 | ||
385 | /* unlock the queue */ | 388 | /* unlock the queue */ |
386 | static inline void queue_access_unlock(queue_t *q) | 389 | static inline void queue_access_unlock(struct snd_seq_queue *q) |
387 | { | 390 | { |
388 | unsigned long flags; | 391 | unsigned long flags; |
389 | 392 | ||
@@ -395,7 +398,7 @@ static inline void queue_access_unlock(queue_t *q) | |||
395 | /* exported - only checking permission */ | 398 | /* exported - only checking permission */ |
396 | int snd_seq_queue_check_access(int queueid, int client) | 399 | int snd_seq_queue_check_access(int queueid, int client) |
397 | { | 400 | { |
398 | queue_t *q = queueptr(queueid); | 401 | struct snd_seq_queue *q = queueptr(queueid); |
399 | int access_ok; | 402 | int access_ok; |
400 | unsigned long flags; | 403 | unsigned long flags; |
401 | 404 | ||
@@ -415,7 +418,7 @@ int snd_seq_queue_check_access(int queueid, int client) | |||
415 | */ | 418 | */ |
416 | int snd_seq_queue_set_owner(int queueid, int client, int locked) | 419 | int snd_seq_queue_set_owner(int queueid, int client, int locked) |
417 | { | 420 | { |
418 | queue_t *q = queueptr(queueid); | 421 | struct snd_seq_queue *q = queueptr(queueid); |
419 | 422 | ||
420 | if (q == NULL) | 423 | if (q == NULL) |
421 | return -EINVAL; | 424 | return -EINVAL; |
@@ -443,8 +446,8 @@ int snd_seq_queue_set_owner(int queueid, int client, int locked) | |||
443 | int snd_seq_queue_timer_open(int queueid) | 446 | int snd_seq_queue_timer_open(int queueid) |
444 | { | 447 | { |
445 | int result = 0; | 448 | int result = 0; |
446 | queue_t *queue; | 449 | struct snd_seq_queue *queue; |
447 | seq_timer_t *tmr; | 450 | struct snd_seq_timer *tmr; |
448 | 451 | ||
449 | queue = queueptr(queueid); | 452 | queue = queueptr(queueid); |
450 | if (queue == NULL) | 453 | if (queue == NULL) |
@@ -463,8 +466,8 @@ int snd_seq_queue_timer_open(int queueid) | |||
463 | */ | 466 | */ |
464 | int snd_seq_queue_timer_close(int queueid) | 467 | int snd_seq_queue_timer_close(int queueid) |
465 | { | 468 | { |
466 | queue_t *queue; | 469 | struct snd_seq_queue *queue; |
467 | seq_timer_t *tmr; | 470 | struct snd_seq_timer *tmr; |
468 | int result = 0; | 471 | int result = 0; |
469 | 472 | ||
470 | queue = queueptr(queueid); | 473 | queue = queueptr(queueid); |
@@ -477,9 +480,10 @@ int snd_seq_queue_timer_close(int queueid) | |||
477 | } | 480 | } |
478 | 481 | ||
479 | /* change queue tempo and ppq */ | 482 | /* change queue tempo and ppq */ |
480 | int snd_seq_queue_timer_set_tempo(int queueid, int client, snd_seq_queue_tempo_t *info) | 483 | int snd_seq_queue_timer_set_tempo(int queueid, int client, |
484 | struct snd_seq_queue_tempo *info) | ||
481 | { | 485 | { |
482 | queue_t *q = queueptr(queueid); | 486 | struct snd_seq_queue *q = queueptr(queueid); |
483 | int result; | 487 | int result; |
484 | 488 | ||
485 | if (q == NULL) | 489 | if (q == NULL) |
@@ -493,7 +497,8 @@ int snd_seq_queue_timer_set_tempo(int queueid, int client, snd_seq_queue_tempo_t | |||
493 | if (result >= 0) | 497 | if (result >= 0) |
494 | result = snd_seq_timer_set_ppq(q->timer, info->ppq); | 498 | result = snd_seq_timer_set_ppq(q->timer, info->ppq); |
495 | if (result >= 0 && info->skew_base > 0) | 499 | if (result >= 0 && info->skew_base > 0) |
496 | result = snd_seq_timer_set_skew(q->timer, info->skew_value, info->skew_base); | 500 | result = snd_seq_timer_set_skew(q->timer, info->skew_value, |
501 | info->skew_base); | ||
497 | queue_access_unlock(q); | 502 | queue_access_unlock(q); |
498 | queuefree(q); | 503 | queuefree(q); |
499 | return result; | 504 | return result; |
@@ -506,7 +511,7 @@ int snd_seq_queue_timer_set_tempo(int queueid, int client, snd_seq_queue_tempo_t | |||
506 | */ | 511 | */ |
507 | int snd_seq_queue_use(int queueid, int client, int use) | 512 | int snd_seq_queue_use(int queueid, int client, int use) |
508 | { | 513 | { |
509 | queue_t *queue; | 514 | struct snd_seq_queue *queue; |
510 | 515 | ||
511 | queue = queueptr(queueid); | 516 | queue = queueptr(queueid); |
512 | if (queue == NULL) | 517 | if (queue == NULL) |
@@ -538,7 +543,7 @@ int snd_seq_queue_use(int queueid, int client, int use) | |||
538 | */ | 543 | */ |
539 | int snd_seq_queue_is_used(int queueid, int client) | 544 | int snd_seq_queue_is_used(int queueid, int client) |
540 | { | 545 | { |
541 | queue_t *q; | 546 | struct snd_seq_queue *q; |
542 | int result; | 547 | int result; |
543 | 548 | ||
544 | q = queueptr(queueid); | 549 | q = queueptr(queueid); |
@@ -559,7 +564,7 @@ void snd_seq_queue_client_termination(int client) | |||
559 | { | 564 | { |
560 | unsigned long flags; | 565 | unsigned long flags; |
561 | int i; | 566 | int i; |
562 | queue_t *q; | 567 | struct snd_seq_queue *q; |
563 | 568 | ||
564 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { | 569 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { |
565 | if ((q = queueptr(i)) == NULL) | 570 | if ((q = queueptr(i)) == NULL) |
@@ -584,7 +589,7 @@ void snd_seq_queue_client_termination(int client) | |||
584 | void snd_seq_queue_client_leave(int client) | 589 | void snd_seq_queue_client_leave(int client) |
585 | { | 590 | { |
586 | int i; | 591 | int i; |
587 | queue_t *q; | 592 | struct snd_seq_queue *q; |
588 | 593 | ||
589 | /* delete own queues from queue list */ | 594 | /* delete own queues from queue list */ |
590 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { | 595 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { |
@@ -615,7 +620,7 @@ void snd_seq_queue_client_leave(int client) | |||
615 | void snd_seq_queue_client_leave_cells(int client) | 620 | void snd_seq_queue_client_leave_cells(int client) |
616 | { | 621 | { |
617 | int i; | 622 | int i; |
618 | queue_t *q; | 623 | struct snd_seq_queue *q; |
619 | 624 | ||
620 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { | 625 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { |
621 | if ((q = queueptr(i)) == NULL) | 626 | if ((q = queueptr(i)) == NULL) |
@@ -627,10 +632,10 @@ void snd_seq_queue_client_leave_cells(int client) | |||
627 | } | 632 | } |
628 | 633 | ||
629 | /* remove cells based on flush criteria */ | 634 | /* remove cells based on flush criteria */ |
630 | void snd_seq_queue_remove_cells(int client, snd_seq_remove_events_t *info) | 635 | void snd_seq_queue_remove_cells(int client, struct snd_seq_remove_events *info) |
631 | { | 636 | { |
632 | int i; | 637 | int i; |
633 | queue_t *q; | 638 | struct snd_seq_queue *q; |
634 | 639 | ||
635 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { | 640 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { |
636 | if ((q = queueptr(i)) == NULL) | 641 | if ((q = queueptr(i)) == NULL) |
@@ -650,9 +655,10 @@ void snd_seq_queue_remove_cells(int client, snd_seq_remove_events_t *info) | |||
650 | /* | 655 | /* |
651 | * send events to all subscribed ports | 656 | * send events to all subscribed ports |
652 | */ | 657 | */ |
653 | static void queue_broadcast_event(queue_t *q, snd_seq_event_t *ev, int atomic, int hop) | 658 | static void queue_broadcast_event(struct snd_seq_queue *q, struct snd_seq_event *ev, |
659 | int atomic, int hop) | ||
654 | { | 660 | { |
655 | snd_seq_event_t sev; | 661 | struct snd_seq_event sev; |
656 | 662 | ||
657 | sev = *ev; | 663 | sev = *ev; |
658 | 664 | ||
@@ -672,7 +678,8 @@ static void queue_broadcast_event(queue_t *q, snd_seq_event_t *ev, int atomic, i | |||
672 | * process a received queue-control event. | 678 | * process a received queue-control event. |
673 | * this function is exported for seq_sync.c. | 679 | * this function is exported for seq_sync.c. |
674 | */ | 680 | */ |
675 | static void snd_seq_queue_process_event(queue_t *q, snd_seq_event_t *ev, | 681 | static void snd_seq_queue_process_event(struct snd_seq_queue *q, |
682 | struct snd_seq_event *ev, | ||
676 | int atomic, int hop) | 683 | int atomic, int hop) |
677 | { | 684 | { |
678 | switch (ev->type) { | 685 | switch (ev->type) { |
@@ -724,9 +731,9 @@ static void snd_seq_queue_process_event(queue_t *q, snd_seq_event_t *ev, | |||
724 | * Queue control via timer control port: | 731 | * Queue control via timer control port: |
725 | * this function is exported as a callback of timer port. | 732 | * this function is exported as a callback of timer port. |
726 | */ | 733 | */ |
727 | int snd_seq_control_queue(snd_seq_event_t *ev, int atomic, int hop) | 734 | int snd_seq_control_queue(struct snd_seq_event *ev, int atomic, int hop) |
728 | { | 735 | { |
729 | queue_t *q; | 736 | struct snd_seq_queue *q; |
730 | 737 | ||
731 | snd_assert(ev != NULL, return -EINVAL); | 738 | snd_assert(ev != NULL, return -EINVAL); |
732 | q = queueptr(ev->data.queue.queue); | 739 | q = queueptr(ev->data.queue.queue); |
@@ -750,12 +757,12 @@ int snd_seq_control_queue(snd_seq_event_t *ev, int atomic, int hop) | |||
750 | /*----------------------------------------------------------------*/ | 757 | /*----------------------------------------------------------------*/ |
751 | 758 | ||
752 | /* exported to seq_info.c */ | 759 | /* exported to seq_info.c */ |
753 | void snd_seq_info_queues_read(snd_info_entry_t *entry, | 760 | void snd_seq_info_queues_read(struct snd_info_entry *entry, |
754 | snd_info_buffer_t * buffer) | 761 | struct snd_info_buffer *buffer) |
755 | { | 762 | { |
756 | int i, bpm; | 763 | int i, bpm; |
757 | queue_t *q; | 764 | struct snd_seq_queue *q; |
758 | seq_timer_t *tmr; | 765 | struct snd_seq_timer *tmr; |
759 | 766 | ||
760 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { | 767 | for (i = 0; i < SNDRV_SEQ_MAX_QUEUES; i++) { |
761 | if ((q = queueptr(i)) == NULL) | 768 | if ((q = queueptr(i)) == NULL) |
diff --git a/sound/core/seq/seq_queue.h b/sound/core/seq/seq_queue.h index ea3c54216ea8..888438599387 100644 --- a/sound/core/seq/seq_queue.h +++ b/sound/core/seq/seq_queue.h | |||
@@ -30,15 +30,15 @@ | |||
30 | 30 | ||
31 | #define SEQ_QUEUE_NO_OWNER (-1) | 31 | #define SEQ_QUEUE_NO_OWNER (-1) |
32 | 32 | ||
33 | struct _snd_seq_queue { | 33 | struct snd_seq_queue { |
34 | int queue; /* queue number */ | 34 | int queue; /* queue number */ |
35 | 35 | ||
36 | char name[64]; /* name of this queue */ | 36 | char name[64]; /* name of this queue */ |
37 | 37 | ||
38 | prioq_t *tickq; /* midi tick event queue */ | 38 | struct snd_seq_prioq *tickq; /* midi tick event queue */ |
39 | prioq_t *timeq; /* real-time event queue */ | 39 | struct snd_seq_prioq *timeq; /* real-time event queue */ |
40 | 40 | ||
41 | seq_timer_t *timer; /* time keeper for this queue */ | 41 | struct snd_seq_timer *timer; /* time keeper for this queue */ |
42 | int owner; /* client that 'owns' the timer */ | 42 | int owner; /* client that 'owns' the timer */ |
43 | unsigned int locked:1, /* timer is only accesibble by owner if set */ | 43 | unsigned int locked:1, /* timer is only accesibble by owner if set */ |
44 | klocked:1, /* kernel lock (after START) */ | 44 | klocked:1, /* kernel lock (after START) */ |
@@ -83,26 +83,26 @@ void snd_seq_queue_client_termination(int client); | |||
83 | void snd_seq_queue_client_leave(int client); | 83 | void snd_seq_queue_client_leave(int client); |
84 | 84 | ||
85 | /* enqueue a event received from one the clients */ | 85 | /* enqueue a event received from one the clients */ |
86 | int snd_seq_enqueue_event(snd_seq_event_cell_t *cell, int atomic, int hop); | 86 | int snd_seq_enqueue_event(struct snd_seq_event_cell *cell, int atomic, int hop); |
87 | 87 | ||
88 | /* Remove events */ | 88 | /* Remove events */ |
89 | void snd_seq_queue_client_leave_cells(int client); | 89 | void snd_seq_queue_client_leave_cells(int client); |
90 | void snd_seq_queue_remove_cells(int client, snd_seq_remove_events_t *info); | 90 | void snd_seq_queue_remove_cells(int client, struct snd_seq_remove_events *info); |
91 | 91 | ||
92 | /* return pointer to queue structure for specified id */ | 92 | /* return pointer to queue structure for specified id */ |
93 | queue_t *queueptr(int queueid); | 93 | struct snd_seq_queue *queueptr(int queueid); |
94 | /* unlock */ | 94 | /* unlock */ |
95 | #define queuefree(q) snd_use_lock_free(&(q)->use_lock) | 95 | #define queuefree(q) snd_use_lock_free(&(q)->use_lock) |
96 | 96 | ||
97 | /* return the (first) queue matching with the specified name */ | 97 | /* return the (first) queue matching with the specified name */ |
98 | queue_t *snd_seq_queue_find_name(char *name); | 98 | struct snd_seq_queue *snd_seq_queue_find_name(char *name); |
99 | 99 | ||
100 | /* check single queue and dispatch events */ | 100 | /* check single queue and dispatch events */ |
101 | void snd_seq_check_queue(queue_t *q, int atomic, int hop); | 101 | void snd_seq_check_queue(struct snd_seq_queue *q, int atomic, int hop); |
102 | 102 | ||
103 | /* access to queue's parameters */ | 103 | /* access to queue's parameters */ |
104 | int snd_seq_queue_check_access(int queueid, int client); | 104 | int snd_seq_queue_check_access(int queueid, int client); |
105 | int snd_seq_queue_timer_set_tempo(int queueid, int client, snd_seq_queue_tempo_t *info); | 105 | int snd_seq_queue_timer_set_tempo(int queueid, int client, struct snd_seq_queue_tempo *info); |
106 | int snd_seq_queue_set_owner(int queueid, int client, int locked); | 106 | int snd_seq_queue_set_owner(int queueid, int client, int locked); |
107 | int snd_seq_queue_set_locked(int queueid, int client, int locked); | 107 | int snd_seq_queue_set_locked(int queueid, int client, int locked); |
108 | int snd_seq_queue_timer_open(int queueid); | 108 | int snd_seq_queue_timer_open(int queueid); |
@@ -110,7 +110,7 @@ int snd_seq_queue_timer_close(int queueid); | |||
110 | int snd_seq_queue_use(int queueid, int client, int use); | 110 | int snd_seq_queue_use(int queueid, int client, int use); |
111 | int snd_seq_queue_is_used(int queueid, int client); | 111 | int snd_seq_queue_is_used(int queueid, int client); |
112 | 112 | ||
113 | int snd_seq_control_queue(snd_seq_event_t *ev, int atomic, int hop); | 113 | int snd_seq_control_queue(struct snd_seq_event *ev, int atomic, int hop); |
114 | 114 | ||
115 | /* | 115 | /* |
116 | * 64bit division - for sync stuff.. | 116 | * 64bit division - for sync stuff.. |
diff --git a/sound/core/seq/seq_system.c b/sound/core/seq/seq_system.c index 0d9eff85ab88..86b1cba33c08 100644 --- a/sound/core/seq/seq_system.c +++ b/sound/core/seq/seq_system.c | |||
@@ -66,12 +66,12 @@ static int announce_port = -1; | |||
66 | 66 | ||
67 | 67 | ||
68 | /* fill standard header data, source port & channel are filled in */ | 68 | /* fill standard header data, source port & channel are filled in */ |
69 | static int setheader(snd_seq_event_t * ev, int client, int port) | 69 | static int setheader(struct snd_seq_event * ev, int client, int port) |
70 | { | 70 | { |
71 | if (announce_port < 0) | 71 | if (announce_port < 0) |
72 | return -ENODEV; | 72 | return -ENODEV; |
73 | 73 | ||
74 | memset(ev, 0, sizeof(snd_seq_event_t)); | 74 | memset(ev, 0, sizeof(struct snd_seq_event)); |
75 | 75 | ||
76 | ev->flags &= ~SNDRV_SEQ_EVENT_LENGTH_MASK; | 76 | ev->flags &= ~SNDRV_SEQ_EVENT_LENGTH_MASK; |
77 | ev->flags |= SNDRV_SEQ_EVENT_LENGTH_FIXED; | 77 | ev->flags |= SNDRV_SEQ_EVENT_LENGTH_FIXED; |
@@ -92,7 +92,7 @@ static int setheader(snd_seq_event_t * ev, int client, int port) | |||
92 | /* entry points for broadcasting system events */ | 92 | /* entry points for broadcasting system events */ |
93 | void snd_seq_system_broadcast(int client, int port, int type) | 93 | void snd_seq_system_broadcast(int client, int port, int type) |
94 | { | 94 | { |
95 | snd_seq_event_t ev; | 95 | struct snd_seq_event ev; |
96 | 96 | ||
97 | if (setheader(&ev, client, port) < 0) | 97 | if (setheader(&ev, client, port) < 0) |
98 | return; | 98 | return; |
@@ -101,7 +101,7 @@ void snd_seq_system_broadcast(int client, int port, int type) | |||
101 | } | 101 | } |
102 | 102 | ||
103 | /* entry points for broadcasting system events */ | 103 | /* entry points for broadcasting system events */ |
104 | int snd_seq_system_notify(int client, int port, snd_seq_event_t *ev) | 104 | int snd_seq_system_notify(int client, int port, struct snd_seq_event *ev) |
105 | { | 105 | { |
106 | ev->flags = SNDRV_SEQ_EVENT_LENGTH_FIXED; | 106 | ev->flags = SNDRV_SEQ_EVENT_LENGTH_FIXED; |
107 | ev->source.client = sysclient; | 107 | ev->source.client = sysclient; |
@@ -112,7 +112,7 @@ int snd_seq_system_notify(int client, int port, snd_seq_event_t *ev) | |||
112 | } | 112 | } |
113 | 113 | ||
114 | /* call-back handler for timer events */ | 114 | /* call-back handler for timer events */ |
115 | static int event_input_timer(snd_seq_event_t * ev, int direct, void *private_data, int atomic, int hop) | 115 | static int event_input_timer(struct snd_seq_event * ev, int direct, void *private_data, int atomic, int hop) |
116 | { | 116 | { |
117 | return snd_seq_control_queue(ev, atomic, hop); | 117 | return snd_seq_control_queue(ev, atomic, hop); |
118 | } | 118 | } |
@@ -121,10 +121,10 @@ static int event_input_timer(snd_seq_event_t * ev, int direct, void *private_dat | |||
121 | int __init snd_seq_system_client_init(void) | 121 | int __init snd_seq_system_client_init(void) |
122 | { | 122 | { |
123 | 123 | ||
124 | snd_seq_client_callback_t callbacks; | 124 | struct snd_seq_client_callback callbacks; |
125 | snd_seq_port_callback_t pcallbacks; | 125 | struct snd_seq_port_callback pcallbacks; |
126 | snd_seq_client_info_t *inf; | 126 | struct snd_seq_client_info *inf; |
127 | snd_seq_port_info_t *port; | 127 | struct snd_seq_port_info *port; |
128 | 128 | ||
129 | inf = kzalloc(sizeof(*inf), GFP_KERNEL); | 129 | inf = kzalloc(sizeof(*inf), GFP_KERNEL); |
130 | port = kzalloc(sizeof(*port), GFP_KERNEL); | 130 | port = kzalloc(sizeof(*port), GFP_KERNEL); |
diff --git a/sound/core/seq/seq_system.h b/sound/core/seq/seq_system.h index 900007255bb4..cf2cfa23430e 100644 --- a/sound/core/seq/seq_system.h +++ b/sound/core/seq/seq_system.h | |||
@@ -34,7 +34,7 @@ void snd_seq_system_broadcast(int client, int port, int type); | |||
34 | #define snd_seq_system_client_ev_port_exit(client, port) snd_seq_system_broadcast(client, port, SNDRV_SEQ_EVENT_PORT_EXIT) | 34 | #define snd_seq_system_client_ev_port_exit(client, port) snd_seq_system_broadcast(client, port, SNDRV_SEQ_EVENT_PORT_EXIT) |
35 | #define snd_seq_system_client_ev_port_change(client, port) snd_seq_system_broadcast(client, port, SNDRV_SEQ_EVENT_PORT_CHANGE) | 35 | #define snd_seq_system_client_ev_port_change(client, port) snd_seq_system_broadcast(client, port, SNDRV_SEQ_EVENT_PORT_CHANGE) |
36 | 36 | ||
37 | int snd_seq_system_notify(int client, int port, snd_seq_event_t *ev); | 37 | int snd_seq_system_notify(int client, int port, struct snd_seq_event *ev); |
38 | 38 | ||
39 | /* register our internal client */ | 39 | /* register our internal client */ |
40 | int snd_seq_system_client_init(void); | 40 | int snd_seq_system_client_init(void); |
diff --git a/sound/core/seq/seq_timer.c b/sound/core/seq/seq_timer.c index 65b64a7c456d..a1d8bfd60ae9 100644 --- a/sound/core/seq/seq_timer.c +++ b/sound/core/seq/seq_timer.c | |||
@@ -41,7 +41,7 @@ extern int seq_default_timer_resolution; | |||
41 | 41 | ||
42 | #define SKEW_BASE 0x10000 /* 16bit shift */ | 42 | #define SKEW_BASE 0x10000 /* 16bit shift */ |
43 | 43 | ||
44 | static void snd_seq_timer_set_tick_resolution(seq_timer_tick_t *tick, | 44 | static void snd_seq_timer_set_tick_resolution(struct snd_seq_timer_tick *tick, |
45 | int tempo, int ppq) | 45 | int tempo, int ppq) |
46 | { | 46 | { |
47 | if (tempo < 1000000) | 47 | if (tempo < 1000000) |
@@ -60,9 +60,9 @@ static void snd_seq_timer_set_tick_resolution(seq_timer_tick_t *tick, | |||
60 | } | 60 | } |
61 | 61 | ||
62 | /* create new timer (constructor) */ | 62 | /* create new timer (constructor) */ |
63 | seq_timer_t *snd_seq_timer_new(void) | 63 | struct snd_seq_timer *snd_seq_timer_new(void) |
64 | { | 64 | { |
65 | seq_timer_t *tmr; | 65 | struct snd_seq_timer *tmr; |
66 | 66 | ||
67 | tmr = kzalloc(sizeof(*tmr), GFP_KERNEL); | 67 | tmr = kzalloc(sizeof(*tmr), GFP_KERNEL); |
68 | if (tmr == NULL) { | 68 | if (tmr == NULL) { |
@@ -81,9 +81,9 @@ seq_timer_t *snd_seq_timer_new(void) | |||
81 | } | 81 | } |
82 | 82 | ||
83 | /* delete timer (destructor) */ | 83 | /* delete timer (destructor) */ |
84 | void snd_seq_timer_delete(seq_timer_t **tmr) | 84 | void snd_seq_timer_delete(struct snd_seq_timer **tmr) |
85 | { | 85 | { |
86 | seq_timer_t *t = *tmr; | 86 | struct snd_seq_timer *t = *tmr; |
87 | *tmr = NULL; | 87 | *tmr = NULL; |
88 | 88 | ||
89 | if (t == NULL) { | 89 | if (t == NULL) { |
@@ -99,7 +99,7 @@ void snd_seq_timer_delete(seq_timer_t **tmr) | |||
99 | kfree(t); | 99 | kfree(t); |
100 | } | 100 | } |
101 | 101 | ||
102 | void snd_seq_timer_defaults(seq_timer_t * tmr) | 102 | void snd_seq_timer_defaults(struct snd_seq_timer * tmr) |
103 | { | 103 | { |
104 | /* setup defaults */ | 104 | /* setup defaults */ |
105 | tmr->ppq = 96; /* 96 PPQ */ | 105 | tmr->ppq = 96; /* 96 PPQ */ |
@@ -118,7 +118,7 @@ void snd_seq_timer_defaults(seq_timer_t * tmr) | |||
118 | tmr->skew = tmr->skew_base = SKEW_BASE; | 118 | tmr->skew = tmr->skew_base = SKEW_BASE; |
119 | } | 119 | } |
120 | 120 | ||
121 | void snd_seq_timer_reset(seq_timer_t * tmr) | 121 | void snd_seq_timer_reset(struct snd_seq_timer * tmr) |
122 | { | 122 | { |
123 | unsigned long flags; | 123 | unsigned long flags; |
124 | 124 | ||
@@ -136,13 +136,13 @@ void snd_seq_timer_reset(seq_timer_t * tmr) | |||
136 | 136 | ||
137 | 137 | ||
138 | /* called by timer interrupt routine. the period time since previous invocation is passed */ | 138 | /* called by timer interrupt routine. the period time since previous invocation is passed */ |
139 | static void snd_seq_timer_interrupt(snd_timer_instance_t *timeri, | 139 | static void snd_seq_timer_interrupt(struct snd_timer_instance *timeri, |
140 | unsigned long resolution, | 140 | unsigned long resolution, |
141 | unsigned long ticks) | 141 | unsigned long ticks) |
142 | { | 142 | { |
143 | unsigned long flags; | 143 | unsigned long flags; |
144 | queue_t *q = (queue_t *)timeri->callback_data; | 144 | struct snd_seq_queue *q = timeri->callback_data; |
145 | seq_timer_t *tmr; | 145 | struct snd_seq_timer *tmr; |
146 | 146 | ||
147 | if (q == NULL) | 147 | if (q == NULL) |
148 | return; | 148 | return; |
@@ -177,7 +177,7 @@ static void snd_seq_timer_interrupt(snd_timer_instance_t *timeri, | |||
177 | } | 177 | } |
178 | 178 | ||
179 | /* set current tempo */ | 179 | /* set current tempo */ |
180 | int snd_seq_timer_set_tempo(seq_timer_t * tmr, int tempo) | 180 | int snd_seq_timer_set_tempo(struct snd_seq_timer * tmr, int tempo) |
181 | { | 181 | { |
182 | unsigned long flags; | 182 | unsigned long flags; |
183 | 183 | ||
@@ -194,7 +194,7 @@ int snd_seq_timer_set_tempo(seq_timer_t * tmr, int tempo) | |||
194 | } | 194 | } |
195 | 195 | ||
196 | /* set current ppq */ | 196 | /* set current ppq */ |
197 | int snd_seq_timer_set_ppq(seq_timer_t * tmr, int ppq) | 197 | int snd_seq_timer_set_ppq(struct snd_seq_timer * tmr, int ppq) |
198 | { | 198 | { |
199 | unsigned long flags; | 199 | unsigned long flags; |
200 | 200 | ||
@@ -217,7 +217,8 @@ int snd_seq_timer_set_ppq(seq_timer_t * tmr, int ppq) | |||
217 | } | 217 | } |
218 | 218 | ||
219 | /* set current tick position */ | 219 | /* set current tick position */ |
220 | int snd_seq_timer_set_position_tick(seq_timer_t *tmr, snd_seq_tick_time_t position) | 220 | int snd_seq_timer_set_position_tick(struct snd_seq_timer *tmr, |
221 | snd_seq_tick_time_t position) | ||
221 | { | 222 | { |
222 | unsigned long flags; | 223 | unsigned long flags; |
223 | 224 | ||
@@ -231,7 +232,8 @@ int snd_seq_timer_set_position_tick(seq_timer_t *tmr, snd_seq_tick_time_t positi | |||
231 | } | 232 | } |
232 | 233 | ||
233 | /* set current real-time position */ | 234 | /* set current real-time position */ |
234 | int snd_seq_timer_set_position_time(seq_timer_t *tmr, snd_seq_real_time_t position) | 235 | int snd_seq_timer_set_position_time(struct snd_seq_timer *tmr, |
236 | snd_seq_real_time_t position) | ||
235 | { | 237 | { |
236 | unsigned long flags; | 238 | unsigned long flags; |
237 | 239 | ||
@@ -245,7 +247,8 @@ int snd_seq_timer_set_position_time(seq_timer_t *tmr, snd_seq_real_time_t positi | |||
245 | } | 247 | } |
246 | 248 | ||
247 | /* set timer skew */ | 249 | /* set timer skew */ |
248 | int snd_seq_timer_set_skew(seq_timer_t *tmr, unsigned int skew, unsigned int base) | 250 | int snd_seq_timer_set_skew(struct snd_seq_timer *tmr, unsigned int skew, |
251 | unsigned int base) | ||
249 | { | 252 | { |
250 | unsigned long flags; | 253 | unsigned long flags; |
251 | 254 | ||
@@ -262,10 +265,10 @@ int snd_seq_timer_set_skew(seq_timer_t *tmr, unsigned int skew, unsigned int bas | |||
262 | return 0; | 265 | return 0; |
263 | } | 266 | } |
264 | 267 | ||
265 | int snd_seq_timer_open(queue_t *q) | 268 | int snd_seq_timer_open(struct snd_seq_queue *q) |
266 | { | 269 | { |
267 | snd_timer_instance_t *t; | 270 | struct snd_timer_instance *t; |
268 | seq_timer_t *tmr; | 271 | struct snd_seq_timer *tmr; |
269 | char str[32]; | 272 | char str[32]; |
270 | int err; | 273 | int err; |
271 | 274 | ||
@@ -282,7 +285,7 @@ int snd_seq_timer_open(queue_t *q) | |||
282 | if (err < 0 && tmr->alsa_id.dev_class != SNDRV_TIMER_CLASS_SLAVE) { | 285 | if (err < 0 && tmr->alsa_id.dev_class != SNDRV_TIMER_CLASS_SLAVE) { |
283 | if (tmr->alsa_id.dev_class != SNDRV_TIMER_CLASS_GLOBAL || | 286 | if (tmr->alsa_id.dev_class != SNDRV_TIMER_CLASS_GLOBAL || |
284 | tmr->alsa_id.device != SNDRV_TIMER_GLOBAL_SYSTEM) { | 287 | tmr->alsa_id.device != SNDRV_TIMER_GLOBAL_SYSTEM) { |
285 | snd_timer_id_t tid; | 288 | struct snd_timer_id tid; |
286 | memset(&tid, 0, sizeof(tid)); | 289 | memset(&tid, 0, sizeof(tid)); |
287 | tid.dev_class = SNDRV_TIMER_CLASS_GLOBAL; | 290 | tid.dev_class = SNDRV_TIMER_CLASS_GLOBAL; |
288 | tid.dev_sclass = SNDRV_TIMER_SCLASS_SEQUENCER; | 291 | tid.dev_sclass = SNDRV_TIMER_SCLASS_SEQUENCER; |
@@ -302,9 +305,9 @@ int snd_seq_timer_open(queue_t *q) | |||
302 | return 0; | 305 | return 0; |
303 | } | 306 | } |
304 | 307 | ||
305 | int snd_seq_timer_close(queue_t *q) | 308 | int snd_seq_timer_close(struct snd_seq_queue *q) |
306 | { | 309 | { |
307 | seq_timer_t *tmr; | 310 | struct snd_seq_timer *tmr; |
308 | 311 | ||
309 | tmr = q->timer; | 312 | tmr = q->timer; |
310 | snd_assert(tmr != NULL, return -EINVAL); | 313 | snd_assert(tmr != NULL, return -EINVAL); |
@@ -316,7 +319,7 @@ int snd_seq_timer_close(queue_t *q) | |||
316 | return 0; | 319 | return 0; |
317 | } | 320 | } |
318 | 321 | ||
319 | int snd_seq_timer_stop(seq_timer_t * tmr) | 322 | int snd_seq_timer_stop(struct snd_seq_timer * tmr) |
320 | { | 323 | { |
321 | if (! tmr->timeri) | 324 | if (! tmr->timeri) |
322 | return -EINVAL; | 325 | return -EINVAL; |
@@ -327,9 +330,9 @@ int snd_seq_timer_stop(seq_timer_t * tmr) | |||
327 | return 0; | 330 | return 0; |
328 | } | 331 | } |
329 | 332 | ||
330 | static int initialize_timer(seq_timer_t *tmr) | 333 | static int initialize_timer(struct snd_seq_timer *tmr) |
331 | { | 334 | { |
332 | snd_timer_t *t; | 335 | struct snd_timer *t; |
333 | unsigned long freq; | 336 | unsigned long freq; |
334 | 337 | ||
335 | t = tmr->timeri->timer; | 338 | t = tmr->timeri->timer; |
@@ -358,7 +361,7 @@ static int initialize_timer(seq_timer_t *tmr) | |||
358 | return 0; | 361 | return 0; |
359 | } | 362 | } |
360 | 363 | ||
361 | int snd_seq_timer_start(seq_timer_t * tmr) | 364 | int snd_seq_timer_start(struct snd_seq_timer * tmr) |
362 | { | 365 | { |
363 | if (! tmr->timeri) | 366 | if (! tmr->timeri) |
364 | return -EINVAL; | 367 | return -EINVAL; |
@@ -373,7 +376,7 @@ int snd_seq_timer_start(seq_timer_t * tmr) | |||
373 | return 0; | 376 | return 0; |
374 | } | 377 | } |
375 | 378 | ||
376 | int snd_seq_timer_continue(seq_timer_t * tmr) | 379 | int snd_seq_timer_continue(struct snd_seq_timer * tmr) |
377 | { | 380 | { |
378 | if (! tmr->timeri) | 381 | if (! tmr->timeri) |
379 | return -EINVAL; | 382 | return -EINVAL; |
@@ -391,7 +394,7 @@ int snd_seq_timer_continue(seq_timer_t * tmr) | |||
391 | } | 394 | } |
392 | 395 | ||
393 | /* return current 'real' time. use timeofday() to get better granularity. */ | 396 | /* return current 'real' time. use timeofday() to get better granularity. */ |
394 | snd_seq_real_time_t snd_seq_timer_get_cur_time(seq_timer_t *tmr) | 397 | snd_seq_real_time_t snd_seq_timer_get_cur_time(struct snd_seq_timer *tmr) |
395 | { | 398 | { |
396 | snd_seq_real_time_t cur_time; | 399 | snd_seq_real_time_t cur_time; |
397 | 400 | ||
@@ -416,19 +419,20 @@ snd_seq_real_time_t snd_seq_timer_get_cur_time(seq_timer_t *tmr) | |||
416 | 419 | ||
417 | /* TODO: use interpolation on tick queue (will only be useful for very | 420 | /* TODO: use interpolation on tick queue (will only be useful for very |
418 | high PPQ values) */ | 421 | high PPQ values) */ |
419 | snd_seq_tick_time_t snd_seq_timer_get_cur_tick(seq_timer_t *tmr) | 422 | snd_seq_tick_time_t snd_seq_timer_get_cur_tick(struct snd_seq_timer *tmr) |
420 | { | 423 | { |
421 | return tmr->tick.cur_tick; | 424 | return tmr->tick.cur_tick; |
422 | } | 425 | } |
423 | 426 | ||
424 | 427 | ||
425 | /* exported to seq_info.c */ | 428 | /* exported to seq_info.c */ |
426 | void snd_seq_info_timer_read(snd_info_entry_t *entry, snd_info_buffer_t * buffer) | 429 | void snd_seq_info_timer_read(struct snd_info_entry *entry, |
430 | struct snd_info_buffer *buffer) | ||
427 | { | 431 | { |
428 | int idx; | 432 | int idx; |
429 | queue_t *q; | 433 | struct snd_seq_queue *q; |
430 | seq_timer_t *tmr; | 434 | struct snd_seq_timer *tmr; |
431 | snd_timer_instance_t *ti; | 435 | struct snd_timer_instance *ti; |
432 | unsigned long resolution; | 436 | unsigned long resolution; |
433 | 437 | ||
434 | for (idx = 0; idx < SNDRV_SEQ_MAX_QUEUES; idx++) { | 438 | for (idx = 0; idx < SNDRV_SEQ_MAX_QUEUES; idx++) { |
diff --git a/sound/core/seq/seq_timer.h b/sound/core/seq/seq_timer.h index 287ed68591de..e9ee1543c924 100644 --- a/sound/core/seq/seq_timer.h +++ b/sound/core/seq/seq_timer.h | |||
@@ -24,13 +24,13 @@ | |||
24 | #include <sound/timer.h> | 24 | #include <sound/timer.h> |
25 | #include <sound/seq_kernel.h> | 25 | #include <sound/seq_kernel.h> |
26 | 26 | ||
27 | typedef struct { | 27 | struct snd_seq_timer_tick { |
28 | snd_seq_tick_time_t cur_tick; /* current tick */ | 28 | snd_seq_tick_time_t cur_tick; /* current tick */ |
29 | unsigned long resolution; /* time per tick in nsec */ | 29 | unsigned long resolution; /* time per tick in nsec */ |
30 | unsigned long fraction; /* current time per tick in nsec */ | 30 | unsigned long fraction; /* current time per tick in nsec */ |
31 | } seq_timer_tick_t; | 31 | }; |
32 | 32 | ||
33 | typedef struct { | 33 | struct snd_seq_timer { |
34 | /* ... tempo / offset / running state */ | 34 | /* ... tempo / offset / running state */ |
35 | 35 | ||
36 | unsigned int running:1, /* running state of queue */ | 36 | unsigned int running:1, /* running state of queue */ |
@@ -40,12 +40,12 @@ typedef struct { | |||
40 | int ppq; /* time resolution, ticks/quarter */ | 40 | int ppq; /* time resolution, ticks/quarter */ |
41 | 41 | ||
42 | snd_seq_real_time_t cur_time; /* current time */ | 42 | snd_seq_real_time_t cur_time; /* current time */ |
43 | seq_timer_tick_t tick; /* current tick */ | 43 | struct snd_seq_timer_tick tick; /* current tick */ |
44 | int tick_updated; | 44 | int tick_updated; |
45 | 45 | ||
46 | int type; /* timer type */ | 46 | int type; /* timer type */ |
47 | snd_timer_id_t alsa_id; /* ALSA's timer ID */ | 47 | struct snd_timer_id alsa_id; /* ALSA's timer ID */ |
48 | snd_timer_instance_t *timeri; /* timer instance */ | 48 | struct snd_timer_instance *timeri; /* timer instance */ |
49 | unsigned int ticks; | 49 | unsigned int ticks; |
50 | unsigned long preferred_resolution; /* timer resolution, ticks/sec */ | 50 | unsigned long preferred_resolution; /* timer resolution, ticks/sec */ |
51 | 51 | ||
@@ -55,17 +55,18 @@ typedef struct { | |||
55 | struct timeval last_update; /* time of last clock update, used for interpolation */ | 55 | struct timeval last_update; /* time of last clock update, used for interpolation */ |
56 | 56 | ||
57 | spinlock_t lock; | 57 | spinlock_t lock; |
58 | } seq_timer_t; | 58 | }; |
59 | 59 | ||
60 | 60 | ||
61 | /* create new timer (constructor) */ | 61 | /* create new timer (constructor) */ |
62 | extern seq_timer_t *snd_seq_timer_new(void); | 62 | struct snd_seq_timer *snd_seq_timer_new(void); |
63 | 63 | ||
64 | /* delete timer (destructor) */ | 64 | /* delete timer (destructor) */ |
65 | extern void snd_seq_timer_delete(seq_timer_t **tmr); | 65 | void snd_seq_timer_delete(struct snd_seq_timer **tmr); |
66 | 66 | ||
67 | /* */ | 67 | /* */ |
68 | static inline void snd_seq_timer_update_tick(seq_timer_tick_t *tick, unsigned long resolution) | 68 | static inline void snd_seq_timer_update_tick(struct snd_seq_timer_tick *tick, |
69 | unsigned long resolution) | ||
69 | { | 70 | { |
70 | if (tick->resolution > 0) { | 71 | if (tick->resolution > 0) { |
71 | tick->fraction += resolution; | 72 | tick->fraction += resolution; |
@@ -119,21 +120,22 @@ static inline void snd_seq_inc_time_nsec(snd_seq_real_time_t *tm, unsigned long | |||
119 | } | 120 | } |
120 | 121 | ||
121 | /* called by timer isr */ | 122 | /* called by timer isr */ |
122 | int snd_seq_timer_open(queue_t *q); | 123 | struct snd_seq_queue; |
123 | int snd_seq_timer_close(queue_t *q); | 124 | int snd_seq_timer_open(struct snd_seq_queue *q); |
124 | int snd_seq_timer_midi_open(queue_t *q); | 125 | int snd_seq_timer_close(struct snd_seq_queue *q); |
125 | int snd_seq_timer_midi_close(queue_t *q); | 126 | int snd_seq_timer_midi_open(struct snd_seq_queue *q); |
126 | void snd_seq_timer_defaults(seq_timer_t *tmr); | 127 | int snd_seq_timer_midi_close(struct snd_seq_queue *q); |
127 | void snd_seq_timer_reset(seq_timer_t *tmr); | 128 | void snd_seq_timer_defaults(struct snd_seq_timer *tmr); |
128 | int snd_seq_timer_stop(seq_timer_t *tmr); | 129 | void snd_seq_timer_reset(struct snd_seq_timer *tmr); |
129 | int snd_seq_timer_start(seq_timer_t *tmr); | 130 | int snd_seq_timer_stop(struct snd_seq_timer *tmr); |
130 | int snd_seq_timer_continue(seq_timer_t *tmr); | 131 | int snd_seq_timer_start(struct snd_seq_timer *tmr); |
131 | int snd_seq_timer_set_tempo(seq_timer_t *tmr, int tempo); | 132 | int snd_seq_timer_continue(struct snd_seq_timer *tmr); |
132 | int snd_seq_timer_set_ppq(seq_timer_t *tmr, int ppq); | 133 | int snd_seq_timer_set_tempo(struct snd_seq_timer *tmr, int tempo); |
133 | int snd_seq_timer_set_position_tick(seq_timer_t *tmr, snd_seq_tick_time_t position); | 134 | int snd_seq_timer_set_ppq(struct snd_seq_timer *tmr, int ppq); |
134 | int snd_seq_timer_set_position_time(seq_timer_t *tmr, snd_seq_real_time_t position); | 135 | int snd_seq_timer_set_position_tick(struct snd_seq_timer *tmr, snd_seq_tick_time_t position); |
135 | int snd_seq_timer_set_skew(seq_timer_t *tmr, unsigned int skew, unsigned int base); | 136 | int snd_seq_timer_set_position_time(struct snd_seq_timer *tmr, snd_seq_real_time_t position); |
136 | snd_seq_real_time_t snd_seq_timer_get_cur_time(seq_timer_t *tmr); | 137 | int snd_seq_timer_set_skew(struct snd_seq_timer *tmr, unsigned int skew, unsigned int base); |
137 | snd_seq_tick_time_t snd_seq_timer_get_cur_tick(seq_timer_t *tmr); | 138 | snd_seq_real_time_t snd_seq_timer_get_cur_time(struct snd_seq_timer *tmr); |
139 | snd_seq_tick_time_t snd_seq_timer_get_cur_tick(struct snd_seq_timer *tmr); | ||
138 | 140 | ||
139 | #endif | 141 | #endif |
diff --git a/sound/core/seq/seq_virmidi.c b/sound/core/seq/seq_virmidi.c index e4f512aa7426..ea2113968fe7 100644 --- a/sound/core/seq/seq_virmidi.c +++ b/sound/core/seq/seq_virmidi.c | |||
@@ -56,7 +56,8 @@ MODULE_LICENSE("GPL"); | |||
56 | /* | 56 | /* |
57 | * initialize an event record | 57 | * initialize an event record |
58 | */ | 58 | */ |
59 | static void snd_virmidi_init_event(snd_virmidi_t *vmidi, snd_seq_event_t *ev) | 59 | static void snd_virmidi_init_event(struct snd_virmidi *vmidi, |
60 | struct snd_seq_event *ev) | ||
60 | { | 61 | { |
61 | memset(ev, 0, sizeof(*ev)); | 62 | memset(ev, 0, sizeof(*ev)); |
62 | ev->source.port = vmidi->port; | 63 | ev->source.port = vmidi->port; |
@@ -76,16 +77,17 @@ static void snd_virmidi_init_event(snd_virmidi_t *vmidi, snd_seq_event_t *ev) | |||
76 | /* | 77 | /* |
77 | * decode input event and put to read buffer of each opened file | 78 | * decode input event and put to read buffer of each opened file |
78 | */ | 79 | */ |
79 | static int snd_virmidi_dev_receive_event(snd_virmidi_dev_t *rdev, snd_seq_event_t *ev) | 80 | static int snd_virmidi_dev_receive_event(struct snd_virmidi_dev *rdev, |
81 | struct snd_seq_event *ev) | ||
80 | { | 82 | { |
81 | snd_virmidi_t *vmidi; | 83 | struct snd_virmidi *vmidi; |
82 | struct list_head *list; | 84 | struct list_head *list; |
83 | unsigned char msg[4]; | 85 | unsigned char msg[4]; |
84 | int len; | 86 | int len; |
85 | 87 | ||
86 | read_lock(&rdev->filelist_lock); | 88 | read_lock(&rdev->filelist_lock); |
87 | list_for_each(list, &rdev->filelist) { | 89 | list_for_each(list, &rdev->filelist) { |
88 | vmidi = list_entry(list, snd_virmidi_t, list); | 90 | vmidi = list_entry(list, struct snd_virmidi, list); |
89 | if (!vmidi->trigger) | 91 | if (!vmidi->trigger) |
90 | continue; | 92 | continue; |
91 | if (ev->type == SNDRV_SEQ_EVENT_SYSEX) { | 93 | if (ev->type == SNDRV_SEQ_EVENT_SYSEX) { |
@@ -111,9 +113,9 @@ static int snd_virmidi_dev_receive_event(snd_virmidi_dev_t *rdev, snd_seq_event_ | |||
111 | * SNDRV_VIRMIDI_SEQ_ATTACH. | 113 | * SNDRV_VIRMIDI_SEQ_ATTACH. |
112 | */ | 114 | */ |
113 | #if 0 | 115 | #if 0 |
114 | int snd_virmidi_receive(snd_rawmidi_t *rmidi, snd_seq_event_t *ev) | 116 | int snd_virmidi_receive(struct snd_rawmidi *rmidi, struct snd_seq_event *ev) |
115 | { | 117 | { |
116 | snd_virmidi_dev_t *rdev; | 118 | struct snd_virmidi_dev *rdev; |
117 | 119 | ||
118 | rdev = rmidi->private_data; | 120 | rdev = rmidi->private_data; |
119 | return snd_virmidi_dev_receive_event(rdev, ev); | 121 | return snd_virmidi_dev_receive_event(rdev, ev); |
@@ -123,10 +125,10 @@ int snd_virmidi_receive(snd_rawmidi_t *rmidi, snd_seq_event_t *ev) | |||
123 | /* | 125 | /* |
124 | * event handler of virmidi port | 126 | * event handler of virmidi port |
125 | */ | 127 | */ |
126 | static int snd_virmidi_event_input(snd_seq_event_t *ev, int direct, | 128 | static int snd_virmidi_event_input(struct snd_seq_event *ev, int direct, |
127 | void *private_data, int atomic, int hop) | 129 | void *private_data, int atomic, int hop) |
128 | { | 130 | { |
129 | snd_virmidi_dev_t *rdev; | 131 | struct snd_virmidi_dev *rdev; |
130 | 132 | ||
131 | rdev = private_data; | 133 | rdev = private_data; |
132 | if (!(rdev->flags & SNDRV_VIRMIDI_USE)) | 134 | if (!(rdev->flags & SNDRV_VIRMIDI_USE)) |
@@ -137,9 +139,9 @@ static int snd_virmidi_event_input(snd_seq_event_t *ev, int direct, | |||
137 | /* | 139 | /* |
138 | * trigger rawmidi stream for input | 140 | * trigger rawmidi stream for input |
139 | */ | 141 | */ |
140 | static void snd_virmidi_input_trigger(snd_rawmidi_substream_t * substream, int up) | 142 | static void snd_virmidi_input_trigger(struct snd_rawmidi_substream *substream, int up) |
141 | { | 143 | { |
142 | snd_virmidi_t *vmidi = substream->runtime->private_data; | 144 | struct snd_virmidi *vmidi = substream->runtime->private_data; |
143 | 145 | ||
144 | if (up) { | 146 | if (up) { |
145 | vmidi->trigger = 1; | 147 | vmidi->trigger = 1; |
@@ -151,9 +153,9 @@ static void snd_virmidi_input_trigger(snd_rawmidi_substream_t * substream, int u | |||
151 | /* | 153 | /* |
152 | * trigger rawmidi stream for output | 154 | * trigger rawmidi stream for output |
153 | */ | 155 | */ |
154 | static void snd_virmidi_output_trigger(snd_rawmidi_substream_t * substream, int up) | 156 | static void snd_virmidi_output_trigger(struct snd_rawmidi_substream *substream, int up) |
155 | { | 157 | { |
156 | snd_virmidi_t *vmidi = substream->runtime->private_data; | 158 | struct snd_virmidi *vmidi = substream->runtime->private_data; |
157 | int count, res; | 159 | int count, res; |
158 | unsigned char buf[32], *pbuf; | 160 | unsigned char buf[32], *pbuf; |
159 | 161 | ||
@@ -198,11 +200,11 @@ static void snd_virmidi_output_trigger(snd_rawmidi_substream_t * substream, int | |||
198 | /* | 200 | /* |
199 | * open rawmidi handle for input | 201 | * open rawmidi handle for input |
200 | */ | 202 | */ |
201 | static int snd_virmidi_input_open(snd_rawmidi_substream_t * substream) | 203 | static int snd_virmidi_input_open(struct snd_rawmidi_substream *substream) |
202 | { | 204 | { |
203 | snd_virmidi_dev_t *rdev = substream->rmidi->private_data; | 205 | struct snd_virmidi_dev *rdev = substream->rmidi->private_data; |
204 | snd_rawmidi_runtime_t *runtime = substream->runtime; | 206 | struct snd_rawmidi_runtime *runtime = substream->runtime; |
205 | snd_virmidi_t *vmidi; | 207 | struct snd_virmidi *vmidi; |
206 | unsigned long flags; | 208 | unsigned long flags; |
207 | 209 | ||
208 | vmidi = kzalloc(sizeof(*vmidi), GFP_KERNEL); | 210 | vmidi = kzalloc(sizeof(*vmidi), GFP_KERNEL); |
@@ -227,11 +229,11 @@ static int snd_virmidi_input_open(snd_rawmidi_substream_t * substream) | |||
227 | /* | 229 | /* |
228 | * open rawmidi handle for output | 230 | * open rawmidi handle for output |
229 | */ | 231 | */ |
230 | static int snd_virmidi_output_open(snd_rawmidi_substream_t * substream) | 232 | static int snd_virmidi_output_open(struct snd_rawmidi_substream *substream) |
231 | { | 233 | { |
232 | snd_virmidi_dev_t *rdev = substream->rmidi->private_data; | 234 | struct snd_virmidi_dev *rdev = substream->rmidi->private_data; |
233 | snd_rawmidi_runtime_t *runtime = substream->runtime; | 235 | struct snd_rawmidi_runtime *runtime = substream->runtime; |
234 | snd_virmidi_t *vmidi; | 236 | struct snd_virmidi *vmidi; |
235 | 237 | ||
236 | vmidi = kzalloc(sizeof(*vmidi), GFP_KERNEL); | 238 | vmidi = kzalloc(sizeof(*vmidi), GFP_KERNEL); |
237 | if (vmidi == NULL) | 239 | if (vmidi == NULL) |
@@ -253,9 +255,9 @@ static int snd_virmidi_output_open(snd_rawmidi_substream_t * substream) | |||
253 | /* | 255 | /* |
254 | * close rawmidi handle for input | 256 | * close rawmidi handle for input |
255 | */ | 257 | */ |
256 | static int snd_virmidi_input_close(snd_rawmidi_substream_t * substream) | 258 | static int snd_virmidi_input_close(struct snd_rawmidi_substream *substream) |
257 | { | 259 | { |
258 | snd_virmidi_t *vmidi = substream->runtime->private_data; | 260 | struct snd_virmidi *vmidi = substream->runtime->private_data; |
259 | snd_midi_event_free(vmidi->parser); | 261 | snd_midi_event_free(vmidi->parser); |
260 | list_del(&vmidi->list); | 262 | list_del(&vmidi->list); |
261 | substream->runtime->private_data = NULL; | 263 | substream->runtime->private_data = NULL; |
@@ -266,9 +268,9 @@ static int snd_virmidi_input_close(snd_rawmidi_substream_t * substream) | |||
266 | /* | 268 | /* |
267 | * close rawmidi handle for output | 269 | * close rawmidi handle for output |
268 | */ | 270 | */ |
269 | static int snd_virmidi_output_close(snd_rawmidi_substream_t * substream) | 271 | static int snd_virmidi_output_close(struct snd_rawmidi_substream *substream) |
270 | { | 272 | { |
271 | snd_virmidi_t *vmidi = substream->runtime->private_data; | 273 | struct snd_virmidi *vmidi = substream->runtime->private_data; |
272 | snd_midi_event_free(vmidi->parser); | 274 | snd_midi_event_free(vmidi->parser); |
273 | substream->runtime->private_data = NULL; | 275 | substream->runtime->private_data = NULL; |
274 | kfree(vmidi); | 276 | kfree(vmidi); |
@@ -278,9 +280,10 @@ static int snd_virmidi_output_close(snd_rawmidi_substream_t * substream) | |||
278 | /* | 280 | /* |
279 | * subscribe callback - allow output to rawmidi device | 281 | * subscribe callback - allow output to rawmidi device |
280 | */ | 282 | */ |
281 | static int snd_virmidi_subscribe(void *private_data, snd_seq_port_subscribe_t *info) | 283 | static int snd_virmidi_subscribe(void *private_data, |
284 | struct snd_seq_port_subscribe *info) | ||
282 | { | 285 | { |
283 | snd_virmidi_dev_t *rdev; | 286 | struct snd_virmidi_dev *rdev; |
284 | 287 | ||
285 | rdev = private_data; | 288 | rdev = private_data; |
286 | if (!try_module_get(rdev->card->module)) | 289 | if (!try_module_get(rdev->card->module)) |
@@ -292,9 +295,10 @@ static int snd_virmidi_subscribe(void *private_data, snd_seq_port_subscribe_t *i | |||
292 | /* | 295 | /* |
293 | * unsubscribe callback - disallow output to rawmidi device | 296 | * unsubscribe callback - disallow output to rawmidi device |
294 | */ | 297 | */ |
295 | static int snd_virmidi_unsubscribe(void *private_data, snd_seq_port_subscribe_t *info) | 298 | static int snd_virmidi_unsubscribe(void *private_data, |
299 | struct snd_seq_port_subscribe *info) | ||
296 | { | 300 | { |
297 | snd_virmidi_dev_t *rdev; | 301 | struct snd_virmidi_dev *rdev; |
298 | 302 | ||
299 | rdev = private_data; | 303 | rdev = private_data; |
300 | rdev->flags &= ~SNDRV_VIRMIDI_SUBSCRIBE; | 304 | rdev->flags &= ~SNDRV_VIRMIDI_SUBSCRIBE; |
@@ -306,9 +310,10 @@ static int snd_virmidi_unsubscribe(void *private_data, snd_seq_port_subscribe_t | |||
306 | /* | 310 | /* |
307 | * use callback - allow input to rawmidi device | 311 | * use callback - allow input to rawmidi device |
308 | */ | 312 | */ |
309 | static int snd_virmidi_use(void *private_data, snd_seq_port_subscribe_t *info) | 313 | static int snd_virmidi_use(void *private_data, |
314 | struct snd_seq_port_subscribe *info) | ||
310 | { | 315 | { |
311 | snd_virmidi_dev_t *rdev; | 316 | struct snd_virmidi_dev *rdev; |
312 | 317 | ||
313 | rdev = private_data; | 318 | rdev = private_data; |
314 | if (!try_module_get(rdev->card->module)) | 319 | if (!try_module_get(rdev->card->module)) |
@@ -320,9 +325,10 @@ static int snd_virmidi_use(void *private_data, snd_seq_port_subscribe_t *info) | |||
320 | /* | 325 | /* |
321 | * unuse callback - disallow input to rawmidi device | 326 | * unuse callback - disallow input to rawmidi device |
322 | */ | 327 | */ |
323 | static int snd_virmidi_unuse(void *private_data, snd_seq_port_subscribe_t *info) | 328 | static int snd_virmidi_unuse(void *private_data, |
329 | struct snd_seq_port_subscribe *info) | ||
324 | { | 330 | { |
325 | snd_virmidi_dev_t *rdev; | 331 | struct snd_virmidi_dev *rdev; |
326 | 332 | ||
327 | rdev = private_data; | 333 | rdev = private_data; |
328 | rdev->flags &= ~SNDRV_VIRMIDI_USE; | 334 | rdev->flags &= ~SNDRV_VIRMIDI_USE; |
@@ -335,13 +341,13 @@ static int snd_virmidi_unuse(void *private_data, snd_seq_port_subscribe_t *info) | |||
335 | * Register functions | 341 | * Register functions |
336 | */ | 342 | */ |
337 | 343 | ||
338 | static snd_rawmidi_ops_t snd_virmidi_input_ops = { | 344 | static struct snd_rawmidi_ops snd_virmidi_input_ops = { |
339 | .open = snd_virmidi_input_open, | 345 | .open = snd_virmidi_input_open, |
340 | .close = snd_virmidi_input_close, | 346 | .close = snd_virmidi_input_close, |
341 | .trigger = snd_virmidi_input_trigger, | 347 | .trigger = snd_virmidi_input_trigger, |
342 | }; | 348 | }; |
343 | 349 | ||
344 | static snd_rawmidi_ops_t snd_virmidi_output_ops = { | 350 | static struct snd_rawmidi_ops snd_virmidi_output_ops = { |
345 | .open = snd_virmidi_output_open, | 351 | .open = snd_virmidi_output_open, |
346 | .close = snd_virmidi_output_close, | 352 | .close = snd_virmidi_output_close, |
347 | .trigger = snd_virmidi_output_trigger, | 353 | .trigger = snd_virmidi_output_trigger, |
@@ -350,13 +356,13 @@ static snd_rawmidi_ops_t snd_virmidi_output_ops = { | |||
350 | /* | 356 | /* |
351 | * create a sequencer client and a port | 357 | * create a sequencer client and a port |
352 | */ | 358 | */ |
353 | static int snd_virmidi_dev_attach_seq(snd_virmidi_dev_t *rdev) | 359 | static int snd_virmidi_dev_attach_seq(struct snd_virmidi_dev *rdev) |
354 | { | 360 | { |
355 | int client; | 361 | int client; |
356 | snd_seq_client_callback_t callbacks; | 362 | struct snd_seq_client_callback callbacks; |
357 | snd_seq_port_callback_t pcallbacks; | 363 | struct snd_seq_port_callback pcallbacks; |
358 | snd_seq_client_info_t *info; | 364 | struct snd_seq_client_info *info; |
359 | snd_seq_port_info_t *pinfo; | 365 | struct snd_seq_port_info *pinfo; |
360 | int err; | 366 | int err; |
361 | 367 | ||
362 | if (rdev->client >= 0) | 368 | if (rdev->client >= 0) |
@@ -426,7 +432,7 @@ static int snd_virmidi_dev_attach_seq(snd_virmidi_dev_t *rdev) | |||
426 | /* | 432 | /* |
427 | * release the sequencer client | 433 | * release the sequencer client |
428 | */ | 434 | */ |
429 | static void snd_virmidi_dev_detach_seq(snd_virmidi_dev_t *rdev) | 435 | static void snd_virmidi_dev_detach_seq(struct snd_virmidi_dev *rdev) |
430 | { | 436 | { |
431 | if (rdev->client >= 0) { | 437 | if (rdev->client >= 0) { |
432 | snd_seq_delete_kernel_client(rdev->client); | 438 | snd_seq_delete_kernel_client(rdev->client); |
@@ -437,9 +443,9 @@ static void snd_virmidi_dev_detach_seq(snd_virmidi_dev_t *rdev) | |||
437 | /* | 443 | /* |
438 | * register the device | 444 | * register the device |
439 | */ | 445 | */ |
440 | static int snd_virmidi_dev_register(snd_rawmidi_t *rmidi) | 446 | static int snd_virmidi_dev_register(struct snd_rawmidi *rmidi) |
441 | { | 447 | { |
442 | snd_virmidi_dev_t *rdev = rmidi->private_data; | 448 | struct snd_virmidi_dev *rdev = rmidi->private_data; |
443 | int err; | 449 | int err; |
444 | 450 | ||
445 | switch (rdev->seq_mode) { | 451 | switch (rdev->seq_mode) { |
@@ -464,9 +470,9 @@ static int snd_virmidi_dev_register(snd_rawmidi_t *rmidi) | |||
464 | /* | 470 | /* |
465 | * unregister the device | 471 | * unregister the device |
466 | */ | 472 | */ |
467 | static int snd_virmidi_dev_unregister(snd_rawmidi_t *rmidi) | 473 | static int snd_virmidi_dev_unregister(struct snd_rawmidi *rmidi) |
468 | { | 474 | { |
469 | snd_virmidi_dev_t *rdev = rmidi->private_data; | 475 | struct snd_virmidi_dev *rdev = rmidi->private_data; |
470 | 476 | ||
471 | if (rdev->seq_mode == SNDRV_VIRMIDI_SEQ_DISPATCH) | 477 | if (rdev->seq_mode == SNDRV_VIRMIDI_SEQ_DISPATCH) |
472 | snd_virmidi_dev_detach_seq(rdev); | 478 | snd_virmidi_dev_detach_seq(rdev); |
@@ -476,7 +482,7 @@ static int snd_virmidi_dev_unregister(snd_rawmidi_t *rmidi) | |||
476 | /* | 482 | /* |
477 | * | 483 | * |
478 | */ | 484 | */ |
479 | static snd_rawmidi_global_ops_t snd_virmidi_global_ops = { | 485 | static struct snd_rawmidi_global_ops snd_virmidi_global_ops = { |
480 | .dev_register = snd_virmidi_dev_register, | 486 | .dev_register = snd_virmidi_dev_register, |
481 | .dev_unregister = snd_virmidi_dev_unregister, | 487 | .dev_unregister = snd_virmidi_dev_unregister, |
482 | }; | 488 | }; |
@@ -484,9 +490,9 @@ static snd_rawmidi_global_ops_t snd_virmidi_global_ops = { | |||
484 | /* | 490 | /* |
485 | * free device | 491 | * free device |
486 | */ | 492 | */ |
487 | static void snd_virmidi_free(snd_rawmidi_t *rmidi) | 493 | static void snd_virmidi_free(struct snd_rawmidi *rmidi) |
488 | { | 494 | { |
489 | snd_virmidi_dev_t *rdev = rmidi->private_data; | 495 | struct snd_virmidi_dev *rdev = rmidi->private_data; |
490 | kfree(rdev); | 496 | kfree(rdev); |
491 | } | 497 | } |
492 | 498 | ||
@@ -495,10 +501,10 @@ static void snd_virmidi_free(snd_rawmidi_t *rmidi) | |||
495 | * | 501 | * |
496 | */ | 502 | */ |
497 | /* exported */ | 503 | /* exported */ |
498 | int snd_virmidi_new(snd_card_t *card, int device, snd_rawmidi_t **rrmidi) | 504 | int snd_virmidi_new(struct snd_card *card, int device, struct snd_rawmidi **rrmidi) |
499 | { | 505 | { |
500 | snd_rawmidi_t *rmidi; | 506 | struct snd_rawmidi *rmidi; |
501 | snd_virmidi_dev_t *rdev; | 507 | struct snd_virmidi_dev *rdev; |
502 | int err; | 508 | int err; |
503 | 509 | ||
504 | *rrmidi = NULL; | 510 | *rrmidi = NULL; |