ID3v1

From Hydrogenaudio Knowledgebase
Revision as of 14:14, 10 March 2018 by XP1 (Talk | contribs)

Jump to: navigation, search

The audio formats MPEG layer I, layer II, and layer III (MP3) have no native way of saving information about the contents, except for some simple yes/no parameters like "private", "copyrighted", and "original home" (meaning this is the original file and not a copy). A solution to this problem was introduced with the program "Studio3" by Eric Kemp, alias NamkraD, in 1996. By adding a small chunk of extra data at the end of the file, one could get the MP3 file to carry information about the audio and not just the audio itself.

The placement of the tag, as the data was called, was probably chosen as there was little chance that it would disturb decoders. In order to make it easy to detect, a fixed size of 128 bytes was chosen. The tag has the following layout:

Example Id3v1 Tag
Song title 30 characters
Artist 30 characters
Album 30 characters
Year 4 characters
Comment 30 characters
Genre 1 byte

If we sum the size of all these fields, we see that 30+30+30+4+30+1 equals 125 bytes and not 128 bytes. The missing three bytes can be found at the very beginning of the tag, before the song title. These three bytes are always "TAG", which is the identification that this is indeed a ID3 tag. The easiest way to find a ID3v1/1.1 tag is to look for the word "TAG" 128 bytes from the end of a file.

As not all artists have a 30-character name, it is said that if there are some bytes left after the information is entered in the field, those bytes should be filled with the binary value 0. You might also think that you cannot write that much in the genre field, being one byte big, but it is clever than that. The byte value you enter in the genre field corresponds to a value in a predefined list. The list that Eric Kemp created had 80 entries, ranging from 0 to 79.


Additional Reading


Copyright

This material is copyrighted by Martin Nilsson, taken from ID3 made easy .