Satellite CCRMA (Alpha Release)

From CCRMA Wiki
Revision as of 16:40, 13 December 2010 by Eberdahl (Talk | contribs) (Required Hardware)

Jump to: navigation, search

By Edgar Berdahl and Wendy Ju

Here we provide instructions for getting the alpha version of Satellite CCRMA up and running.


Required Hardware

  • Two GT Max adjustable-length USB cables
  • Ethernet cable
  • 2.5A 5V switching power adaptor (For example DVE DSA-15P-05 US)
  • Solderless breadboard

Note: Yes, both the host USB connector (for communication) and client USB connector (for power) on the Beagleboard are connected to the hub!

SatelliteTable.png Satellite CCRMA (Alpha version with additional Wifi adaptor plugged in via USB)

Powering Up For The First Time

Plug the power cable from the 5V supply into the hub. You will see some lights turn on, flickering every now and then. This means that Satellite CCRMA is booting up.


How To Connect

On this page, we explain how to connect to Satellite CCRMA over the Ethernet cable.

Mac OS X

Go to System Preferences, select Network, and choose the Ethernet module. Write down your current settings in case you think that you might need them in the future. (For example, if you use Ethernet to connect to the Internet in your dormitory, you probably want to save these settings for when you go home.) Now change your Ethernet settings to the following:

  • Configure: Manually
  • IP Address: 192.168.1.1
  • Subnet Mask: 255.255.255.0

The remaining items such as Router, DNS Server, and Search Domains can be left blank for now, and click the Apply button in the bottom right to apply the settings.

If your laptop is currently connected to the Internet using some method other than Ethernet: It can be convenient to enable the Beagleboard to get onto the Internet. Go back to System Preferences and choose Sharing. Edit the settings so that your Internet connection is shared with the Ethernet port. In order to do this, you may have to disable Internet Sharing temporarily. Finally, click the Internet Sharing checkbox to enable this option.

You will use the Terminal program to login to Satellite CCRMA over the Ethernet connection. It should be inside the Utilities folder inside of Applications.

Now open up a window in Terminal. Your Satellite CCRMA board should choose the IP address 192.168.1.105. To check that it is visible type the command ping 192.168.1.105, and see how fast the network response is. Once you are satisfied, hit Control-C to quit ping. Then, to finally login to Satellite CCRMA, type

ssh -X ccrma@192.168.1.105 The password should be temppwd.

Windows 7

<No instructions yet, but it should be analogous to the examples for other operating systems.>

Linux

Instructions for Ubuntu 10.04 Netbook Remix:

  • Run ifconfig in a terminal and look for your wired ethernet device. It will probably be called "eth0". Copy down the value next to HWaddr.
  • Go to "System" -> "Network Connections".
  • Under the "Wired" tab of the dialog that opens click "Add".
  • Set the "Connection name" to something logical, like CCRMA Satellite. Paste the value you copied from HWAddress in the "MAC address" box.
  • Click the "IPv4 Settings" tab. Change "Method" to "Manual". Next to "Addresses" click "Add". In the "Address" column type "192.168.1.1". In the "Netmask" column type "255.255.255.0". Click "Apply".
  • In the notification area on your desktop panel, click the NetworkManager Applet icon. Select the connection you just created. You now should be able to ssh into the board by typing "ssh -X ccrma@192.168.1.105" in a terminal.

For internet connection sharing, this link might help (I haven't tried it yet): https://help.ubuntu.com/community/Internet/ConnectionSharing


Test Run

Try issuing some of the following commands to explore the possibilities enabled by Satellite CCRMA:

  • qjackctl & (Opens up a GUI for starting the Jack audio server)
  • pd & (Starts pure data extended, an environment for graphical programming for sound synthesis)
  • ls /dev/tty* (To verify that the Arduino Nano is showing up on /dev/ttyUSB0)
  • arduino & (Starts the Arduino software for programming the Arduino Nano microcontroller attached via USB)
    • For instance, you could use the Arduino software to install some default firmware. It can be found under File|Examples|Firmata|StandardFirmata.
  • Run audacity & to edit audio samples.
  • Explore employing Faust to automatically generate audio DSP code in a variety of environments. The source code for Faust is in /usr/src/faust.
  • Run the example script in the directory ~/chuck_examples to takes the ChucK audio programming language for a spin.
  • Type ping yahoo.com to see if you are properly sharing your laptop's Internet connection with Satellite CCRMA. If you cannot ping yahoo, then please see the troubleshooting section.
  • Use the wget command to directly download files from the Internet via URLs.
  • Use scp to copy files to and from your kit.
  • See below for more tips on installing and/or compiling more software.


Installing New Software

If your favorite linux software has been compiled for the ARM architecture, it may be available by way of the apt-get utility.

  • To get a list of packages available on the OMAP's ARM architecture, type sudo apt-cache pkgnames
  • You will notice that this list is way too long to look at. You can pipe it to the text file using the command

sudo apt-cache pkgnames > packages.txt and then look at it using emacs packages.txt, or you search for a particular package, such as sudo apt-cache pkgnames | grep emacs.

  • Or you can compile linux software yourself on the Beagleboard. The gcc, g++ tools etc. are already installed.

Type the df command. You can see that there is not a whole lot more than 1GB available on the SD card, so you should only install software if you decide that you need it.


Autonomous Mode

It is possible to make Satellite CCRMA run a default program at startup. This way you can prototype devices that are fully autonomous of other systems!

Here we show how to cause the Jack audio server and Pure data (with a default patch) to start automatically after the kit boots up.

In the terminal, change to the on-startup directory by typing cd ~/on-startup and type ls -la to see what files are in there. You can see that the link (aka alias) default_patch.pd points to windy-day.pd. In order to enable the default patch to load on boot, rename the file load_default_patch_disabled to load_default_patch using the command mv load_default_patch_disabled load_default patch.

The cat command can be used to display the contents of any ASCII file. To look at the contents of load_default_patch, type cat load_default_patch. As you can see, it starts up Jack using the text-based jackd instead of qjackctl, and then it loads default_patch.pd in pd with the graphical user interface (GUI) disabled.

To test it, just reboot the kit by typing sudo reboot and entering the password temppwd. As it is rebooting, plug a pair of ear buds, headphones, or loudspeakers into the 1/8" (2.54mm) jack labeled AUDIO OUT on the beagleboard. Within about a minute, your kit should be fully rebooted. To check this, you can try logging in with SSH. Either way, it should start running windy_day.pd upon startup.

Once your kit is fully rebooted, if you touch the anaog input pins A0-A7 on the Arduino Nano, it should start making some sound. However, unless you connect up a sensor circuit to some of the analog inputs, the exact behavior may be complicated. In particular, it will depend on the electrical properties of your body (how much sweat is on your fingers, whether you are touching a grounded device such as a laptop with any part of your body. Ask for help if you cannot get any sound.

Finally, log back into Satellite CCRMA using the same command as always ssh -X ccrma@192.168.1.105. Type ps -A at the prompt to get a list of the currently running processes. jackd is the Jack audio sound server, and pdextended is the pd process. To stop the default patch from running, type ./stop_default. To see how stop_default works, type cat stop_default. (The ./ was necessary in order to run the script stop_default because the current user directory ~ is not in the user path, so linux needs the ./ to indicate to look for stop_default in the current directory.)


Halt Your Board When Finished!

When you are finished, it is probably best to shut down Satellite CCRMA by issuing the command sudo halt, just as you would shut down a linux desktop machine. This ensures that any data that is scheduled to be written to the SD card is written right away.



Appendix: Troubleshooting

Tips:

  • Type dmesg to see if there are any weird messages.
  • Check if the Jack audio server has crashed. If so, then restart it.
  • Type ls /dev/tty* to make sure that the Arduino is showing up on /dev/ttyUSB0.

Solutions:

  • If you are running out of space on the SD card, you can free up some space by deleting items in /usr/src. For instance, all of the files needed for building Pure Data Extended are rather large.
  • If you are unable to access the internet from Satellite CCRMA, you may need to change the nameservers specified in /etc/resolv.conf


Appendix: Writing the Image to an SD Card

If you have not obtained an SD card directly from us, then you will need to create one from the following image:

If you are running Mac OS X on your laptop, then you can use the following steps. On linux, the commands are very similar.

  • Unzip the image using unzip SatelliteCCRMAAlphaThree.dd.zip
  • Insert an SD card into the laptop, and find out which device it is associated with (e.g. /dev/disk2) using df
  • Make sure that the SD card is 4GB or larger. The following steps will cause all of the data currently on the SD card to be erased!
  • The SD card needs to be unmounted by OS X but not ejected. One way I have figured out how to do this is using fdisk. Assuming that the SD card is on /dev/disk2,
    • sudo fdisk -e /dev/disk2
    • print (just to check that you are fdisking the correct device)
    • setpid 1 and choose type 36. This is an unknown type, so that upon reinsertion of the SD card, OS X will no longer mount the volume.
    • write
    • quit
    • Eject the SD card in OS X.
    • Remove the SD card from the laptop.
    • Reinsert the SD card into the laptop.
  • Probably the SD card will still be on the same device, so in that case you can use

sudo dd if=SatelliteCCRMAAlphaThree.dd of=/dev/disk2