2021-11-26 06:41:56 +03:00
|
|
|
/**
|
|
|
|
* @brief Implementation of the 'beep' utility.
|
|
|
|
*
|
|
|
|
* I've tried to get the functionality here as close to the common
|
|
|
|
* utility available on Linux systems so that "beep music" can be
|
|
|
|
* played back.
|
|
|
|
*
|
|
|
|
* @copyright
|
2018-08-15 04:07:33 +03:00
|
|
|
* This file is part of ToaruOS and is released under the terms
|
2018-05-04 07:11:06 +03:00
|
|
|
* of the NCSA / University of Illinois License - see LICENSE.md
|
2018-11-29 11:33:31 +03:00
|
|
|
* Copyright (C) 2014-2018 K. Lange
|
2018-05-04 07:11:06 +03:00
|
|
|
*/
|
|
|
|
#include <stdio.h>
|
2018-11-29 11:33:31 +03:00
|
|
|
#include <stdlib.h>
|
2018-05-04 07:11:06 +03:00
|
|
|
#include <unistd.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
|
|
|
int spkr = 0;
|
|
|
|
|
|
|
|
struct spkr {
|
|
|
|
int length;
|
|
|
|
int frequency;
|
|
|
|
};
|
|
|
|
|
2018-11-29 11:33:31 +03:00
|
|
|
static void note(int length, int frequency) {
|
2018-05-04 07:11:06 +03:00
|
|
|
struct spkr s = {
|
|
|
|
.length = length,
|
|
|
|
.frequency = frequency,
|
|
|
|
};
|
|
|
|
|
|
|
|
write(spkr, &s, sizeof(s));
|
|
|
|
}
|
|
|
|
|
2018-11-29 11:33:31 +03:00
|
|
|
/* Stolen from the Linux tool */
|
|
|
|
#define DEFAULT_FREQ 440.0
|
|
|
|
#define DEFAULT_LEN 200
|
|
|
|
#define DEFAULT_DELAY 100
|
|
|
|
|
|
|
|
static int repetitions = 1;
|
|
|
|
static float frequency = DEFAULT_FREQ;
|
|
|
|
static int length = DEFAULT_LEN;
|
|
|
|
static int delay = DEFAULT_DELAY;
|
|
|
|
static int beep_after = 0;
|
|
|
|
|
|
|
|
void beep(void) {
|
|
|
|
for (int i = 0; i < repetitions; ++i) {
|
|
|
|
note(length, frequency * 10);
|
|
|
|
if (delay && ((i != repetitions - 1) || beep_after)) {
|
|
|
|
usleep(delay * 1000);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-05-04 07:11:06 +03:00
|
|
|
int main(int argc, char * argv[]) {
|
|
|
|
|
|
|
|
spkr = open("/dev/spkr", O_WRONLY);
|
|
|
|
if (spkr == -1) {
|
|
|
|
fprintf(stderr, "%s: could not open speaker\n", argv[0]);
|
|
|
|
}
|
|
|
|
|
2018-11-29 11:33:31 +03:00
|
|
|
int opt;
|
2018-11-29 14:56:16 +03:00
|
|
|
while ((opt = getopt(argc, argv, "?hr:f:l:d:D:n")) != -1) {
|
2018-11-29 11:33:31 +03:00
|
|
|
switch (opt) {
|
2018-11-29 14:56:16 +03:00
|
|
|
case 'h':
|
|
|
|
case '?':
|
|
|
|
fprintf(stderr, "usage: %s BEEP...\n"
|
|
|
|
"Where BEEP consists of:\n"
|
|
|
|
" -r REPS \033[3mNumber of repetitions.\033[0m\n"
|
|
|
|
" -f FREQ \033[3mFrequency in Hz. 440 is A4. Supports fractional values.\033[0m\n"
|
|
|
|
" -l TIME \033[3mDuration in milliseconds.\033[0m\n"
|
|
|
|
" -d TIME \033[3mDelay between repetitions in milliseconds.\033[0m\n"
|
|
|
|
" -D TIME \033[3mDelay between, and after, repetitions.\033[0m\n"
|
|
|
|
" -n \033[3mStart a new beep.\033[0m\n"
|
|
|
|
"\n"
|
|
|
|
"The default values are:\n"
|
|
|
|
" -r 1 -l %d -f %.2f -d %d\n"
|
|
|
|
"\n"
|
|
|
|
"A length of -1 will start a sustained beep without blocking.\n"
|
|
|
|
"A length of 0 will stop a currently playing sustained beep.\n",
|
|
|
|
argv[0], DEFAULT_LEN, DEFAULT_FREQ, DEFAULT_DELAY);
|
|
|
|
return 1;
|
2018-11-29 11:33:31 +03:00
|
|
|
case 'r':
|
|
|
|
repetitions = atoi(optarg);
|
|
|
|
break;
|
|
|
|
case 'l':
|
|
|
|
length = atoi(optarg);
|
|
|
|
break;
|
|
|
|
case 'f':
|
|
|
|
frequency = atof(optarg);
|
|
|
|
break;
|
|
|
|
case 'd':
|
|
|
|
delay = atoi(optarg);
|
|
|
|
beep_after = 0;
|
|
|
|
break;
|
|
|
|
case 'D':
|
|
|
|
delay = atoi(optarg);
|
|
|
|
beep_after = 1;
|
|
|
|
break;
|
|
|
|
case 'n':
|
|
|
|
beep();
|
|
|
|
repetitions = 1;
|
|
|
|
frequency = DEFAULT_FREQ;
|
|
|
|
length = DEFAULT_LEN;
|
|
|
|
delay = DEFAULT_DELAY;
|
|
|
|
beep_after = 0;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
beep();
|
2018-05-04 07:11:06 +03:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|