| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155 | 
							- /* 
 
-  *  Squeezelite for esp32
 
-  *
 
-  *  (c) Sebastien 2019
 
-  *      Philippe G. 2019, philippe_44@outlook.com
 
-  *
 
-  *  This software is released under the MIT License.
 
-  *  https://opensource.org/licenses/MIT
 
-  *
 
-  */
 
- #include <setjmp.h>
 
- #include "squeezelite.h"
 
- #include "pthread.h"
 
- #include "esp_pthread.h"
 
- #include "esp_system.h"
 
- #include "esp_timer.h"
 
- #include "esp_wifi.h"
 
- #include "esp_log.h"
 
- #include "monitor.h"
 
- #include "platform_config.h"
 
- #include "messaging.h"
 
- #include "gpio_exp.h"
 
- #include "accessors.h"
 
- #ifndef CONFIG_POWER_GPIO_LEVEL
 
- #define CONFIG_POWER_GPIO_LEVEL 1
 
- #endif
 
- static const char TAG[] = "embedded";
 
- static struct {
 
- 	int gpio, active;
 
- } power_control = { CONFIG_POWER_GPIO, CONFIG_POWER_GPIO_LEVEL };
 
- extern void sb_controls_init(void);
 
- extern bool sb_displayer_init(void);
 
- u8_t custom_player_id = 12;
 
- mutex_type slimp_mutex;
 
- static jmp_buf jumpbuf;
 
- #ifndef POWER_LOCKED
 
- static void set_power_gpio(int gpio, char *value) {
 
- 	if (strcasestr(value, "power")) {
 
-         char *p = strchr(value, ':');
 
- 		if (p) power_control.active = atoi(p + 1);
 
- 		power_control.gpio = gpio;        
 
- 	}	
 
- }
 
- #endif
 
- void get_mac(u8_t mac[]) {
 
-     esp_read_mac(mac, ESP_MAC_WIFI_STA);
 
- }
 
- _sig_func_ptr signal(int sig, _sig_func_ptr func) {
 
- 	return NULL;
 
- }
 
- void em_logprint(const char *fmt, ...) {
 
-     va_list args;
 
- 	va_start(args, fmt);
 
- 	vfprintf(stderr, fmt, args);    
 
-     vmessaging_post_message(MESSAGING_ERROR, MESSAGING_CLASS_SYSTEM, fmt, args); 
 
- 	va_end(args);
 
- 	fflush(stderr);
 
- }
 
- void *audio_calloc(size_t nmemb, size_t size) {
 
- 	return calloc(nmemb, size);
 
- }
 
- int	pthread_create_name(pthread_t *thread, _CONST pthread_attr_t  *attr, 
 
- 				   void *(*start_routine)( void * ), void *arg, char *name) {
 
- 	esp_pthread_cfg_t cfg = esp_pthread_get_default_config(); 
 
- 	cfg.thread_name = name; 
 
- 	cfg.inherit_cfg = true; 
 
- 	esp_pthread_set_cfg(&cfg); 
 
- 	return pthread_create(thread, attr, start_routine, arg);
 
- }
 
- uint32_t _gettime_ms_(void) {
 
- 	return (uint32_t) (esp_timer_get_time() / 1000);
 
- }
 
- int embedded_init(void) {
 
- 	mutex_create(slimp_mutex);
 
- 	sb_controls_init();
 
- 	custom_player_id = sb_displayer_init() ? 100 : 101;
 
-     
 
- #ifndef POWER_LOCKED
 
- 	parse_set_GPIO(set_power_gpio);
 
- #endif
 
- 	if (power_control.gpio != -1) {
 
- 		gpio_pad_select_gpio_x(power_control.gpio);
 
- 		gpio_set_direction_x(power_control.gpio, GPIO_MODE_OUTPUT);
 
- 		gpio_set_level_x(power_control.gpio, !power_control.active);
 
- 		ESP_LOGI(TAG, "setting power GPIO %d (active:%d)", power_control.gpio, power_control.active);	
 
- 	}	    
 
-     
 
-     return setjmp(jumpbuf);
 
- }
 
- void embedded_exit(int code) {
 
-     longjmp(jumpbuf, code + 1);
 
- }    
 
- void powering(bool on) {
 
-     if (power_control.gpio != -1) {
 
-         ESP_LOGI(TAG, "powering player %s", on ? "ON" : "OFF");	
 
-         gpio_set_level_x(power_control.gpio, on ? power_control.active : !power_control.active);
 
-     }
 
- }
 
- u16_t get_RSSI(void) {
 
-     wifi_ap_record_t wifidata;
 
-     esp_wifi_sta_get_ap_info(&wifidata);
 
- 	// we'll assume dBm, -30 to -100
 
-     if (wifidata.primary != 0) return 100 + wifidata.rssi + 30;
 
-     else return 0xffff;
 
- }	
 
- u16_t get_plugged(void) {
 
-     return jack_inserted_svc() ? PLUG_HEADPHONE : 0;
 
- }
 
- u16_t get_battery(void) {
 
- 	return (u16_t) (battery_value_svc() * 128) & 0x0fff;
 
- }	 
 
- void set_name(char *name) {
 
- 	char *cmd = config_alloc_get(NVS_TYPE_STR, "autoexec1");
 
- 	char *p, *q;
 
- 	
 
- 	if (!cmd) return;
 
- 	if ((p = strstr(cmd, " -n")) != NULL) {
 
- 		q = p + 3;
 
- 		// in case some smart dude has a " -" in player's name
 
- 		while ((q = strstr(q, " -")) != NULL) {
 
- 			if (!strchr(q, '"') || !strchr(q+1, '"')) break;
 
- 			q++;
 
- 		}
 
- 		if (q) memmove(p, q, strlen(q) + 1);
 
- 		else *p = '\0';
 
- 	}
 
- 	asprintf(&q, "%s -n \"%s\"", cmd, name);
 
-     config_set_value(NVS_TYPE_STR, "autoexec1", q);
 
- 	
 
- 	free(q);
 
- 	free(cmd);
 
- }
 
 
  |