WO2006137973A2 - Serialization of media transfer communications - Google Patents

Serialization of media transfer communications Download PDF

Info

Publication number
WO2006137973A2
WO2006137973A2 PCT/US2006/015670 US2006015670W WO2006137973A2 WO 2006137973 A2 WO2006137973 A2 WO 2006137973A2 US 2006015670 W US2006015670 W US 2006015670W WO 2006137973 A2 WO2006137973 A2 WO 2006137973A2
Authority
WO
WIPO (PCT)
Prior art keywords
storage medium
computer
terminal
file
readable media
Prior art date
Application number
PCT/US2006/015670
Other languages
English (en)
French (fr)
Other versions
WO2006137973A3 (en
Inventor
Oren Rosenbloom
Vladimir Sadovsky
Blake D. Manders
Joseph D. Ternasky
Original Assignee
Microsoft Corporation
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US11/154,633 external-priority patent/US8239544B2/en
Application filed by Microsoft Corporation filed Critical Microsoft Corporation
Priority to KR1020127032231A priority Critical patent/KR101278767B1/ko
Priority to EP06751399.4A priority patent/EP1896950A4/en
Priority to CN200680020705.3A priority patent/CN101194234B/zh
Priority to JP2008516869A priority patent/JP4907651B2/ja
Publication of WO2006137973A2 publication Critical patent/WO2006137973A2/en
Publication of WO2006137973A3 publication Critical patent/WO2006137973A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/06Protocols specially adapted for file transfer, e.g. file transfer protocol [FTP]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/38Information transfer, e.g. on bus
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/14Session management
    • H04L67/141Setup of application sessions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/329Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the application layer [OSI layer 7]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1095Replication or mirroring of data, e.g. scheduling or transport for data synchronisation between network nodes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level

Definitions

  • a device may write to a storage card, and the storage card may then be removed from the device and inserted into a personal computer, which may retrieve information from the storage card.
  • a personal computer may write to a storage card, and the storage card may then be removed from the personal computer and inserted into the device, which may retrieve information from the storage card.
  • a storage card may be used to transfer photographs from a camera to a personal computer, or to transfer music files from a personal computer to a personal music player.
  • a personal computer may process the content before or after a transfer. For example, it may be advantageous to transcode information, that is, to converted coded information from one encoding format into another encoding format.
  • a music file may be stored in the personal computer as a relatively large high-fidelity file. Prior to transferring the music file to a personal music player for playback, it may be advantageous to represent the music file as a smaller low-fidelity file.
  • metadata may be added to photographs received from a camera.
  • content such as, for example, copyrighted media content, may include protection features, such as by implementing Digital Rights Management (DRM) features.
  • DRM Digital Rights Management
  • DRM may specify restrictions on a particular content, a particular device, or both.
  • a subscription DRM service might allow a user unlimited playback of all content on a particular personal music player, such as allowing unlimited playback of all music for one month.
  • a per-use DRM service might allow a user to play a particular content a particular number of times, such as allowing a user to play a movie once, or allowing a user to play a song three times.
  • the multiplicity of technical mechanisms, the different types of restrictions, and the different methods of handling DRM used by different devices may each complicate the transfer or playback of DRM content.
  • a set of conventions and operations can be followed by both a device and a terminal to allow a removable storage medium to act as a network connection.
  • the terminal can configure the device and media objects can be transferred between the device and the terminal solely by the movement of the removable storage medium between the device and the terminal.
  • These capabilities may be equivalent to the configuration and transfer capabilities that would be allowed by the network connection between the device and the terminal, allowing for the high latency incurred by the physical movement of the storage medium between the device and the terminal.
  • a removable storage medium is passed between a terminal and a device, and a device file stored on the removable storage medium is used to communicate media content and other information between the terminal and the device.
  • the device file may include "session information," such as information that can be used to represent a network session between the terminal and the device file.
  • the session information may be made up of one or more segments, each segment containing one or more requests and/or responses.
  • the session information may include, for example, media content and header information along with any other communication stream that may otherwise occur if two or more devices were directly connected via wired or wireless communication protocol.
  • the device file may allow the terminal to treat the removable storage medium as a locally connected device in some situations.
  • the terminal may create a device stack based upon the device file using device parameters stored on the removable storage medium, and use the device stack to communicate with the device via the removable storage medium.
  • a device may represent its content using human-readable data.
  • a user interface for playback of audio files should present the user with metadata such as the title, artist, album, duration, and the like.
  • a terminal may obtain such metadata from an outside source, such as an online source, or may or generate such metadata, for example, by interpreting file headers; many devices lack the resources to obtain or generate useful metadata.
  • One implementation therefore provides a method for a terminal to obtain or generate such metadata, and for the metadata to be transferred to a device.
  • Other implementations allow a terminal to generate other types of metadata, such as encoding parameters (for example, the bitrate of a media file), abstracted content (for example, Personal Information Manager data), and the like.
  • FIG. 1 is block diagram illustrating a computerized environment in which embodiments of the invention may be implemented;
  • FIG. 2 is a block diagram illustrating an overview of a system in accordance with an embodiment of the present invention
  • FIG. 3 is a block diagram illustrating an overview of a storage medium in accordance with an embodiment of the present invention.
  • FIG. 4 is a flow chart illustrating a method for communicating with a device, in accordance with an embodiment of the present invention.
  • FIG. 5 is a flow chart illustrating a method for communicating with a terminal, in accordance with an embodiment of the present invention.
  • FIG. 6 is a block diagram illustrating an overview of a system in accordance with an embodiment of the present invention. DETAILED DESCRIPTION
  • the invention relates to a system and method for removable storage content transfer.
  • a removable storage medium such as a memory stick or the like, may be used to transfer information between a device and a terminal, such as a personal computer.
  • a synchronization, or "sync,” operation may be used to transfer information between two or more devices with disparate information. The intention of a sync operation may be that all of the devices will eventually hold a common subset of information.
  • communication may follow a sequence of information exchanges, which may make up a sync operation.
  • a typical sequence of information exchanges may include the following:
  • the first and second steps transfer information from the device to a terminal.
  • a device may write information to a storage medium in a defined file format, and a terminal may read the information from the storage medium.
  • the storage medium may provide all the information an application on the terminal would require to perform functions such as device- specific media encoding, metadata-based views of device/storage content, and the like.
  • the third and fourth steps transfer information from the terminal to the device.
  • the terminal may, for example, choose to add to, deleted from, or rearrange the contents of the device. Rather than performing this interactively, the terminal may directly modify the content on the storage medium, and the actions taken on that content may be logged in a defined file format so the device can later process it as though it were communicated in an active session.
  • synchronization can be performed in one "round- trip" of a storage medium.
  • a round-trip may be completed when the removable storage medium has been accessed by each device in the group of devices at least once.
  • a round-trip may consist of that device accessing the removable storage medium at least once before all the other devices in the group of devices, and again at least once after all the other devices in the group of devices.
  • a round-trip may consist of the device accessing the storage medium, the terminal accessing the storage medium, and the device again accessing the storage medium.
  • a sync operation including error processing may be accomplished in two round-trips of the storage medium.
  • the storage medium may be transferred from the device to the terminal, which may place commands on the storage medium, and the storage medium may then be transferred back to the device. If the device is unable to process the commands on the storage medium, the device may place an error message on the storage medium.
  • the storage medium may be transferred to the terminal, and the error message may be processed by the terminal.
  • a defined container file format may be provided for errors.
  • the second round trip can be performed the next time the user wishes to transfer information between the device and the terminal.
  • the second round-trip can be used for media transfer or sync operations concurrently with the communication of error messages.
  • the interactive process of device synchronization can be performed in a single exchange of a storage medium.
  • device information may be communicated in a flat file on the storage medium. This device information may allow the terminal to communicate with the storage medium as though it were the device. Thus, the synchronizing application on the terminal may not recognize the storage medium as simple storage, but may consider it to be the device itself.
  • the data that is transferred between the device and the terminal may be arranged into a standard file format.
  • the standard file format may be the same data that would be sent to and from the device in an actual interactive session, serialized to a flat file (possibly with additional formatting information). This configuration allows devices to be built using only one set of processing logic, independent of whether the device contents are transferred by an interactive direct session or by storage medium exchange.
  • FIG. 1 illustrates an example of a suitable computing system environment 100 on which the system for serialization of media transfer may be implemented.
  • the computing system environment 100 is only one example of a suitable computing environment and is not intended to suggest any limitation as to the scope of use or functionality of the invention. Neither should the computing environment 100 be interpreted as having any dependency or requirement relating to any one or combination of components illustrated in the exemplary operating environment 100.
  • the invention is described in the general context of computer-executable instructions, such as program modules, being executed by a computer.
  • program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types.
  • the invention may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like.
  • the invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network.
  • program modules may be located in both local and remote computer storage media including memory storage devices.
  • the exemplary system 100 for implementing the invention includes a general purpose-computing device in the form of a computer 110 including a processing unit 120, a system memory 130, and a system bus 121 that couples various system components including the system memory to the processing unit 120.
  • Computer 110 typically includes a variety of computer readable media.
  • computer readable media may comprise computer storage media and communication media.
  • the system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132.
  • ROM read only memory
  • RAM random access memory
  • BIOS basic input/output system
  • RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 120.
  • FIG. 1 illustrates operating system 134, application programs 135, other program modules 136, and program data 137.
  • the computer 110 may also include other removable/nonremovable, volatile/nonvolatile computer storage media.
  • FIG. 1 illustrates a hard disk drive 141 that reads from or writes to nonremovable, nonvolatile magnetic media, a magnetic disk drive 151 that reads from or writes to a removable, nonvolatile magnetic disk 152, and an optical disk drive 155 that reads from or writes to a removable, nonvolatile optical disk 156 such as a CD ROM or other optical media.
  • removable/nonremovable, volatile/nonvolatile computer storage media that can be used in the exemplary operating environment include, but are not limited to, magnetic tape cassettes, flash memory cards, digital versatile disks, digital video tape, solid state RAM, solid state ROM, and the like.
  • the hard disk drive 141 is typically connected to the system bus 121 through an non-removable memory interface such as interface 140, and magnetic disk drive 151 and optical disk drive 155 are typically connected to the system bus 121 by a removable memory interface, such as interface 150.
  • the drives and their associated computer storage media discussed above and illustrated in FIG. 1, provide storage of computer readable instructions, data structures, program modules and other data for the computer 110.
  • hard disk drive 141 is illustrated as storing operating system 144, application programs 145, other program modules 146, and program data 147. Note that these components can either be the same as or different from operating system 134, application programs 135, other program modules 136, and program data 137. Operating system 144, application programs 145, other program modules 146, and program data 147 are given different numbers here to illustrate that, at a minimum, they are different copies.
  • a user may enter commands and information into the computer 110 through input devices such as a keyboard 162 and pointing device 161, commonly referred to as a mouse, trackball or touch pad.
  • Other input devices may include a microphone, joystick, game pad, satellite dish, scanner, or the like.
  • a user input interface 160 that is coupled to the system bus, but may be connected by other interface and bus structures, such as a parallel port, game port or a universal serial bus (USB).
  • a monitor 191 or other type of display device is also connected to the system bus 121 via an interface, such as a video interface 190.
  • computers may also include other peripheral output devices such as speakers 197 and printer 196, which may be connected through an output peripheral interface 195.
  • the computer 110 in the present invention will operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180.
  • the remote computer 180 may be a personal computer, and typically includes many or all of the elements described above relative to the computer 110, although only a memory storage device 181 has been illustrated in FIG. 1.
  • the logical connections depicted in FIG. 1 include a local area network (LAN) 171 and a wide area network (WAN) 173, but may also include other networks.
  • LAN local area network
  • WAN wide area network
  • the computer 110 When used in a LAN networking environment, the computer 110 is connected to the LAN 171 through a network interface or adapter 170. When used in a WAN networking environment, the computer 110 typically includes a modem 172 or other means for establishing communications over the WAN 173, such as the Internet.
  • the modem 172 which may be internal or external, may be connected to the system bus 121 via the user input interface 160, or other appropriate mechanism.
  • program modules depicted relative to the computer 110, or portions thereof may be stored in the remote memory storage device.
  • FIG. 1 illustrates remote application programs 185 as residing on memory device 181. It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers may be used.
  • FIG. 2 is a block diagram illustrating an overview of a system in accordance with an embodiment of the present invention.
  • a device 200 such as a consumer electronic device, may receive content from or transfer content to a terminal 202, such as a personal computer.
  • a terminal 202 such as a personal computer.
  • Each of the device 200 and the terminal 202 may be equipped with one or more storage readers and/or writers.
  • the device 200 may be, for example, an automotive built-in media system, a portable digital stereo system, a home entertainment system with built-in storage, a camera, a portable gaming device, a mobile telephone, or any other electronic system.
  • a plurality of devices 200 may receive content from or transfer content to the terminal 202.
  • the device 200 and the terminal 202 both may implement a configuration and transfer protocol that allows for configuration of the device 200 and the exchange of information between the device 200 and the terminal 202 when a network connection 204 is established between the device and the PC.
  • both the device 200 and the terminal 202 may have Universal Serial Bus (USB) connectors 203, 204 so that the device 200 can be connected to the terminal 202 via a direct USB cable 206 or some combination of USB cables and USB hubs.
  • USB Universal Serial Bus
  • MTP Media Transfer Protocol
  • both the device 200 and the terminal 202 may implement MTP allow for configuration of the device 200 and the transfer of media objects between the device 200 and the terminal 202.
  • MTP Mobility Transfer Protocol
  • TCP/IP Transmission Control Protocol/Internet Protocol
  • PTP Picture Transfer Protocol
  • a network connection is established between the device 200 and the terminal 202, via the USB cable 206 or some other connection, discrete packets of information may be sent from the device 200 to the terminal 202, or from the terminal 202 to the device 200.
  • the time it takes to perform such a transfer may depend on the latency of the network connection, and how reliable such transmission is may depend on the reliability of the network carrying the connection. Both the configuration and transfer protocol and the transport protocol may include mechanisms to make the best use of the network connection (reduce the latency) while reducing transmission errors (improving the reliability).
  • the communication between the device 200 and the terminal 202 over the USB cable 206 or other network connection may include one or more sessions. Each session is, for example, a lasting communication involving the exchange of many packets.
  • the configuration and transfer protocol being used may define one or more transfer protocol entities, which are software modules useful for configuration and transfer; such as operations, result codes, object formats, data types, data sets, data file references, and the like.
  • the configuration and transfer protocol, such as MTP may further define how these transfer protocol entities may be used.
  • When configuration or transfer is performed via a USB cable 206 or other network connection, one or more of these transfer protocol entities may be sent within discrete packets as part of a session.
  • the device 200 and the terminal 202 may share a storage medium 208.
  • the storage medium 208 is a removable read/write storage medium such as a memory card or magnetic disk.
  • the storage medium 208 may be formatted with a file system 210 that allows individual files to be created, read, written, or deleted.
  • Software running on both the device 200 and the terminal 202 may implement support for the file system 210, providing access to files stored on the storage medium 208 to both the device 200 and the terminal 202.
  • the storage medium 208 may be routinely moved back and forth between the device 200 and the terminal 202.
  • the storage medium 208 may be formatted in such a way that software running on both the device 200 and the terminal 202 can access and modify information in files carried on the storage medium 208.
  • the storage medium 208 can be treated as a network connection. This configuration may allow the device 200 and the terminal 202 to communicate without the USB cable 206.
  • a network connection is used for configuration or transfer, a session is established, including one or more discrete packets sent over a USB cable 206 or other network connection.
  • the packets may included transfer protocol entities; such as operations, result codes, object formats, data types, data sets, data file references and the like; that are defined by MTP or another configuration and transfer protocol.
  • these transfer protocol entities may be used in a like fashion, to carry out device configurations or transfers.
  • the transfer protocol entities may be recorded within a device file 212 on the storage medium 208.
  • the information stored in the device file 212 may be recorded, for example, as a byte stream.
  • the device file 212 may include all the information that would be transmitted during session, and the device file 212 may therefore be said to "represent" a session.
  • all the transfer protocol entities, header information, and other information that would be communicated between the device 200 and the terminal 202 during a session are recorded into the device file 212.
  • the device file 212 may record the transfer protocol entities sent in either direction, including packet "headers" that describe where the packet originated (for example, from the device 200 or the PC 202) and the packet's destination. Likewise, the device file 212 may include other packet header information, such as sequence numbers, session identifiers, transaction identifiers, etc. that may be used to represent a complete session.
  • a device file 212 can be viewed as a "serialized" session between one device 200 and one terminal 202, in the sense that the information in a device file 212 is sufficient to construct a session that would have the intended effects on both the device 200 and the terminal 202.
  • the storage medium 208 may be treated in some instances as a locally connected device.
  • programs, protocols, and data structures that are used to transfer information to and from locally connected devices may be utilized.
  • the Windows operating system may use a device stack to transfer information to and from locally connected devices.
  • the device file 212 representing a session allows the operating system to communicate with the device using a device stack. Details of the device stack will be discussed further with reference to FIG. 5.
  • FIG. 3 is a block diagram illustrating an overview of a storage medium in accordance with an embodiment of the present invention.
  • the storage medium may include a file system 210, which may provide access to files stored on the storage medium 208.
  • the storage medium 208 may further include one or more device files 212.
  • the storage medium 208 may be used, for example, for communication between two or more devices and/or terminals (not shown in FIG. 3) by means of passing the storage medium 208 back and forth between the devices and/or terminals.
  • Each device file 212 may represent a communication between one terminal and one device.
  • a plurality of devices may use the storage medium 208 to communicate with a central terminal.
  • each device may create a separate device file 212 used for communication with the central terminal.
  • Each of the device files 212 may contain a device profile 302.
  • Each device profile 302 may identify the device using the device file for communication.
  • each device profile 302 contains enough information for each device to determine which device file 302 corresponds to that device.
  • each device profile 302 may contain a unique device identifier.
  • a device file directory is used to simplify access to the device files 212 stored on the storage medium 208.
  • the device profile information 302 may be stored in the device file directory.
  • a device searching for the appropriate device file 212 may search the device file directory for the appropriate profile information 302, and then follow a pointer in the device file directory, or otherwise use the device file directory, to access the corresponding device file 212.
  • each device using the storage medium 208 writes a device profile 302 into a device file 212 and/or into a device file directory at the time the device file 212 is created.
  • the device profile 302 may be defined by the configuration and transfer protocol as a dataset that is used to characterize the device. For example, if MTP is the configuration and transfer protocol, each device may create a device file 212 and write a "Devicelnfo" dataset into a device profile 302 in the device file 212 and/or the device file directory. At a later time, when the device is searching for the appropriate device file 212 on the storage medium 208, the Devicelnfo dataset in the device profile 302 may allow the device to determine exactly which device file 212, if any, corresponds to that device.
  • Each device file 212 may contain zero or more segments 304.
  • Each segment 304 may be session information that is written by one party to the communication, either a device or a terminal, and read by the other party.
  • the writing party may be referred to as the Initiator and the other party may be referred to as the Responder.
  • the Initiator and Responder may communicate using any appropriate configuration and transfer protocol.
  • the Initiator may include zero or more responses, where each response corresponds to a request by the other party in a previous segment 304.
  • the Initiator may also include zero or more requests in a segment 304, where each request is intended to trigger a response from the Responder in a future segment 304.
  • each segment 304 may be bracketed, for example, by information in the device file 212 that delimits the extent of each segment 304. For example, where MTP is the configuration and transfer protocol, each segment 304 may be bracketed by "OpenSession" and "CloseSession" requests. In one implementation, no responses to these OpenSession and CloseSession requests are included within the segment 304, although responses to other requests may appear in the segment 304.
  • MTP is the configuration and transfer protocol.
  • a terminal may write a segment 304 to a device file 212 with a "SetDevicePropValue" request, including the new property value as part of the request. Later, when the storage medium 208 is inserted into the device to which this request was addressed, the device may respond to this request by appending a new segment 304 to the device file 212. This new segment may include a response to the "SetDevicePropValue" request, including, for example, a response code indicating success or failure in modifying the property value.
  • a request for information and the subsequent response addressing the request may be referred to as "related.”
  • related requests and responses within a device file contain common information that may be used to determine their relationship. For example, where MTP is the configuration and transfer protocol, a related request and response may share a common "SessionID" and "TransactionID.” Different requests or responses in a single segment 304 of the device file 212 may use different SessionID and/or TransactionID values, since these items may not be related to each other. This may be an example of a mismatch between the MTP concept of sessions and transactions and the concepts of device files and segments used in the device files 212.
  • the rules of MTP may be relaxed, for example, to allow for a segment that includes requests and responses with different SessionIDs and/or TransactionIDs.
  • other configuration and transfer protocols may be used, and the rules of the configuration and transfer protocols may be relaxed to allow for serialized communication using a removable storage medium.
  • the device files 212 may grow longer as additional segments 304 are appended to the device files 212.
  • a device or terminal may eliminate segments 304 from a device file 212 to reclaim the storage used by the device file 212. Eliminating unnecessary segments from a device file 212 will be discussed further below with reference to FIGs. 4-5.
  • a storage card may be used as a means to connect two or more devices that would otherwise never be directly connected. These devices understand a common communication protocol, such as MTP as an example.
  • a set of protocol operations can be serialized, or saved to a file that is stored on the removable storage medium, such as a compact flash memory card.
  • One such example of a session is a mechanism for explaining the types of files that a device may support. For example, a particular device that only supports the transfer of photos may record to its device file on its removable storage that only photos are understood by the device.
  • the terminal When this removable storage is directly inserted into a terminal, the terminal would parse the device file and then instantiate a device stack with an extra virtual layer bound to the device file that emulates the actual device. As such, the terminal believes it is directly communicating with the device and will determine that only photos can be transferred to/from the device. The terminal may then choose, for example, to transfer a photo to that virtual device. This operation will result in another device file on the removable storage that indicates that a new object is being created on the device, and a reference to the actual photo file that was saved to the removable storage. When this removable storage is then inserted back into the device, the device will read the new device file that was created by the terminal and conclude that a new photo file was added and the device file explains the attributes of this new photo file.
  • serialized communication may be used to perform content synchronization between a device and a terminal, or to perform content synchronization between two or more devices, optionally using the terminal as a common content depot.
  • serialized communication may further be used for propagation of user preferences, settings and configuration from a terminal to one or more devices, or for collection of recent user settings from one or more devices into a terminal.
  • serialized communication may be used for transfer of DRM keys from a service to the device by way of the terminal, or for transmitting requests for updated DRM keys from one or more devices to the service by way of the terminal.
  • Further applications may include transferring content from a service to the device by way of a terminal, or transmitting requests for content from the device to the service by way of the terminal.
  • Still further applications may include synchronization of device clocks, time zones, or locations from the terminal to one or more devices.
  • Still further applications may include discovery of new devices on the terminal, exposing additional device-specific user interfaces or features on the terminal when new devices are discovered, or exposing additional user interfaces or features on the terminal when a new combination of devices is discovered. Many other applications will be apparent to those skilled in the art.
  • FIG. 4 is a flowchart illustrating a method for communicating with a terminal.
  • the method may begin in step 400, wherein a device may receive a storage medium.
  • the storage medium may be inserted into a slot or disk drive, or otherwise placed in communication with the device.
  • the method may continue in step 402, wherein it is determined whether the storage medium has been formatted for the device.
  • the device determines whether or not the storage medium has been formatted for the device, for example, by detecting the presence of device-specific information on the storage medium. For example, the device may detect the presence of a device profile, a device file, or other information on the storage medium.
  • the device may format the storage medium. Formatting the storage medium may include, for example, creating and/or storing a device file and/or device profile on the storage medium. The method may continue in step 408. 10061] In one implementation, the device file and/or the device profile may be written into a secured portion of the storage medium, for example, with the assistance of a storage microcontroller. This implementation may protect device- specific information against accidental erasure. [0062] If it is determined in step 402 that the storage medium has been formatted for the device, the method may continue in step 405, wherein the appropriate device file is found on the storage medium.
  • the device may find the appropriate device file, for example, by searching for a device file that includes a device profile that corresponds to that device.
  • a device file directory may be used to find the appropriate device file.
  • one or more segments may be read from the device file.
  • the segment(s) read may include, for example, one or more requests and/or responses.
  • one or more segments may be written to the storage medium.
  • the segment(s) written may include, for example, one or more requests and/or responses.
  • Writing segment(s) includes, for example, storing these requests and/or responses into the device file as a byte stream.
  • the requests and/or responses include one or more media transfer entities.
  • the requests and responses read from or written to the storage medium may include media content or an indication of content transfer, such as a request for content, a result code indicating successful content transfer, header information, or other information.
  • the device may delete unnecessary segments from the device file.
  • segments may be preserved within the device file while any requests in the segment do not have related responses within the same device file.
  • a segment should only be removed from the device file when the requests made by that segment have been acknowledged by the Initiator. In one implementation, this acknowledgement may not be formally given, so the segment may typically removed by the Initiator.
  • the device removes segments for which it was the Initiator.
  • the Responder may remove a segment, for example, if the Initiator has made additional requests after receiving responses to all requests in the segment.
  • the device may simply delete the entire existing device file, create a new device file, and initialize it by creating a device profile.
  • the storage medium may be removed from the device.
  • the storage medium may be removed from a card slot or disk drive, or otherwise withdrawn from communication with the device.
  • FIG. 5 is a flowchart illustrating a method for communicating with a device.
  • the method may begin in step 500, wherein a terminal may receive a storage medium.
  • the storage medium may be inserted into a slot or disk drive, or otherwise placed in communication with the terminal.
  • the terminal may find the appropriate device file on the storage medium.
  • the terminal may find the appropriate device file, for example, by searching for a device file that includes a device profile that corresponds to a particular device with which the terminal wishes to communicate.
  • a user may be contacted with a list of potential devices and asked to choose the device with which to communicate.
  • a terminal may obtain a device profile from the device file or elsewhere on the storage medium.
  • a device stack may be built.
  • the device stack may be, for example, software that is configured to facilitate communication by simulating a connection to the device.
  • the device stack may be built, for example, by the operating system based on the device profile obtained from the storage medium.
  • the device stack may include, for example, a virtual layer configured to simulate the operation of the device and a driver configured to communicate between the storage medium the operating system or a content application.
  • one or more segment(s) may be read from the device file.
  • Reading segment(s) 506 may include, for example,
  • one or more segments may be read from the device file.
  • the segment(s) read may include, for example, one or more requests and/or responses.
  • the requests and/or responses include one or more media transfer entities.
  • the requests and responses read from the storage medium may include media content or an indication of content transfer, such as a request for content, a result code indicating successful content transfer, header information, or other information.
  • step 507 action may be taken on the content.
  • action taken on the content is performed via the terminal.
  • the terminal is therefore responsible, for example, for actions such as compressing the content, adding metadata to the content, performing DRM functions associated with the content, or performing other actions to facilitate communication between the device and the terminal.
  • Taking action on the content 507 may be performed, for example, in communication with a DRM engine or other protected content engine, an operating system, and/or a content application.
  • taking action on the content may include processing the received content and storing it in the terminal. For example, metadata may be added or DRM functions may be performed prior to storing received content in the terminal.
  • taking action on the content may include processing content to be transmitted to the device. For example, content may be retrieved from local storage on the terminal, and the content may be compressed or DRM functions may be performed in preparation for transmitting the content to the device.
  • a plurality of DRM engines may be provided for handling various DRM schemes.
  • an appropriate DRM engine may be selected for performing action on content.
  • An appropriate DRM engine may be selected, for example, for communication with a particular device.
  • the DRM engine may be selected based on the device profile or the device file.
  • an appropriate DRM engine may be selected based on user preferences or terminal parameters. In this case, preferences or parameters stored on the terminal may be used to select the DRM engine.
  • the DRM engine is an example of a protected content engine used in embodiments of the invention. Those skilled in the art will appreciate that other types of protected content engines used for protection and/or playback of protected content may be used.
  • one or more segments may be written to the storage medium.
  • the segment(s) written may include, for example, one or more requests and/or responses.
  • Writing segment(s) includes, for example, storing these requests and/or responses into the device file as a byte stream.
  • the requests and/or responses include one or more media transfer entities.
  • the requests and responses read from or written to the storage medium may include media content or an indication of content transfer, such as a request for content, a result code indicating successful content transfer, header information, or other information. Taking action on content 507 and writing segments to the device file 508 will be discussed further with reference to FIG. 6.
  • the terminal may delete unnecessary segments from the device file.
  • segments may be preserved within the device file while any requests in the segment do not have related responses within the same device file.
  • a segment should only be removed from the device file when the requests made by that segment have been acknowledged by the Initiator. In one implementation, this acknowledgement may not be formally given, so the segment may typically removed by the Initiator.
  • the terminal removes segments for which it was the Initiator. In another implementation, however, the Responder may remove a segment, for example, if the Initiator has made additional requests after receiving responses to all requests in the segment.
  • the storage medium may be removed from the terminal.
  • FIG. 6 is a block diagram illustrating an overview of a system in accordance with an embodiment of the present invention.
  • a terminal 202 may be configured to receive a storage medium 208, such as a memory card or magnetic disk, via an input 600, such as a card slot, disk drive, or the like.
  • the storage medium 208 may be used, for example, to communicate with a device (not shown in FIG. 6) by means of passing the storage medium 208 back and forth between the terminal 202 and the device.
  • the terminal 202 may include a content application 601 that communicates with the device via the storage medium 208.
  • the content application 601 may be a digital media player configured to communicate with a personal music player device.
  • the content application 601 is configured to transmit media files to, or receive media files from, the personal music player.
  • the content application 601 may be an application for storing and manipulating photographs.
  • the content application 601 may be configured to receive photographs from, or transmit photographs to, a camera device.
  • Other implementations including other content applications 601, other content types, and other devices are possible.
  • the terminal 202 also includes, for example, an operating system 602.
  • the operating system 602 may be configured to communicate with the device via the storage medium 208.
  • a device stack 604 may be created.
  • the device stack 604 is created by the operating system 602.
  • the device stack 604 is, for example, software that is configured to facilitate communication by simulating a connection to the device.
  • a device profile 302 may be read from a device file 212 on the storage medium 208 and stored in the terminal 202.
  • the device profile 302 may be or include, for example, parameters specifying properties or attributes of the device, or otherwise describing the device.
  • the device profile 302 may include such information as the type of device, the type of content accepted by the device, the compression schemes used by the device, available memory on the device, Digital Rights Management information for the device, and the like.
  • the device profile 302 may be written to the storage medium 208, for example, by the device during formatting.
  • a virtual layer 608 may be created, for example, based on the device profile.
  • the virtual layer 608 simulates the operation of the device.
  • the combination of the device file 212 and the virtual layer 608 may be said to comprise a "virtual device.”
  • the operation of the virtual device may be such that, from the perspective of the terminal 202, the device appears to actually be connected to the terminal 202.
  • the device stack may also contain a driver 612.
  • the driver 612 is, for example, a software module configured to communicate between the storage medium 208 and the content application 601 or the operating system 602.
  • the driver 612 receives a device file 212 from the storage medium 208 or otherwise accesses the device file 212 on the storage medium 208.
  • the driver 612 may also receive information and/or instructions from the content application 601 and/or the operating system 602. Based on the information in the device file 212, the information received from the content application 601, and/or the information received from the operating system 602, the driver 212 determines whether content should be transmitted from the device file 212 to the terminal 202, and whether content should be transmitted from the terminal 202 to the device file 212. [0083] If the driver 612 determines that content should be written from the device file 212 to the terminal 202, the driver 612 retrieves the content from the device file 212.
  • the driver 612 determines whether any action should be taken on the content.
  • the driver 612 determines whether action should be taken on the content, for example, by examining the virtual layer 608, the content application 601, and/or the operating system 602. Examples of action taken on content include, for example, compressing the content, adding metadata to the content, performing DRM functions associated with the content, or the like. If action should be taken on the content, the driver 612 performs such action, for example, by examining the virtual layer 608. In performing action on the content, the driver 612 may communicate with one or more DRM engines 614. After action is taken on the content, the modified content may be stored, for example, to a database 616.
  • One or more transfer protocol entities indicating the operations that occurred may be written to the device file 212.
  • the driver 612 determines that content should be written from the terminal 202 to the device file 212, the driver 612 retrieves the content, for example, from the database 616, the content application 601, or another location within the terminal 202. The driver 612 then determines whether any action should be taken on the content. The driver 612 determines whether action should be taken on the content, for example, by examining the virtual layer 608, the content application 601, and/or the operating system 602.
  • Examples of action taken on content include, for example, compressing the content, adding metadata to the content, performing DRM functions associated with the content, or the like. If action should be taken on the content, the driver 612 performs such action, for example, by examining the virtual layer 608. In performing action on the content, the driver 612 may communicate with one or more DRM engines 614. After action is taken on the content, the modified content may be written, for example, to the device file 212. The modified content is stored, for example, as a bit stream in the device file 212. The modified content may be stored, for example, in conjunction with header data, transfer protocol entities, or other data. [0085] In one implementation, the driver 612 may communicate with a plurality of DRM engines 614.
  • the driver 612 and/or the virtual layer 608 may select an appropriate DRM engine 614 for performing action on content.
  • An appropriate DRM engine 614 may be selected for communication with a particular device. In this case, the DRM engine may be selected based on the device profile, the device file 212 or the virtual layer 608. Furthermore, an appropriate DRM engine 614 may be selected based on user preferences or terminal parameters. In this case, preferences or parameters stored on the terminal 202 may be used to select the DRM engine 614 for performing action on content. [0086] Because content may be modified on the terminal 202, the content stored in the device file 212 may be matched to the stream parameters, DRM model, and other expectations of the device. This may result in a smooth user experience that allows playback or other content consumption on the device with little or no input required from a user.
  • an accelerator can be used in conjunction with the invention.
  • an accelerator may write an accelerator file to the storage medium, for example, as media content storage is being completed.
  • the accelerator file may provide content metadata that may be accessed, for example, by a user interface for the device.
  • An accelerator scheme used in conjunction with the present invention may be, for example, independent of the block file system which is used to format the card.
  • an accelerator file such as, for example, a device-optimized metadata database, may be used.
  • other accelerators may be used.
  • Implementations provide a coherent user experience by providing the terminal an accurate snapshot of the device parameters at the time when it runs the content. Implementations provide a standard scheme of encoding the device parameters, which allows the terminal to enable optimal device operation when transfer is done via a storage medium. The terminal can therefore create an accelerator file for use by the device, as well as taking action on media content to prepare the media content for the device.
  • a plurality of terminals could use the storage medium to communicate with each other and/or with external devices.
  • terminal profiles identifying a terminal involved in a communication session could be stored instead of, or in addition to, the device profiles 302.
  • a plurality of devices could use the storage medium to communicate with each other.
  • two or more device profiles 302 could be included in, or associated with, each device file 212.
  • OBEX Object Exchange
  • PTP Picture Transfer Protocol
  • IrMC Infrared Mobile Communications
  • WebDAV Web-based Distributed Authoring and Versioning
  • FTP File Transfer Protocol
  • HTTP Hyper Text Transfer Protocol

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Computer Security & Cryptography (AREA)
  • Software Systems (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Computer And Data Communications (AREA)
  • Television Signal Processing For Recording (AREA)
  • Storage Device Security (AREA)
PCT/US2006/015670 2005-06-17 2006-04-26 Serialization of media transfer communications WO2006137973A2 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
KR1020127032231A KR101278767B1 (ko) 2005-06-17 2006-04-26 미디어 전송 통신의 직렬화
EP06751399.4A EP1896950A4 (en) 2005-06-17 2006-04-26 SERIALIZATION OF MULTIMEDIA TRANSFER COMMUNICATIONS
CN200680020705.3A CN101194234B (zh) 2005-06-17 2006-04-26 媒体传送通信的串行化
JP2008516869A JP4907651B2 (ja) 2005-06-17 2006-04-26 メディア転送通信の直列化

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US11/154,633 2005-06-17
US11/154,633 US8239544B2 (en) 2005-06-17 2005-06-17 Removable storage content transfer
US11/167,587 2005-06-28
US11/167,587 US20060288165A1 (en) 2005-06-17 2005-06-28 Serialization of media transfer communications

Publications (2)

Publication Number Publication Date
WO2006137973A2 true WO2006137973A2 (en) 2006-12-28
WO2006137973A3 WO2006137973A3 (en) 2007-07-12

Family

ID=37570926

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2006/015670 WO2006137973A2 (en) 2005-06-17 2006-04-26 Serialization of media transfer communications

Country Status (7)

Country Link
US (1) US20060288165A1 (zh)
EP (1) EP1896950A4 (zh)
JP (1) JP4907651B2 (zh)
KR (2) KR101278767B1 (zh)
CN (1) CN101894081B (zh)
TW (1) TWI399691B (zh)
WO (1) WO2006137973A2 (zh)

Families Citing this family (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8239544B2 (en) * 2005-06-17 2012-08-07 Microsoft Corporation Removable storage content transfer
EP1942437A4 (en) * 2005-10-26 2012-08-01 Panasonic Corp DATA PROCESSING DEVICE
KR101319189B1 (ko) * 2006-03-03 2013-10-16 삼성전자주식회사 세션별 동시 다중 PoC 멀티미디어 서비스 제공 방법과단말기 및 그 시스템
US8369971B2 (en) * 2006-04-11 2013-02-05 Harman International Industries, Incorporated Media system having preemptive digital audio and/or video extraction function
US20090222602A1 (en) * 2008-02-28 2009-09-03 Broadcom Corporation Optimized data transfer between a portable device and a remote computer
US20090222588A1 (en) * 2008-02-28 2009-09-03 Broadcom Corporation Portable device and remote computer synchronization
US8671215B2 (en) * 2008-02-28 2014-03-11 Broadcom Corporation Portable communications framework
US8788634B2 (en) 2008-02-28 2014-07-22 Broadcom Corporation Portable device upgrade via a content transfer protocol
TWI425414B (zh) * 2008-08-29 2014-02-01 Chi Mei Comm Systems Inc 移動終端及其快速顯示圖形的方法
US9215255B2 (en) * 2008-12-18 2015-12-15 Google Technology Holdings LLC Transfer method and apparatus for seamless content transfer
JP2010150032A (ja) * 2008-12-26 2010-07-08 Fujitsu Ltd 段差解消装置及び段差解消方法
US8856414B2 (en) * 2009-06-03 2014-10-07 Lsi Corporation Determining required software components for SCSI system initialization
JP5728167B2 (ja) * 2010-05-12 2015-06-03 キヤノン株式会社 情報処理装置およびその制御方法、コンピュータプログラム
MY168816A (en) * 2011-07-20 2018-12-04 Aviat Networks Inc Systems and methods of network synchronization
US10210326B2 (en) * 2016-06-20 2019-02-19 Vmware, Inc. USB stack isolation for enhanced security
EP3511799B1 (en) * 2018-01-16 2022-08-03 Nokia Technologies Oy An apparatus, system and method for communicating data
CN109656880A (zh) * 2018-12-20 2019-04-19 努比亚技术有限公司 一种镜像文件系统解耦方法及装置、移动终端及存储介质

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4780601A (en) 1985-07-02 1988-10-25 Smh Alcatel Control system for franking machines

Family Cites Families (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5715164A (en) * 1994-12-14 1998-02-03 Ascom Hasler Mailing Systems Ag System and method for communications with postage meters
NL1002733C2 (nl) * 1996-03-28 1997-09-30 Gerrit Vriend Informatienetwerk en een in een dergelijk netwerk toepasbare elektronische kaart.
TW357307B (en) * 1997-04-01 1999-05-01 Mitac Int Corp Method of automated file transmission in networks
CN1229728C (zh) * 1999-06-30 2005-11-30 三得利株式会社 具有会话管理和分布式管理功能以及相应的操作管理机制的web应用系统
US6553223B1 (en) * 1999-12-30 2003-04-22 Qualcomm Incorporated Virtual device architecture for mobile telephones
KR100544177B1 (ko) * 2000-01-18 2006-01-23 삼성전자주식회사 컴퓨터를 통한 디지털 컨텐츠의 저장 및 재생 기능을구비한 개인 휴대 장치의 제어방법 및 이에 따른 개인휴대장치의 동작방법
WO2001069548A1 (de) * 2000-03-15 2001-09-20 Swisscom Mobile Ag Verfahren zur verbreitung von parametern in offline chipkarten-terminals, sowie dazu geeignete chipkarten-terminals und benutzerchipkarten
JP4524480B2 (ja) 2000-11-24 2010-08-18 三洋電機株式会社 データ端末装置
US6900980B2 (en) * 2001-05-02 2005-05-31 Palm, Inc. Synchronization cradle with expansion card slots
TW548924B (en) * 2001-08-16 2003-08-21 Inventec Appliances Corp Mutual data transmission method between digital camera and portable electronic communication apparatus
US20080086494A1 (en) * 2006-09-11 2008-04-10 Apple Computer, Inc. Transfer and synchronization of media data
US8150937B2 (en) * 2004-10-25 2012-04-03 Apple Inc. Wireless synchronization between media player and host device
JP4309153B2 (ja) * 2003-02-27 2009-08-05 サンデン株式会社 自動販売機及び自動販売機の運用データ移行プログラムを記録した記録媒体
WO2005086583A2 (en) * 2004-03-18 2005-09-22 M-Systems Flash Disk Pioneers Ltd. System, apparatus and method for sharing media
US20060080415A1 (en) * 2004-08-27 2006-04-13 Tu Edgar A Methods and apparatuses for automatically synchronizing a profile across multiple devices
JP2006092242A (ja) * 2004-09-24 2006-04-06 Fuji Xerox Co Ltd 遠隔会議システム、拠点サーバ、管理サーバ、遠隔会議管理方法及びプログラム

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4780601A (en) 1985-07-02 1988-10-25 Smh Alcatel Control system for franking machines

Also Published As

Publication number Publication date
US20060288165A1 (en) 2006-12-21
TWI399691B (zh) 2013-06-21
CN101894081A (zh) 2010-11-24
KR20130012139A (ko) 2013-02-01
TW200701051A (en) 2007-01-01
CN101894081B (zh) 2015-11-25
KR101261660B1 (ko) 2013-05-06
KR101278767B1 (ko) 2013-06-25
KR20080028879A (ko) 2008-04-02
EP1896950A4 (en) 2013-05-22
WO2006137973A3 (en) 2007-07-12
EP1896950A2 (en) 2008-03-12
JP2008547083A (ja) 2008-12-25
JP4907651B2 (ja) 2012-04-04

Similar Documents

Publication Publication Date Title
US20060288165A1 (en) Serialization of media transfer communications
JP6619700B2 (ja) ネットワーク・インターフェイス装置を使用しネットワークを介してメディアを転送するための方法及び装置
US8239544B2 (en) Removable storage content transfer
JP4644249B2 (ja) 記憶オブジェクトのプロパティ検索を最適化するシステムおよび方法
RU2427026C2 (ru) Специфическая для устройства индексация содержимого для оптимизированной работы устройства
CN101682634B (zh) 用于基于事务的通信的文件协议
CN1870642B (zh) 用于通过使用数据通信协议在网络计算环境内通信的方法
EP1475940A2 (en) System and method for facilitating communication between a computing device and multiple categories of media devices
JP2007527575A (ja) コンテンツを同期及び識別する方法及び装置
CN109451079B (zh) 一种云u盘及其存储方法和存储系统
WO2006088496A2 (en) System and method for extensible metadata architecture for digital images
US20080005028A1 (en) Contents metadata registering method, registering system, and registering program
EP2400402A1 (en) Management of media files
US20060047817A1 (en) Digital media receiver having a reader
KR20100001622A (ko) 섬네일 데이터 운용 방법과 이를 위한 기록매체

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 200680020705.3

Country of ref document: CN

121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 2006751399

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 2008516869

Country of ref document: JP

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 1020077029460

Country of ref document: KR

NENP Non-entry into the national phase

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 1020127032231

Country of ref document: KR