Tuesday, 7 July 2009

Re-Programming MusicPal

I have not made any progress with the MusicPal since Christmas, but someone else has been busy and made a good start on some alternative software to run on it, which he has published here http://musicpal.v3v.de/.
Well done Marco - you have got much further than I have!
Giles also made progress with sound output and left his code in a comment to one of my earlier posts here.
Maybe it would be worth starting a project on Google Code or somewhere so other people can help develop it?

19 comments:

  1. Great to hear that someone has done some work on getting alternative software working on the Music Pal. Have you tried out this software yet, if so what features and capabilities does it have.

    ReplyDelete
  2. The current features are:

    - MP3 recording / ripping
    - Samba Server (as addon)
    - Customized menues (/home/palmod.cfg)
    - Command line parameters, to control display, knobs and audio.

    It runs parallel to nashville.
    I posted a tutorial in german on http://www.mydssd.de/musicpal/doku.php

    The included README is in english but a little bit shortened.

    ReplyDelete
  3. Thats Great News, I would like to be able to stream (mp3/wav) from my laptop to the musicpal. Do you think you might implement this?

    (I know that you can do this via upnp and stuff like MediaTomb, but that requires me to walk over to the device and press buttons, I want to do it remotely)

    ReplyDelete
  4. Ok.. I gave it a try... but those depencies drove me crazy ;-)

    I already compiled madplay without any problems. It needs libmad and libid3-tag. These are also needed by mpd, when you want to play MP3.

    mpd >= 0.14 needs glib, so I tried 0.13.2 and it compiles cleanly, supporting mp3, mp2 and oss:

    ./configure --disable-oggflac --disable-oggvorbis --build=i386-linux-gnu --target=arm-linux --host=arm-linux --with-mad-libraries=/home/maz/MusicPal/madplay/libmad-0.15.1b/.libs/ --with-mad-includes=/home/maz/MusicPal/madplay/libmad-0.15.1b/ --with-id3tag-libraries=/home/maz/MusicPal/madplay/libid3tag-0.15.1b/.libs/ --with-id3tag-includes=/home/maz/MusicPal/madplay/libid3tag-0.15.1b/

    It starts on the MusicPal, but OSS wouldn't work, I think.

    ReplyDelete
  5. mpd output:

    list: play 0:"Bill Wyman's Rhythm Kings - Groovin' - 13 - Streamline Woman.mp3"
    copyMpdTagToOB: !acceptMetadata || !tag
    interface 0: command returned 0
    interface 0: process command "status"
    interface 0: command returned 0
    interface 0: process command "outputs"
    interface 0: command returned 0
    interface 0: process command "status"
    interface 0: command returned 0
    interface 0: process command "outputs"
    interface 0: command returned 0
    OSS device "/dev/audio" does not support 2 channels: Inappropriate ioctl for device
    problems opening audio device while playing "Bill Wyman's Rhythm Kings - Groovin' - 13 - Streamline Woman.mp3"
    playlist: stop
    interface 0: process command "status"
    interface 0: command returned 0
    interface 0: process command "clearerror"
    interface 0: command returned 0
    interface 0: process command "outputs"
    interface 0: command returned 0
    interface 0: process command "

    I modify mpd later.

    ReplyDelete
  6. Wow - such progress!
    You are right that OSS output will not work - the MusicPal audio interface looks similar to OSS, but not the same.
    I think the thing to do is to look in src/output in the mpd source directory and create a new output plugin for the MusicPal. I had a quick go at this based on the OSS one, but then I failed to get autoconf to link my new code into it....
    I seem to have lost my code though - If I find it I will post it somewhere for you.

    ReplyDelete
  7. I forgot something to mention:

    The paths in mpd.conf should be changed! They show to my usb drive.

    Everything else is preconfigured.
    It also works, when nashville is running (but not playing).

    ./mpd --no-daemon --stdout --verbose mpd.conf

    ReplyDelete
  8. Wow, it works!

    I don't have an usb drive attached to my musicpal (yet) so I had to fiddle with mpd.conf, and put all the test music in the limited space in /tmp

    Once running I attached to the mpd running on musicpal with Gnome Music Player Client.

    I can't stream audio from my pc to the musicpal, I don't know if this is a limitation of mpd or gmpc. But I think once I have soldered a usb drive socket to the musicpal it will do what I want it to.

    Thanks to Maz and NT for all the effort, I look forward to seeing what else can be done ;)

    ReplyDelete
  9. Actually, I just realised, you made a samba plugin for palmod, could I prehaps use this to mount an smb share in which my music is kept?

    It would be nice to have a standalone version of smbmount if you would be so kind Maz ;)

    ReplyDelete
  10. My god, that was quick!

    Can't wait to try it...

    ReplyDelete
  11. After spending several hours getting samba on my laptop working, sigh.

    It worked, however the module is too big to put anywhere other than tmp, which then gets deleted after I shut down the music pal.

    I wonder maz, could the size of the module be reduced by stripping, as discussed here:

    http://www.linux-mips.org/archives/linux-mips/2002-04/msg00031.html

    ReplyDelete
  12. There are ~220kb left on the device, but the jffs filesystem should compress that file about 50%.

    /tmp seems to be fixed size, but enough for loading cifs with a boot script using wget.

    ReplyDelete
  13. Ah ha it fits afterall, well it wouldn't before because I had a huge mpd.conf in my /home dir, anyway, so now I basically just have cifs.ko in my /home dir aswell as the following script:

    #!/bin/sh

    insmod cifs.ko
    mkdir /tmp/mpd
    mount -t cifs -o username=guest //192.168.2.4/mpd /tmp/mpd
    mount -t cifs -o username=guest //192.168.2.4/music /tmp/mpd/music/

    /tmp/mpd/mpd /tmp/mpd/mpd.conf

    ReplyDelete
  14. You can also write to /usr. You only have to remount the filesystem rewriteable:

    # writeable
    mount -o remount,rw /
    # readonly
    mount -o remount,ro /

    root is mtdblock0 and home is mtdblock1, so you've got two partitions.

    I think, it would be better to put mpd to the samba share and start it from there. At least the database.

    ReplyDelete
  15. And a little bit on compiling kernel modules here

    ReplyDelete
  16. That's cool.

    NFS may be faster than CIFS/SMB.
    I'll put this into the FW replacement kit.

    MpPong is really funny :-)

    ReplyDelete
  17. @giles your blog seems to be down...

    @maz via google cache of giles blog -
    "maybe the USB-Host can manage other devices."

    If this can be achieved then were definitely on to something, put a hub inside like they did with the EEEPC
    http://beta.ivancover.com/wiki/index.php/Eee_PC_Internal_Upgrades

    From the internal hub put some storage inside and still have an external USB socket.

    From there have all the software on the extra storage (apart from the alarm clock part I guess).

    [stuartaxon.com]

    ReplyDelete
  18. Yeah it keeps going down because I have a measily 100MB a month bandwidth quota, I get my web hosting for free, but prehaps I need to upgrade to the unlimited bandwidth option.

    Anyway, there is a mirror of my site hosted at http://korma.home.dyndns.org/wordpress

    ReplyDelete
  19. To answer Stu's question, USB hubs seem to work fine with the MusicPal (at least with flash drives, I haven't tried anything more complicated), so you could easily hide a little one inside the MusicPal case with a small flash drive to extend the storage capacity.

    I like Maz's idea of stripping out the superfluous stuff from the MusicPal firmware and replacing nashville with a mpd client. I just haven't got brave enough to try to re-flash it yet I'll have to try the 'emergency re-flash' procedure to make sure it works first so I can go back to the manufacturers' firmware.

    ReplyDelete