Previous 199869 Revisions Next

r34154 Thursday 1st January, 2015 at 23:47:35 UTC by Couriersud
Fix compile on clang
[src/emu]render.c render.h rendersw.inc
[src/emu/bus/a8sio]a8sio.h cassette.c cassette.h
[src/emu/sound]pokey.c pokey.h
[src/mess/drivers]atari400.c
[src/osd/sdl]sdl.mak

trunk/src/emu/bus/a8sio/a8sio.h
r242665r242666
4545   MCFG_DEVICE_SLOT_INTERFACE(a8sio_cards, _def_slot, false) \
4646   a8sio_slot_device::static_set_a8sio_slot(*device, _nbtag, _tag);
4747
48#define MCFG_A8SIO_DATA_IN_CB(_devcb) \
49   devcb = &a8sio_device::set_data_in_callback(*device, DEVCB_##_devcb);
5048
51
5249class a8sio_slot_device : public device_t,
5350                     public device_slot_interface
5451{
trunk/src/emu/bus/a8sio/cassette.c
r242665r242666
2626//**************************************************************************
2727
2828const device_type A8SIO_CASSETTE = &device_creator<a8sio_cassette_device>;
29const device_timer_id TIMER_CASSETTE_READ = 1;
3029
3130static MACHINE_CONFIG_FRAGMENT( cassette )
3231   MCFG_CASSETTE_ADD("cassette")
33   //MCFG_CASSETTE_DEFAULT_STATE(CASSETTE_STOPPED)
34   MCFG_CASSETTE_DEFAULT_STATE(CASSETTE_PLAY)
32   MCFG_CASSETTE_DEFAULT_STATE(CASSETTE_STOPPED)
3533   MCFG_CASSETTE_INTERFACE("atari8bit_cass")
3634MACHINE_CONFIG_END
3735
r242665r242666
4846   : device_t(mconfig, A8SIO_CASSETTE, "Atari 8 bit cassette", tag, owner, clock, "a8sio_cass", __FILE__)
4947   , device_a8sio_card_interface(mconfig, *this)
5048   , m_cassette(*this, "cassette")
51   , m_old_cass_signal(0)
52   , m_signal_count(0)
5349{
5450}
5551
r242665r242666
5753   : device_t(mconfig, type, name, tag, owner, clock, shortname, source)
5854   , device_a8sio_card_interface(mconfig, *this)
5955   , m_cassette(*this, "cassette")
60   , m_old_cass_signal(0)
61   , m_signal_count(0)
6256{
6357}
6458
6559void a8sio_cassette_device::device_start()
6660{
6761   set_a8sio_device();
68
69   save_item(NAME(m_old_cass_signal));
70   save_item(NAME(m_signal_count));
71
72   m_read_timer = timer_alloc(TIMER_CASSETTE_READ);
7362}
7463
7564void a8sio_cassette_device::device_reset()
r242665r242666
7968WRITE_LINE_MEMBER( a8sio_cassette_device::motor_w )
8069{
8170   //printf("a8sio_cassette::motor_w %d\n", state);
82   if (!state)
83   {
84      m_cassette->change_state(CASSETTE_MOTOR_ENABLED, CASSETTE_MASK_MOTOR);
85      m_read_timer->adjust(attotime::zero, 0, attotime::from_hz(44100));
86   }
87   else
88   {
89      m_cassette->change_state(CASSETTE_MOTOR_DISABLED, CASSETTE_MASK_MOTOR);
90      m_read_timer->reset();
91   }
9271}
9372
94void a8sio_cassette_device::device_timer(emu_timer &timer, device_timer_id id, int param, void *ptr)
95{
96   switch (id)
97   {
98      case TIMER_CASSETTE_READ:
99         UINT8 cass_signal = m_cassette->input() < 0 ? 0 : 1;
100
101         if (m_signal_count < 20)
102         {
103            m_signal_count++;
104         }
105
106         if (cass_signal != m_old_cass_signal)
107         {
108            //printf("cass_signal: %d, count: %d, data: %d\n", cass_signal, m_signal_count, m_signal_count < 5 ? 1 : 0);
109            // ~4 kHz -> 0
110            // ~5 kHz -> 1
111            m_a8sio->data_in_w((m_signal_count < 5) ? 1 : 0);
112            m_signal_count = 0;
113            m_old_cass_signal = cass_signal;
114         }
115         break;
116   }
117}
118
trunk/src/emu/bus/a8sio/cassette.h
r242665r242666
3838protected:
3939   virtual void device_start();
4040   virtual void device_reset();
41   virtual void device_timer(emu_timer &timer, device_timer_id id, int param, void *ptr);
4241
4342   required_device<cassette_image_device> m_cassette;
44   emu_timer *m_read_timer;
45
46   UINT8 m_old_cass_signal;
47   UINT8 m_signal_count;
4843};
4944
5045// device type definition
trunk/src/emu/render.c
r242665r242666
222222    return *this;
223223}
224224
225render_texinfo::render_texinfo(const render_texinfo &src)
226{
227    base = src.base;
228    rowpixels = src.rowpixels;
229    width = src.width;
230    height = src.height;
231    seqid = src.seqid;
232    osddata = src.osddata;
233    m_palette = src.m_palette;
234    if (m_palette != NULL)
235    {
236        m_palette->ref_count++;
237    }
238}
239
225240void render_texinfo::set_palette(const dynamic_array<rgb_t> *source)
226241{
227242    free_palette();
trunk/src/emu/render.h
r242665r242666
219219
220220class render_texinfo
221221{
222private:
223    render_texinfo(const render_texinfo &src) {}
224222public:
225223    render_texinfo()
226224    : base(NULL), rowpixels(0), width(0), height(0),
227225      seqid(0), osddata(0), m_palette(NULL)
228226    {}
227
228    render_texinfo(const render_texinfo &src);
229
229230    ~render_texinfo()
230231    {
231232        free_palette();
trunk/src/emu/rendersw.inc
r242665r242666
622622      INT32 endx = setup.endx;
623623
624624      // ensure all parameters are valid
625      assert(prim.texture.palette() != NULL);
625      assert(prim.texture.palette != NULL);
626626
627627      // fast case: no coloring, no alpha
628628      if (prim.color.r >= 1.0f && prim.color.g >= 1.0f && prim.color.b >= 1.0f && is_opaque(prim.color.a))
r242665r242666
730730      INT32 endx = setup.endx;
731731
732732      // ensure all parameters are valid
733      assert(prim.texture.palette() != NULL);
733      assert(prim.texture.palette != NULL);
734734
735735      // fast case: no coloring, no alpha
736736      if (prim.color.r >= 1.0f && prim.color.g >= 1.0f && prim.color.b >= 1.0f && is_opaque(prim.color.a))
r242665r242666
823823      INT32 endx = setup.endx;
824824
825825      // ensure all parameters are valid
826      assert(prim.texture.palette() != NULL);
826      assert(prim.texture.palette != NULL);
827827
828828      // fast case: no coloring, no alpha
829829      if (prim.color.r >= 1.0f && prim.color.g >= 1.0f && prim.color.b >= 1.0f && is_opaque(prim.color.a))
trunk/src/emu/sound/pokey.c
r242665r242666
10551055
10561056}
10571057
1058WRITE_LINE_MEMBER( pokey_device::sid_w )
1059{
1060   if (state)
1061   {
1062      m_SKSTAT |= SK_SERIN;
1063   }
1064   else
1065   {
1066      m_SKSTAT &= ~SK_SERIN;
1067   }
1068}
1069
10701058void pokey_device::serin_ready(int after)
10711059{
10721060   timer_set(m_clock_period * after, 5, 0);
trunk/src/emu/sound/pokey.h
r242665r242666
234234   UINT8 read(offs_t offset);
235235   void  write(offs_t offset, UINT8 data);
236236
237   DECLARE_WRITE_LINE_MEMBER( sid_w ); // pin 24
238237   void serin_ready(int after);
239238
240239   // analog output configuration
trunk/src/mess/drivers/atari400.c
r242665r242666
21002100   MCFG_PIA_CB2_HANDLER(DEVWRITELINE("fdc", atari_fdc_device, pia_cb2_w))
21012101
21022102   MCFG_DEVICE_ADD("a8sio", A8SIO, 0)
2103   MCFG_A8SIO_DATA_IN_CB(DEVWRITELINE("pokey", pokey_device, sid_w))
21042103   MCFG_A8SIO_SLOT_ADD("a8sio", "sio", NULL)
21052104
21062105   /* sound hardware */
trunk/src/osd/sdl/sdl.mak
r242665r242666
498498# Compile using framework (compile using libSDL is the exception)
499499ifeq ($(SDL_LIBVER),sdl2)
500500LIBS += -F$(SDL_FRAMEWORK_PATH) -framework SDL2 -framework Cocoa -framework OpenGL -lpthread
501BASELIBS += -F$(SDL_FRAMEWORK_PATH) -framework SDL2 -framework Cocoa -framework OpenGL -lpthread
502501else
503502LIBS += -F$(SDL_FRAMEWORK_PATH) -framework SDL -framework Cocoa -framework OpenGL -lpthread
504BASELIBS += -F$(SDL_FRAMEWORK_PATH) -framework SDL -framework Cocoa -framework OpenGL -lpthread
505503endif
506504INCPATH += -F$(SDL_FRAMEWORK_PATH)
507505else


Previous 199869 Revisions Next


© 1997-2024 The MAME Team