Module Name: src Committed By: isaki Date: Sat Mar 26 06:49:27 UTC 2022
Modified Files: src/sys/dev/audio: audio.c Log Message: Add terminology comments. To generate a diff of this commit: cvs rdiff -u -r1.119 -r1.120 src/sys/dev/audio/audio.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/dev/audio/audio.c diff -u src/sys/dev/audio/audio.c:1.119 src/sys/dev/audio/audio.c:1.120 --- src/sys/dev/audio/audio.c:1.119 Sat Mar 26 06:43:36 2022 +++ src/sys/dev/audio/audio.c Sat Mar 26 06:49:27 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: audio.c,v 1.119 2022/03/26 06:43:36 isaki Exp $ */ +/* $NetBSD: audio.c,v 1.120 2022/03/26 06:49:27 isaki Exp $ */ /*- * Copyright (c) 2008 The NetBSD Foundation, Inc. @@ -63,6 +63,49 @@ */ /* + * Terminology: "sample", "channel", "frame", "block", "track": + * + * channel frame + * | ........ + * v : : \ + * +------:------:------:- -+------+ : +------+-.. | + * #0(L) |sample|sample|sample| .. |sample| : |sample| | + * +------:------:------:- -+------+ : +------+-.. | + * #1(R) |sample|sample|sample| .. |sample| : |sample| | + * +------:------:------:- -+------+ : +------+-.. | track + * : : : : | + * +------:------:------:- -+------+ : +------+-.. | + * |sample|sample|sample| .. |sample| : |sample| | + * +------:------:------:- -+------+ : +------+-.. | + * : : / + * ........ + * + * \--------------------------------/ \--------.. + * block + * + * - A "frame" is the minimum unit in the time axis direction, and consists + * of samples for the number of channels. + * - A "block" is basic length of processing. The audio layer basically + * handles audio data stream block by block, asks underlying hardware to + * process them block by block, and then the hardware raises interrupt by + * each block. + * - A "track" is single completed audio stream. + * + * For example, the hardware block is assumed to be 10 msec, and your audio + * track consists of 2.1(=3) channels 44.1kHz 16bit PCM, + * + * "channel" = 3 + * "sample" = 2 [bytes] + * "frame" = 2 [bytes/sample] * 3 [channels] = 6 [bytes] + * "block" = 44100 [Hz] * (10/1000) [seconds] * 6 [bytes/frame] = 2646 [bytes] + * + * The terminologies shown here are only for this MI audio layer. Note that + * different terminologies may be used in each manufacturer's datasheet, and + * each MD driver may follow it. For example, what we call a "block" is + * called a "frame" in sys/dev/pci/yds.c. + */ + +/* * Locking: there are three locks per device. * * - sc_lock, provided by the underlying driver. This is an adaptive lock, @@ -138,7 +181,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: audio.c,v 1.119 2022/03/26 06:43:36 isaki Exp $"); +__KERNEL_RCSID(0, "$NetBSD: audio.c,v 1.120 2022/03/26 06:49:27 isaki Exp $"); #ifdef _KERNEL_OPT #include "audio.h"