Chargement...
 
[Voir/Cacher menus de gauche]
[Voir/Cacher menus de droite]


L'un des problèmes du MIDI sous Linux c'est le fait que deux normes existent :
Les deux normes sont à peu près également utilisées, ce qui vous oblige parfois à créer un pont entre les deux pour connecter un matériel à un logiciel, ou un logiciel à un autre (avec par exemple a2jmidid).

Pourquoi avoir créé une implémentation MIDI par JACK alors qu'il y en avait déjà par ALSA ?

JACK MIDI a été créé entre autre parce que l'implémentation d'ALSA n'est plus développée depuis environ 10 ans, et c'est pour cela qu'on appelle ALSA parfois legacy. Du point de vue des développeurs de JACK, un défaut d'ALSA réside dans le fait qu'il est implémenté dans l'espace kernel. En effet, vous l'avez remarqué, la couche ALSA vient sous formes de modules du kernel. Mais il y a surement d'autres raisons.
L'implémentation d'un transport de données autres qu'audio dans JACK est une alternative à ALSA qui a certains avantages et des inconvénients (du moins pour l'instant).

Avantages de JACK MIDI

  • Une implémentation entièrement dans l'espace utilisateur de la mémoire.
  • Une implémentation plus légère et une interface logicielle moins lourde pour le développeur.
  • Une liaison très directe du timing des flux de MIDI aux flux audio passant par JACK, donc la possibilité d'associer des événements MIDI et ondes audio générés par des synthés avec une grande précision. C'est la fameuse histoire du "sample accurate timing", qui est pourtant soumise à beaucoup de conditionnels dans le monde réel, d'où parfois quelques désaccords entre les développeurs.
  • JACK MIDI est pour l'instant la seule possibilité de gérer le MIDI des cartes son firewire à travers FFADO.

Inconvénients

  • Pour les développeurs: Contrairement à ALSA, JACK MIDI ne possède pas de séquenceur intégré. En effet, ALSA décharge les logiciels clients de s'occuper du timing effectif des notes envoyées ou reçues par un mécanisme de pré-stockage d'événements MIDI dans une "queue", et c'est le module ALSA lui même qui jouera l'événement avec le timing souhaité par le logiciel. Ceci est fait avec une énorme précision. Dans JACK, comme pour l'audio, le logiciel doit lui même réagir en envoyant des données "quand c'est le temps", c'est à dire quand JACK demande le prochain bloc de données, elles doivent être accessibles et correcte. En réalité ceci n'est pas extrêmement compliquée non plus pour le développeur, mais nécessite quelques précautions.
  • Quand on envoie du MIDI à l'extérieur par USB, le timing du MIDI dans JACK est aussi bon que la latence de JACK, et les flux sont interrompus de la même façon que les flux audio quand il y a des "xruns".
  • JACK MIDI ne gère actuellement pas d'événements SYSEX permettant une communication de données avancées aux instruments réels (synthés et boites MIDI externes), comme par exemple l'échange et la sauvegarde de patchs.

Dans l'ensemble les deux implémentations sont très performantes, avec une plus grande facilité pour les développeurs avec ALSA quand il s'agit de séquenceurs (grâce à la présence d'une queue de stockage) et une plus grande facilité avec JACK quand il s'agit de synthés et processeurs de données MIDI.

Pour l'instant, on a les deux à gérer sous Linux, selon les choix des développeurs. Heureusement il existe un pont entre les deux systèmes : a2jmidid permet d'accéder aux clients à partir des deux côtés et de faire fonctionner les logiciels ALSA MIDI et JACK MIDI entre elles.

Gestionnaires de connexions

Les principaux gestionnaires de connexions permettent de voir et connecter les deux types d'entrées et sorties MIDI :
  • QjackCtl possède deux onglets :
    • l'onglet "MIDI" qui correspond au MIDI de JACK
    • l'onglet "ALSA" qui correspond au MIDI d'ALSA
  • Patchage affiche deux couleurs :
    • vert pour le MIDI d'ALSA
    • rouge pour le MIDI de JACK
  • Catia et Claudia affichent deux couleurs :
    • marron pour le MIDI de JACK
  • LADISH, on ne voit pas le MIDI d'ALSA sauf quand on lance a2j en tant qu'application

Liens et commentaires



[+]

Documentation [Afficher / Cacher]

Connexion
[Afficher / Cacher]


Mégaphone [Afficher / Cacher]

r1, 19:51, sam. 19 Aug 2017: @sub26nico : cool merci :-)
sub26nico, 10:38, sam. 19 Aug 2017: L'éditorial du mois d'Août 2017 est publié !
sub26nico, 10:26, sam. 19 Aug 2017: Salut et bienvenue à Scorpi4 et be1 :-)
sub26nico, 10:17, sam. 19 Aug 2017: @be1, n'hésites pas à créer une page pour ton greffon, ça lui donnera plus de visibilité et tu peux ouvrir un fil de forum pour ta demande
be1, 01:55, sam. 19 Aug 2017: hello, j'ai fait un plugin LV2 de spacialisation stéréo d'une source (bi-)mono. Si ça intéresse des testeurs, me faire un message perso...
sub26nico, 18:45, jeu. 17 Aug 2017: Salut et bienvenue à sebos et Schmorgluck :-)
sub26nico, 20:31, mer. 16 Aug 2017: Ardour 5.11 est disponible [Lien]
sub26nico, 16:58, mer. 16 Aug 2017: Salut et bienvenue à Seb56Os :-)
zebassprophet, 15:17, mer. 16 Aug 2017: yep et j'en suis désolé sri_raoul. Des bouchons en Bretagne alors que anne de Bretagne a tant fait pour les autoroutes gratuites, un comble bref je m'organiserais mieux l'an prochain ;)
sub26nico, 14:08, mar. 15 Aug 2017: Salut et bienvenue à RoYmasta et Zulaan :-)
brigitte, 10:35, dim. 13 Aug 2017: Salut à tout le monde. Je débute en mao mais je joue du clavier depuis longtemps. J'ai installé Librazik studio. Je suis un peu perdu mais je plonge . Merci pour ce site sans lequel je ne pourrai pas imaginer avoir accès à tout ce savoir
sub26nico, 01:34, dim. 13 Aug 2017: Salut et bienvenue à charlhenri :-)