Skip to content

Commit

Permalink
[i2s_audio] Rebase with ESPHome to prepare for merging (#77)
Browse files Browse the repository at this point in the history
* esphome origin

* move bits_for_sample into base i2s

* adjustment for setting mode at input/output component

* update how yaml sets i2s mode

* import bits per sample from parent i2s audio

* more consistent base microphone class

* point to new branch
  • Loading branch information
kahrendt authored Sep 5, 2024
1 parent 1d40e84 commit 160efda
Show file tree
Hide file tree
Showing 17 changed files with 279 additions and 703 deletions.
28 changes: 13 additions & 15 deletions esphome/components/i2s_audio/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,33 +22,35 @@
CONF_I2S_BCLK_PIN = "i2s_bclk_pin"
CONF_I2S_LRCLK_PIN = "i2s_lrclk_pin"

CONF_BITS_PER_SAMPLE = "bits_per_sample"
CONF_I2S_AUDIO = "i2s_audio"
CONF_I2S_AUDIO_ID = "i2s_audio_id"

CONF_I2S_MODE = "i2s_mode"
CONF_PRIMARY = "primary"
CONF_SECONDARY = "secondary"

CONF_I2S_AUDIO = "i2s_audio"
CONF_I2S_AUDIO_ID = "i2s_audio_id"
CONF_BITS_PER_SAMPLE = "bits_per_sample"
i2s_bits_per_sample_t = cg.global_ns.enum("i2s_bits_per_sample_t")
BITS_PER_SAMPLE = {
16: i2s_bits_per_sample_t.I2S_BITS_PER_SAMPLE_16BIT,
32: i2s_bits_per_sample_t.I2S_BITS_PER_SAMPLE_32BIT,
}

_validate_bits = cv.float_with_unit("bits", "bit")


i2s_audio_ns = cg.esphome_ns.namespace("i2s_audio")
I2SAudioComponent = i2s_audio_ns.class_("I2SAudioComponent", cg.Component)
I2SAudioIn = i2s_audio_ns.class_("I2SAudioIn", cg.Parented.template(I2SAudioComponent))
I2SAudioOut = i2s_audio_ns.class_(
"I2SAudioOut", cg.Parented.template(I2SAudioComponent)
)

i2s_mode_t = cg.global_ns.enum("i2s_mode_t")
I2S_MODE_OPTIONS = {
CONF_PRIMARY: i2s_mode_t.I2S_MODE_MASTER, # NOLINT
CONF_SECONDARY: i2s_mode_t.I2S_MODE_SLAVE, # NOLINT
}
i2s_bits_per_sample_t = cg.global_ns.enum("i2s_bits_per_sample_t")
BITS_PER_SAMPLE = {
16: i2s_bits_per_sample_t.I2S_BITS_PER_SAMPLE_16BIT,
32: i2s_bits_per_sample_t.I2S_BITS_PER_SAMPLE_32BIT,
}

_validate_bits = cv.float_with_unit("bits", "bit")

# https://github.com/espressif/esp-idf/blob/master/components/soc/{variant}/include/soc/soc_caps.h
I2S_PORTS = {
Expand All @@ -64,9 +66,6 @@
cv.Required(CONF_I2S_LRCLK_PIN): pins.internal_gpio_output_pin_number,
cv.Optional(CONF_I2S_BCLK_PIN): pins.internal_gpio_output_pin_number,
cv.Optional(CONF_I2S_MCLK_PIN): pins.internal_gpio_output_pin_number,
cv.Optional(CONF_I2S_MODE, default=CONF_PRIMARY): cv.enum(
I2S_MODE_OPTIONS, lower=True
),
}
)

Expand All @@ -89,9 +88,8 @@ async def to_code(config):
var = cg.new_Pvariable(config[CONF_ID])
await cg.register_component(var, config)

cg.add(var.set_i2s_mode(config[CONF_I2S_MODE]))
cg.add(var.set_lrclk_pin(config[CONF_I2S_LRCLK_PIN]))
if CONF_I2S_BCLK_PIN in config:
cg.add(var.set_bclk_pin(config[CONF_I2S_BCLK_PIN]))
if CONF_I2S_MCLK_PIN in config:
cg.add(var.set_mclk_pin(config[CONF_I2S_MCLK_PIN]))
cg.add(var.set_mclk_pin(config[CONF_I2S_MCLK_PIN]))
2 changes: 1 addition & 1 deletion esphome/components/i2s_audio/i2s_audio.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -31,4 +31,4 @@ void I2SAudioComponent::setup() {
} // namespace i2s_audio
} // namespace esphome

#endif // USE_ESP32
#endif // USE_ESP32
28 changes: 1 addition & 27 deletions esphome/components/i2s_audio/i2s_audio.h
Original file line number Diff line number Diff line change
Expand Up @@ -9,28 +9,6 @@
namespace esphome {
namespace i2s_audio {


enum class TaskEventType : uint8_t {
STARTING = 0,
STARTED,
RUNNING,
IDLE,
STOPPING,
STOPPED,
MUTED,
WARNING = 255,
};


struct CommandEvent {
bool stop;
};

struct TaskEvent {
TaskEventType type;
esp_err_t err;
};

class I2SAudioComponent;

class I2SAudioIn : public Parented<I2SAudioComponent> {};
Expand All @@ -55,9 +33,6 @@ class I2SAudioComponent : public Component {
void set_bclk_pin(int pin) { this->bclk_pin_ = pin; }
void set_lrclk_pin(int pin) { this->lrclk_pin_ = pin; }

void set_i2s_mode(i2s_mode_t mode) { this->mode_ = mode; }
i2s_mode_t get_i2s_mode() { return this->mode_; }

void lock() { this->lock_.lock(); }
bool try_lock() { return this->lock_.try_lock(); }
void unlock() { this->lock_.unlock(); }
Expand All @@ -74,10 +49,9 @@ class I2SAudioComponent : public Component {
int bclk_pin_{I2S_PIN_NO_CHANGE};
int lrclk_pin_;
i2s_port_t port_{};
i2s_mode_t mode_{};
};

} // namespace i2s_audio
} // namespace esphome

#endif // USE_ESP32
#endif // USE_ESP32
10 changes: 8 additions & 2 deletions esphome/components/i2s_audio/microphone/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,14 @@
import esphome.codegen as cg

from esphome import pins
from esphome.const import CONF_CHANNEL, CONF_ID, CONF_NUMBER
from esphome.const import CONF_CHANNEL, CONF_ID, CONF_NUMBER, CONF_SAMPLE_RATE
from esphome.components import microphone, esp32
from esphome.components.adc import ESP32_VARIANT_ADC1_PIN_TO_CHANNEL, validate_adc_pin

from .. import (
CONF_I2S_MODE,
CONF_PRIMARY,
I2S_MODE_OPTIONS,
i2s_audio_ns,
I2SAudioComponent,
I2SAudioIn,
Expand All @@ -23,7 +26,6 @@
CONF_ADC_PIN = "adc_pin"
CONF_ADC_TYPE = "adc_type"
CONF_PDM = "pdm"
CONF_SAMPLE_RATE = "sample_rate"
CONF_USE_APLL = "use_apll"

I2SAudioMicrophone = i2s_audio_ns.class_(
Expand Down Expand Up @@ -64,6 +66,9 @@ def validate_esp32_variant(config):
_validate_bits, cv.enum(BITS_PER_SAMPLE)
),
cv.Optional(CONF_USE_APLL, default=False): cv.boolean,
cv.Optional(CONF_I2S_MODE, default=CONF_PRIMARY): cv.enum(
I2S_MODE_OPTIONS, lower=True
),
}
).extend(cv.COMPONENT_SCHEMA)

Expand Down Expand Up @@ -103,6 +108,7 @@ async def to_code(config):
cg.add(var.set_din_pin(config[CONF_I2S_DIN_PIN]))
cg.add(var.set_pdm(config[CONF_PDM]))

cg.add(var.set_i2s_mode(config[CONF_I2S_MODE]))
cg.add(var.set_channel(config[CONF_CHANNEL]))
cg.add(var.set_sample_rate(config[CONF_SAMPLE_RATE]))
cg.add(var.set_bits_per_sample(config[CONF_BITS_PER_SAMPLE]))
Expand Down
Loading

0 comments on commit 160efda

Please sign in to comment.