2011-03-12 20:37:26 +03:00
|
|
|
/////////////////////////////////////////////////////////////////////////
|
|
|
|
// $Id$
|
|
|
|
/////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
2012-08-31 16:08:19 +04:00
|
|
|
// ES1370 soundcard support (ported from QEMU)
|
2011-03-12 20:37:26 +03:00
|
|
|
//
|
2012-08-31 16:08:19 +04:00
|
|
|
// Copyright (c) 2005 Vassili Karpov (malc)
|
2015-02-13 14:30:46 +03:00
|
|
|
// Copyright (C) 2011-2015 The Bochs Project
|
2011-03-12 20:37:26 +03:00
|
|
|
//
|
2012-08-31 16:08:19 +04:00
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
// of this software and associated documentation files (the "Software"), to deal
|
|
|
|
// in the Software without restriction, including without limitation the rights
|
|
|
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
// copies of the Software, and to permit persons to whom the Software is
|
|
|
|
// furnished to do so, subject to the following conditions:
|
2011-03-12 20:37:26 +03:00
|
|
|
//
|
2012-08-31 16:08:19 +04:00
|
|
|
// The above copyright notice and this permission notice shall be included in
|
|
|
|
// all copies or substantial portions of the Software.
|
|
|
|
//
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
|
|
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
// THE SOFTWARE.
|
|
|
|
/////////////////////////////////////////////////////////////////////////
|
2011-03-12 20:37:26 +03:00
|
|
|
|
|
|
|
#ifndef BX_IODEV_ES1370_H
|
|
|
|
#define BX_IODEV_ES1370_H
|
|
|
|
|
|
|
|
#if BX_USE_ES1370_SMF
|
|
|
|
# define BX_ES1370_SMF static
|
|
|
|
# define BX_ES1370_THIS theES1370Device->
|
|
|
|
# define BX_ES1370_THIS_PTR theES1370Device
|
|
|
|
#else
|
|
|
|
# define BX_ES1370_SMF
|
|
|
|
# define BX_ES1370_THIS this->
|
|
|
|
# define BX_ES1370_THIS_PTR this
|
|
|
|
#endif
|
|
|
|
|
2013-12-14 21:43:12 +04:00
|
|
|
#define BX_ES1370_CODEC_REGS 0x1a
|
|
|
|
|
2011-03-12 20:37:26 +03:00
|
|
|
typedef struct {
|
|
|
|
Bit32u shift;
|
|
|
|
Bit32u leftover;
|
|
|
|
Bit32u scount;
|
|
|
|
Bit32u frame_addr;
|
|
|
|
Bit32u frame_cnt;
|
|
|
|
} chan_t;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
chan_t chan[3];
|
|
|
|
Bit32u ctl;
|
|
|
|
Bit32u status;
|
|
|
|
Bit32u mempage;
|
2013-12-14 21:43:12 +04:00
|
|
|
Bit8u codec_index;
|
|
|
|
Bit8u codec_reg[BX_ES1370_CODEC_REGS];
|
2013-12-15 21:09:18 +04:00
|
|
|
Bit16u wave_vol;
|
2011-03-12 20:37:26 +03:00
|
|
|
Bit32u sctl;
|
2015-04-05 14:48:44 +03:00
|
|
|
Bit8u legacy1B;
|
2011-03-12 20:37:26 +03:00
|
|
|
|
|
|
|
int dac1_timer_index;
|
|
|
|
int dac2_timer_index;
|
2015-02-20 00:31:18 +03:00
|
|
|
Bit8u dac_outputinit;
|
2011-04-04 20:07:24 +04:00
|
|
|
bx_bool adc_inputinit;
|
2011-04-25 21:35:39 +04:00
|
|
|
int dac_nr_active;
|
2011-04-26 22:35:43 +04:00
|
|
|
Bit16u dac_packet_size[2];
|
2015-04-03 02:21:04 +03:00
|
|
|
Bit32u dac_timer_val[2];
|
2011-03-12 20:37:26 +03:00
|
|
|
|
|
|
|
Bit8u devfunc;
|
|
|
|
} bx_es1370_t;
|
|
|
|
|
|
|
|
|
2015-02-13 14:30:46 +03:00
|
|
|
// forward definitions
|
|
|
|
class bx_soundlow_waveout_c;
|
2015-02-14 20:25:39 +03:00
|
|
|
class bx_soundlow_wavein_c;
|
2011-03-12 20:37:26 +03:00
|
|
|
|
|
|
|
class bx_es1370_c : public bx_devmodel_c, bx_pci_device_stub_c {
|
|
|
|
public:
|
|
|
|
bx_es1370_c();
|
|
|
|
virtual ~bx_es1370_c();
|
|
|
|
virtual void init(void);
|
|
|
|
virtual void reset(unsigned type);
|
|
|
|
virtual void register_state(void);
|
|
|
|
virtual void after_restore_state(void);
|
|
|
|
|
|
|
|
virtual Bit32u pci_read_handler(Bit8u address, unsigned io_len);
|
|
|
|
virtual void pci_write_handler(Bit8u address, Bit32u value, unsigned io_len);
|
|
|
|
|
2013-11-29 00:47:34 +04:00
|
|
|
// runtime options
|
|
|
|
static Bit64s es1370_param_handler(bx_param_c *param, int set, Bit64s val);
|
|
|
|
static const char* es1370_param_string_handler(bx_param_string_c *param, int set,
|
|
|
|
const char *oldval, const char *val,
|
|
|
|
int maxlen);
|
|
|
|
static void runtime_config_handler(void *);
|
|
|
|
void runtime_config(void);
|
|
|
|
|
2011-03-12 20:37:26 +03:00
|
|
|
private:
|
|
|
|
bx_es1370_t s;
|
|
|
|
|
|
|
|
BX_ES1370_SMF void set_irq_level(bx_bool level);
|
|
|
|
BX_ES1370_SMF void update_status(Bit32u new_status);
|
|
|
|
BX_ES1370_SMF void check_lower_irq(Bit32u sctl);
|
2011-03-27 13:32:17 +04:00
|
|
|
BX_ES1370_SMF void update_voices(Bit32u ctl, Bit32u sctl, bx_bool force);
|
2015-04-03 02:21:04 +03:00
|
|
|
BX_ES1370_SMF Bit32u run_channel(unsigned channel, int timer_id, Bit32u buflen);
|
2013-07-13 21:37:48 +04:00
|
|
|
BX_ES1370_SMF void sendwavepacket(unsigned channel, Bit32u buflen, Bit8u *buffer);
|
2013-11-29 00:47:34 +04:00
|
|
|
BX_ES1370_SMF void closewaveoutput();
|
2015-03-31 21:01:52 +03:00
|
|
|
BX_ES1370_SMF Bit16u calc_output_volume(Bit8u reg1, Bit8u reg2, bx_bool shift);
|
2011-03-12 20:37:26 +03:00
|
|
|
|
|
|
|
static void es1370_timer_handler(void *);
|
|
|
|
void es1370_timer(void);
|
|
|
|
|
2011-04-04 20:07:24 +04:00
|
|
|
static Bit32u es1370_adc_handler(void *, Bit32u len);
|
|
|
|
|
2011-03-12 20:37:26 +03:00
|
|
|
static Bit32u read_handler(void *this_ptr, Bit32u address, unsigned io_len);
|
|
|
|
static void write_handler(void *this_ptr, Bit32u address, Bit32u value, unsigned io_len);
|
|
|
|
#if !BX_USE_ES1370_SMF
|
|
|
|
Bit32u read(Bit32u address, unsigned io_len);
|
|
|
|
void write(Bit32u address, Bit32u value, unsigned io_len);
|
|
|
|
#endif
|
|
|
|
|
2015-02-20 00:31:18 +03:00
|
|
|
bx_soundlow_waveout_c *waveout[2];
|
2015-02-14 20:25:39 +03:00
|
|
|
bx_soundlow_wavein_c *wavein;
|
2013-07-13 21:37:48 +04:00
|
|
|
int wavemode;
|
2015-02-20 00:31:18 +03:00
|
|
|
Bit8u wave_changed;
|
2011-03-12 20:37:26 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|