38
© 2011 Microchip Technology Inc. DS21143C-page 1 HCS301 FEATURES Security Programmable 28-bit serial number Programmable 64-bit encryption key Each transmission is unique 66-bit transmission code length 32-bit hopping code 34-bit fixed code (28-bit serial number, 4-bit button code, 2-bit status) Encryption keys are read protected Operating 3.5V - 13.0V operation Four button inputs No additional circuitry required 15 functions available Selectable baud rate Automatic code word completion Battery low signal transmitted to receiver Battery low indication on LED Non-volatile synchronization data Other Functionally identical to HCS300 Easy-to-use programming interface On-chip EEPROM On-chip oscillator and timing components Button inputs have internal pull-down resistors Current limiting on LED output Low external component cost Typical Applications The HCS301 is ideal for Remote Keyless Entry (RKE) applications. These applications include: Automotive RKE systems Automotive alarm systems Automotive immobilizers Gate and garage door openers Identity tokens Burglar alarm systems DESCRIPTION The HCS301 from Microchip Technology Inc. is a code hopping encoder designed for secure Remote Keyless Entry (RKE) systems. The HCS301 utilizes the KEELOQ ® code hopping technology, which incorpo- rates high security, a small package outline and low cost, to make this device a perfect solution for unidirec- tional remote keyless entry systems and access control systems. PACKAGE TYPES HCS301 BLOCK DIAGRAM The HCS301 combines a 32-bit hopping code, generated by a nonlinear encryption algorithm, with a 28-bit serial number and 6 information bits to create a 66-bit code word. The code word length eliminates the threat of code scanning and the code hopping mecha- nism makes each transmission unique, thus rendering code capture and resend schemes useless. 1 2 3 4 8 7 6 5 S0 S1 S2 S3 VDD LED PWM VSS PDIP, SOIC HCS301 VSS VDD Oscillator RESET circuit LED driver Controller Power latching and switching Button input port 32-bit shift register Encoder EEPROM PWM LED S3 S2 S1 S0 KEELOQ ® Code Hopping Encoder

HCS301 - KeeLoQ Code Hopping Encoder - Farnell · 2016. 7. 26. · access to keys or manipulate synchronization values. The HCS301 provides an easy-to-use serial interface for programming

  • Upload
    others

  • View
    3

  • Download
    0

Embed Size (px)

Citation preview

  • HCS301KEELOQ® Code Hopping Encoder

    FEATURES

    Security• Programmable 28-bit serial number• Programmable 64-bit encryption key• Each transmission is unique• 66-bit transmission code length• 32-bit hopping code• 34-bit fixed code (28-bit serial number,

    4-bit button code, 2-bit status)• Encryption keys are read protected

    Operating• 3.5V - 13.0V operation• Four button inputs• No additional circuitry required• 15 functions available • Selectable baud rate• Automatic code word completion• Battery low signal transmitted to receiver• Battery low indication on LED• Non-volatile synchronization data

    Other• Functionally identical to HCS300• Easy-to-use programming interface• On-chip EEPROM• On-chip oscillator and timing components• Button inputs have internal pull-down resistors• Current limiting on LED output• Low external component cost

    Typical ApplicationsThe HCS301 is ideal for Remote Keyless Entry (RKE)applications. These applications include:

    • Automotive RKE systems• Automotive alarm systems• Automotive immobilizers• Gate and garage door openers • Identity tokens• Burglar alarm systems

    DESCRIPTIONThe HCS301 from Microchip Technology Inc. is a codehopping encoder designed for secure Remote KeylessEntry (RKE) systems. The HCS301 utilizes theKEELOQ® code hopping technology, which incorpo-rates high security, a small package outline and lowcost, to make this device a perfect solution for unidirec-tional remote keyless entry systems and access controlsystems.

    PACKAGE TYPES

    HCS301 BLOCK DIAGRAM

    The HCS301 combines a 32-bit hopping code,generated by a nonlinear encryption algorithm, with a28-bit serial number and 6 information bits to create a66-bit code word. The code word length eliminates thethreat of code scanning and the code hopping mecha-nism makes each transmission unique, thus renderingcode capture and resend schemes useless.

    1

    2

    3

    4

    8

    7

    6

    5

    S0

    S1

    S2

    S3

    VDD

    LED

    PWM

    VSS

    PDIP, SOIC

    HC

    S301

    VSS

    VDD

    Oscillator

    RESET circuit

    LED driver

    Controller

    Powerlatchingandswitching

    Button input port

    32-bit shift register

    EncoderEEPROM

    PWM

    LED

    S3 S2 S1 S0

    © 2011 Microchip Technology Inc. DS21143C-page 1

  • HCS301

    The crypt key, serial number and configuration data arestored in an EEPROM array which is not accessible viaany external connection. The EEPROM data is pro-grammable but read-protected. The data can be veri-fied only after an automatic erase and programmingoperation. This protects against attempts to gainaccess to keys or manipulate synchronization values.The HCS301 provides an easy-to-use serial interfacefor programming the necessary keys, system parame-ters and configuration data.

    1.0 SYSTEM OVERVIEWKey TermsThe following is a list of key terms used throughout thisdata sheet. For additional information on KEELOQ andCode Hopping, refer to Technical Brief 3 (TB003).

    • RKE - Remote Keyless Entry• Button Status - Indicates what button input(s)

    activated the transmission. Encompasses the 4 button status bits S3, S2, S1 and S0 (Figure 4-2).

    • Code Hopping - A method by which a code, viewed externally to the system, appears to change unpredictably each time it is transmitted.

    • Code word - A block of data that is repeatedly transmitted upon button activation (Figure 4-1).

    • Transmission - A data stream consisting of repeating code words (Figure 9-2).

    • Crypt key - A unique and secret 64-bit number used to encrypt and decrypt data. In a symmetri-cal block cipher such as the KEELOQ algorithm, the encryption and decryption keys are equal and will therefore be referred to generally as the crypt key.

    • Encoder - A device that generates and encodes data.

    • Encryption Algorithm - A recipe whereby data is scrambled using a crypt key. The data can only be interpreted by the respective decryption algorithm using the same crypt key.

    • Decoder - A device that decodes data received from an encoder.

    • Decryption algorithm - A recipe whereby data scrambled by an encryption algorithm can be unscrambled using the same crypt key.

    • Learn – Learning involves the receiver calculating the transmitter’s appropriate crypt key, decrypting the received hopping code and storing the serial number, synchronization counter value and crypt key in EEPROM. The KEELOQ product family facil-itates several learning strategies to be imple-mented on the decoder. The following are examples of what can be done. - Simple Learning

    The receiver uses a fixed crypt key, common to all components of all systems by the same manufacturer, to decrypt the received code word’s encrypted portion.

    - Normal LearningThe receiver uses information transmitted during normal operation to derive the crypt key and decrypt the received code word’s encrypted portion.

    - Secure LearnThe transmitter is activated through a special button combination to transmit a stored 60-bit seed value used to generate the transmitter’s crypt key. The receiver uses this seed value to derive the same crypt key and decrypt the received code word’s encrypted portion.

    • Manufacturer’s code – A unique and secret 64-bit number used to generate unique encoder crypt keys. Each encoder is programmed with a crypt key that is a function of the manufacturer’s code. Each decoder is programmed with the manufac-turer code itself.

    The HCS301 code hopping encoder is designed specif-ically for keyless entry systems; primarily vehicles andhome garage door openers. The encoder portion of akeyless entry system is integrated into a transmitter,carried by the user and operated to gain access to avehicle or restricted area. The HCS301 is meant to bea cost-effective yet secure solution to such systems,requiring very few external components (Figure 2-1).

    Most low-end keyless entry transmitters are given afixed identification code that is transmitted every time abutton is pushed. The number of unique identificationcodes in a low-end system is usually a relatively smallnumber. These shortcomings provide an opportunityfor a sophisticated thief to create a device that ‘grabs’a transmission and retransmits it later, or a device thatquickly ‘scans’ all possible identification codes until thecorrect one is found.

    The HCS301, on the other hand, employs the KEELOQcode hopping technology coupled with a transmissionlength of 66 bits to virtually eliminate the use of code‘grabbing’ or code ‘scanning’. The high security level ofthe HCS301 is based on the patented KEELOQ technol-ogy. A block cipher based on a block length of 32 bitsand a key length of 64 bits is used. The algorithmobscures the information in such a way that even if thetransmission information (before coding) differs by onlyone bit from that of the previous transmission, the next

    DS21143C-page 2 © 2011 Microchip Technology Inc.

  • HCS301

    coded transmission will be completely different. Statis-tically, if only one bit in the 32-bit string of informationchanges, greater than 50 percent of the coded trans-mission bits will change.

    As indicated in the block diagram on page one, theHCS301 has a small EEPROM array which must beloaded with several parameters before use; most oftenprogrammed by the manufacturer at the time of produc-tion. The most important of these are:

    • A 28-bit serial number, typically unique for every encoder

    • A crypt key• An initial 16-bit synchronization value• A 16-bit configuration value

    The crypt key generation typically inputs the transmitterserial number and 64-bit manufacturer’s code into thekey generation algorithm (Figure 1-1). The manufac-turer’s code is chosen by the system manufacturer andmust be carefully controlled as it is a pivotal part of theoverall system security.

    FIGURE 1-1: CREATION AND STORAGE OF CRYPT KEY DURING PRODUCTION

    The 16-bit synchronization counter is the basis behindthe transmitted code word changing for each transmis-sion; it increments each time a button is pressed. Dueto the code hopping algorithm’s complexity, each incre-ment of the synchronization value results in greaterthan 50% of the bits changing in the transmitted codeword.

    Figure 1-2 shows how the key values in EEPROM areused in the encoder. Once the encoder detects a buttonpress, it reads the button inputs and updates the syn-chronization counter. The synchronization counter andcrypt key are input to the encryption algorithm and theoutput is 32 bits of encrypted information. This data willchange with every button press, its value appearingexternally to ‘randomly hop around’, hence it is referredto as the hopping portion of the code word. The 32-bithopping code is combined with the button informationand serial number to form the code word transmitted tothe receiver. The code word format is explained ingreater detail in Section 4.0.

    A receiver may use any type of controller as a decoder,but it is typically a microcontroller with compatible firm-ware that allows the decoder to operate in conjunctionwith an HCS301 based transmitter. Section 7.0provides detail on integrating the HCS301 into a sys-tem.

    A transmitter must first be ‘learned’ by the receiverbefore its use is allowed in the system. Learningincludes calculating the transmitter’s appropriate cryptkey, decrypting the received hopping code and storingthe serial number, synchronization counter value andcrypt key in EEPROM.

    In normal operation, each received message of validformat is evaluated. The serial number is used to deter-mine if it is from a learned transmitter. If from a learnedtransmitter, the message is decrypted and the synchro-nization counter is verified. Finally, the button status ischecked to see what operation is requested. Figure 1-3shows the relationship between some of the valuesstored by the receiver and the values received fromthe transmitter.

    Transmitter

    Manufacturer’s

    Serial Number

    CodeCrypt Key

    KeyGenerationAlgorithm

    Serial NumberCrypt KeySync Counter

    ..

    .

    HCS301ProductionProgrammer

    EEPROM Array

    © 2011 Microchip Technology Inc. DS21143C-page 3

  • HCS301

    FIGURE 1-2: BUILDING THE TRANSMITTED CODE WORD (ENCODER)

    FIGURE 1-3: BASIC OPERATION OF RECEIVER (DECODER)

    NOTE: Circled numbers indicate the order of execution.

    Button PressInformation

    EEPROM Array

    32 Bits Encrypted DataSerial Number

    Transmitted Information

    Crypt Key

    Sync Counter

    Serial Number

    KEELOQ®EncryptionAlgorithm

    Button Press Information

    EEPROM Array

    Manufacturer Code 32 Bits of Encrypted DataSerial Number

    Received Information

    DecryptedSynchronization Counter

    Check for Match

    Sync Counter

    Serial Number

    KEELOQ®DecryptionAlgorithm

    1

    3

    4

    Check for Match2

    Perform Function Indicated by button press 5

    Crypt Key

    DS21143C-page 4 © 2011 Microchip Technology Inc.

  • HCS301

    2.0 DEVICE OPERATIONAs shown in the typical application circuits (Figure 2-1),the HCS301 is a simple device to use. It requires onlythe addition of buttons and RF circuitry for use as thetransmitter in your security application. A description ofeach pin is given in Table 2-1.

    FIGURE 2-1: TYPICAL CIRCUITS

    TABLE 2-1: PIN DESCRIPTIONS

    The HCS301 will wake-up upon detecting a buttonpress and delay approximately 10 ms for buttondebounce (Figure 2-2). The synchronization counter,discrimination value and button information will beencrypted to form the hopping code. The hopping codeportion will change every transmission, even if thesame button is pushed again. A code word that hasbeen transmitted will not repeat for more than 64Ktransmissions. This provides more than 18 years of usebefore a code is repeated; based on 10 operations perday. Overflow information sent from the encoder can beused to extend the number of unique transmissions tomore than 192K.

    If in the transmit process it is detected that a new but-ton(s) has been pressed, a RESET will immediatelyoccur and the current code word will not be completed.Please note that buttons removed will not have anyeffect on the code word unless no buttons remainpressed; in which case the code word will be completedand the power-down will occur.

    Note: When VDD > 9.0V and driving low capaci-tive loads, a resistor with a minimum valueof 50Ω should be used in line with VDD.This prevents clamping of PWM at 9.0V inthe event of PWM overshoot.

    B0

    Tx out

    S0

    S1S2S3

    LED

    VDD

    PWMVSS

    2 button remote control

    B1

    Tx out

    S0

    S1S2S3

    LED

    VDD

    PWMVSS

    5 button remote control (1)

    B4 B3 B2 B1 B0

    Note 1: Up to 15 functions can be implemented by pressingmore than one button simultaneously or by using asuitable diode array.

    2: Resistor R is recommended for current limiting.

    +12V

    R

    +12V

    R

    (2)

    (2)

    Name PinNumber Description

    S0 1 Switch input 0

    S1 2 Switch input 1

    S2 3 Switch input 2 / Clock pin when inProgramming mode

    S3 4 Switch input 3

    VSS 5 Ground reference

    PWM 6 Pulse Width Modulation (PWM)output pin / Data pin forProgramming mode

    LED 7 Cathode connection for LED

    VDD 8 Positive supply voltage

    © 2011 Microchip Technology Inc. DS21143C-page 5

  • HCS301

    FIGURE 2-2: ENCODER OPERATION 3.0 EEPROM MEMORY

    ORGANIZATIONThe HCS301 contains 192 bits (12 x 16-bit words) ofEEPROM memory (Table 3-1). This EEPROM array isused to store the encryption key information,synchronization value, etc. Further descriptions of thememory array is given in the following sections.

    TABLE 3-1: EEPROM MEMORY MAP

    3.1 KEY_0 - KEY_3 (64-Bit Crypt Key)The 64-bit crypt key is used to create the encryptedmessage transmitted to the receiver. This key is calcu-lated and programmed during production using a keygeneration algorithm. The key generation algorithmmay be different from the KEELOQ algorithm. Inputs tothe key generation algorithm are typically the transmit-ter’s serial number and the 64-bit manufacturer’s code.While the key generation algorithm supplied fromMicrochip is the typical method used, a user may electto create their own method of key generation. This maybe done providing that the decoder is programmed withthe same means of creating the key fordecryption purposes.

    Power-Up

    RESET and Debounce Delay (10 ms)

    Sample Inputs

    Update Sync Info

    Encrypt With

    Load Transmit Register

    ButtonsAdded

    ?

    AllButtons

    Released?

    (A button has been pressed)

    Transmit

    Stop

    No

    Yes

    No

    Yes

    Crypt Key

    Complete Code Word Transmission

    WORD ADDRESS MNEMONIC DESCRIPTION

    0 KEY_0 64-bit encryption key(word 0) LSb’s

    1 KEY_1 64-bit encryption key(word 1)

    2 KEY_2 64-bit encryption key(word 2)

    3 KEY_3 64-bit encryption key(word 3) MSb’s

    4 SYNC 16-bit synchronizationvalue

    5 RESERVED Set to 0000H

    6 SER_0 Device Serial Number(word 0) LSb’s

    7 SER_1(Note) Device Serial Number(word 1) MSb’s

    8 SEED_0 Seed Value (word 0)

    9 SEED_1 Seed Value (word 1)

    10 RESERVED Set to 0000H

    11 CONFIG Config Word

    Note: The MSB of the serial number contains a bit used to select the Auto-shutoff timer.

    DS21143C-page 6 © 2011 Microchip Technology Inc.

  • HCS301

    3.2 SYNC (Synchronization Counter)This is the 16-bit synchronization value that is used tocreate the hopping code for transmission. This valuewill increment after every transmission.

    3.3 ReservedMust be initialized to 0000H.

    3.4 SER_0, SER_1 (Encoder Serial Number)

    SER_0 and SER_1 are the lower and upper words ofthe device serial number, respectively. Although thereare 32 bits allocated for the serial number, only thelower order 28 bits are transmitted. The serial numberis meant to be unique for every transmitter.

    3.4.1 AUTO-SHUTOFF TIMER ENABLE

    The Most Significant bit of the serial number (Bit 31) isused to turn the Auto-shutoff timer on or off. This timerprevents the transmitter from draining the batteryshould a button get stuck in the on position for a longperiod of time. The time period is approximately25 seconds, after which the device will go to the Time-out mode. When in the Time-out mode, the device willstop transmitting, although since some circuits withinthe device are still active, the current draw within theShutoff mode will be higher than Standby mode. If theMost Significant bit in the serial number is a one, thenthe Auto-shutoff timer is enabled, and a zero in theMost Significant bit will disable the timer. The length ofthe timer is not selectable.

    3.5 SEED_0, SEED_1 (Seed Word)The 2-word (32-bit) seed code will be transmitted whenall three buttons are pressed at the same time (seeFigure 4-2). This allows the system designer to imple-ment the secure learn feature or use this fixed codeword as part of a different key generation/tracking pro-cess.

    3.6 CONFIG (Configuration Word)The Configuration Word is a 16-bit word stored inEEPROM array that is used by the device to storeinformation used during the encryption process, as wellas the status of option configurations. The followingsections further explain these bits.

    TABLE 3-2: CONFIGURATION WORD

    3.6.1 DISCRIMINATION VALUE (DISC0 TO DISC9)

    The discrimination value aids the post-decryptioncheck on the decoder end. It may be any value, but ina typical system it will be programmed as the 10 LeastSignificant bits of the serial number. Values other thanthis must be separately stored by the receiver when atransmitter is learned. The discrimination bits are partof the information that form the encrypted portion of thetransmission (Figure 4-2). After the receiver hasdecrypted a transmission, the discrimination bits arechecked against the receiver’s stored value to verifythat the decryption process was valid. If the discrimina-tion value was programmed as the 10 LSb’s of theserial number then it may merely be compared to therespective bits of the received serial number; savingEEPROM space.

    3.6.2 OVERFLOW BITS (OVR0, OVR1)

    The overflow bits are used to extend the number ofpossible synchronization values. The synchronizationcounter is 16 bits in length, yielding 65,536 valuesbefore the cycle repeats. Under typical use of10 operations a day, this will provide nearly 18 years ofuse before a repeated value will be used. Should thesystem designer conclude that is not adequate, thenthe overflow bits can be utilized to extend the number

    Bit Number Bit Description0 Discrimination Bit 01 Discrimination Bit 12 Discrimination Bit 23 Discrimination Bit 34 Discrimination Bit 45 Discrimination Bit 56 Discrimination Bit 67 Discrimination Bit 78 Discrimination Bit 89 Discrimination Bit 910 Overflow Bit 0 (OVR0)11 Overflow Bit 1 (OVR1)12 Low Voltage Trip Point Select

    (VLOW SEL)13 Baud rate Select Bit 0 (BSL0)14 Baud rate Select Bit 1 (BSL1)15 Reserved, set to 0

    © 2011 Microchip Technology Inc. DS21143C-page 7

  • HCS301

    of unique values. This can be done by programmingOVR0 and OVR1 to 1s at the time of production. Theencoder will automatically clear OVR0 the first time thatthe synchronization value wraps from 0xFFFF to0x0000 and clear OVR1 the second time the counterwraps. Once cleared, OVR0 and OVR1 cannot be setagain, thereby creating a permanent record of thecounter overflow. This prevents fast cycling of 64Kcounter. If the decoder system is programmed to trackthe overflow bits, then the effective number of uniquesynchronization values can be extended to 196,608.

    3.6.3 BAUD RATE SELECT BITS (BSL0, BSL1)

    BSL0 and BSL1 select the speed of transmission andthe code word blanking. Table 3-3 shows how the bitsare used to select the different baud rates andSection 5.7 provides detailed explanation in code wordblanking.

    TABLE 3-3: BAUD RATE SELECT

    3.6.4 LOW VOLTAGE TRIP POINT SELECT

    The low voltage trip point select bit is used to tell theHCS301 what VDD level is being used. This informationwill be used by the device to determine when to send thevoltage low signal to the receiver. When this bit is set toa one, the VDD level is assumed to be operating from a9V or 12V VDD level. If the bit is set low, then the VDD levelis assumed to be 6.0 volts. Refer to Figure 3-1 for volt-age trip point.

    FIGURE 3-1: VOLTAGE TRIP POINTS BY CHARACTERIZATION

    BSL1 BSL0 Basic Pulse ElementCode Words Transmitted

    0 0 400 μs All0 1 200 μs 1 out of 21 0 100 μs 1 out of 21 1 100 μs 1 out of 4

    -40 20 40 100

    8.5

    7.5

    8.0

    7.0

    9.0

    2.5

    3.0

    3.5

    4.0

    VLOW

    Temp (C)

    Volts (V)

    VLOW sel = 1

    VLOW sel = 0

    4.5

    -20 0 60 80

    5.0

    5.5

    Max

    Min

    Max

    Min

    DS21143C-page 8 © 2011 Microchip Technology Inc.

  • HCS301

    4.0 TRANSMITTED WORD

    4.1 Code Word FormatThe HCS301 code word is made up of several parts(Figure 4-1). Each code word contains a 50% dutycycle preamble, a header, 32 bits of encrypted data and34 bits of fixed data followed by a guard period beforeanother code word can begin. Refer to Table 9-4 forcode word timing.

    4.2 Code Word OrganizationThe HCS301 transmits a 66-bit code word when abutton is pressed. The 66-bit word is constructed froma Fixed Code portion and an Encrypted Code portion(Figure 4-2).

    The 32 bits of Encrypted Data are generated from 4button bits, 12 discrimination bits and the 16-bit syncvalue. The encrypted portion alone provides up to fourbillion changing code combinations.

    The 34 bits of Fixed Code Data are made up of 2 sta-tus bits, 4 button bits and the 28-bit serial number. Thefixed and encrypted sections combined increase thenumber of code combinations to 7.38 x 1019.

    FIGURE 4-1: CODE WORD FORMAT

    FIGURE 4-2: CODE WORD ORGANIZATION

    LOGIC ‘0’

    LOGIC ‘1’

    BitPeriod

    Preamble HeaderEncrypted Portion of Transmission

    Fixed Portion ofTransmission

    Guard Time

    TP TH THOP TFIX TG

    TETETE

    50% Duty Cycle

    Repeat(1 bit)

    VLOW(1 bit)

    Button Status

    S2 S1 S0 S3

    Serial Number(28 bits)

    Button Status

    S2 S1 S0 S3

    OVR(2 bits)

    DISC(10 bits)

    Sync Counter(16 bits)

    Repeat(1 bit)

    VLOW(1 bit)

    Button Status

    1 1 1 1

    Serial Number(28 bits)

    SEED(32 bits)

    34 bits of Fixed Portion 32 bits of Encrypted Portion

    66 Data bitsTransmitted

    LSb first.

    LSbMSb

    MSb LSbNote: SEED replaces Encrypted Portion when all button inputs are activated at the same time.

    © 2011 Microchip Technology Inc. DS21143C-page 9

  • HCS301

    4.3 Synchronous Transmission ModeSynchronous Transmission mode can be used to clockthe code word out using an external clock.

    To enter Synchronous Transmission mode, the Pro-gramming mode start-up sequence must be executedas shown in Figure 4-3. If either S1 or S0 is set on thefalling edge of S2 (or S3), the device enters Synchro-nous Transmission mode. In this mode, it functions asa normal transmitter, with the exception that the timingof the PWM data string is controlled externally and 16extra bits are transmitted at the end with the code word.

    The button code will be the S0, S1 value at the fallingedge of S2 or S3. The timing of the PWM data string iscontrolled by supplying a clock on S2 or S3 and shouldnot exceed 20 kHz. The code word is the same as inPWM mode with 16 reserved bits at the end of theword. The reserved bits can be ignored. When in Syn-chronous Transmission mode S2 or S3 should not betoggled until all internal processing has been com-pleted as shown in Figure 4-4.

    FIGURE 4-3: SYNCHRONOUS TRANSMISSION MODE

    FIGURE 4-4: CODE WORD ORGANIZATION (SYNCHRONOUS TRANSMISSION MODE)

    “01,10,11”

    PWM

    S2

    S[1:0]

    TPS TPH1 TPH2 t = 50ms Preamble Header Data

    Reserved(16 bits)

    Padding(2 bits)

    Button Status

    S2 S1 S0 S3

    Serial Number(28 bits)

    Button Status

    S2 S1 S0 S3

    DISC+ OVR(12 bits)

    Sync Counter(16 bits)

    82 Data bitsTransmitted

    LSb first.

    LSbMSb

    Fixed Portion Encrypted Portion

    DS21143C-page 10 © 2011 Microchip Technology Inc.

  • HCS301

    5.0 SPECIAL FEATURES

    5.1 Code Word Completion The code word completion feature ensures that entirecode words are transmitted, even if the button isreleased before the code word is complete. If the but-ton is held down beyond the time for one code word,multiple code words will result. If another button is acti-vated during a transmission, the active transmissionwill be aborted and a new transmission will begin usingthe new button information.

    5.2 LED Output OperationDuring normal transmission the LED output is LOW. Ifthe supply voltage drops below the low voltage trippoint, the LED output will be toggled at approximately5Hz during the transmission (Section 3.6.4).

    5.3 RPT: Repeat Indicator This bit will be low for the first transmitted word. If abutton is held down for more than one transmitted codeword, this bit will be set to indicate a repeated codeword and remain set until the button is released.

    5.4 VLOW: Voltage LOW Indicator The VLOW signal is transmitted so the receiver can givean indication to the user that the transmitter battery islow. The VLOW bit is included in every transmission(Figure 4-2 and Figure 9-5) and will be transmitted as azero if the operating voltage is above the low voltagetrip point. Refer to Figure 4-2. The trip point is select-able based on the battery voltage being used. See Sec-tion 3.6.3 for a description of how the low voltage trippoint is configured.

    5.5 Auto-shutoffThe Auto-shutoff function automatically stops thedevice from transmitting if a button inadvertently getspressed for a long period of time. This will prevent thedevice from draining the battery if a button getspressed while the transmitter is in a pocket or purse.This function can be enabled or disabled and isselected by setting or clearing the Auto-shutoff bit (seeSection 3.4.1). Setting this bit high will enable the func-tion (turn Auto-shutoff function on) and setting the bitlow will disable the function. Time-out period is approx-imately 25 seconds.

    5.6 Seed TransmissionIn order to increase the level of security in a system, itis possible for the receiver to implement what is knownas a secure learn function. This can be done by utilizingthe seed value stored in EEPROM, transmitted onlywhen all three button inputs are pressed at the sametime (Table 5-1). Instead of the normal key generationinputs being used to create the crypt key, this seedvalue is used.

    TABLE 5-1: PIN ACTIVATION TABLE

    Function S3 S2 S1 S0

    Standby 0 0 0 0 0

    Hopping Code

    1 0 0 0 1

    2 0 0 1 0

    - - - - -

    13 1 1 0 1

    14 1 1 1 0

    Seed Code 15 1 1 1 1

    © 2011 Microchip Technology Inc. DS21143C-page 11

  • HCS301

    5.7 Blank Alternate Code Word Federal Communications Commission (FCC) part 15rules specify the limits on worst case average funda-mental power and harmonics that can be transmitted ina 100 ms window. For FCC approval purposes, it maytherefore be advantageous to minimize the transmis-sion duty cycle. This can be achieved by minimizing theduty cycle of the individual bits as well as by blankingout consecutive code words. Blank Alternate CodeWord (BACW) may be used to reduce the averagepower of a transmission by transmitting only every sec-

    ond code word (Figure 5-1). This is a selectable featurethat is determined in conjunction with the baud rateselection bit BSL0.

    Enabling the BACW option may likewise allow the userto transmit a higher amplitude transmission as the timeaveraged power is reduced. BACW effectively halvesthe RF on time for a given transmission so the RF out-put power could theoretically be doubled while main-taining the same time averaged output power.

    FIGURE 5-1: BLANK ALTERNATE CODE WORD (BACW)

    Code WordBACW Disabled(All words transmitted)

    BACW Enabled(1 out of 2 transmitted)

    BACW Enabled(1 out of 4 transmitted)

    A

    2A

    4A

    Amplitude

    Time

    Code Word Code Word Code Word

    DS21143C-page 12 © 2011 Microchip Technology Inc.

  • HCS301

    6.0 PROGRAMMING THE HCS301 When using the HCS301 in a system, the user will haveto program some parameters into the device includingthe serial number and the secret key before it can beused. The programming cycle allows the user to inputall 192 bits in a serial data stream, which are thenstored internally in EEPROM. Programming will beinitiated by forcing the PWM line high, after the S2 (orS3) line has been held high for the appropriate lengthof time line (Table 6-1 and Figure 6-1). After the Pro-gram mode is entered, a delay must be provided to thedevice for the automatic bulk write cycle to complete.This will set all locations in the EEPROM to zeros. Thedevice can then be programmed by clocking in 16 bitsat a time, using S2 (or S3) as the clock line and PWMas the data in line. After each 16-bit word is loaded, a

    programming delay is required for the internal programcycle to complete. This delay can take up to TWC. At theend of the programming cycle, the device can be veri-fied (Figure 6-2) by reading back the EEPROM. Read-ing is done by clocking the S2 (or S3) line and readingthe data bits on PWM. For security reasons, it is notpossible to execute a verify function without first pro-gramming the EEPROM. A Verify operation can onlybe done once, immediately following the Programcycle.

    FIGURE 6-1: PROGRAMMING WAVEFORMS

    FIGURE 6-2: VERIFY WAVEFORMS

    Note: To ensure that the device does not acci-dentally enter Programming mode, PWMshould never be pulled high by the circuitconnected to it. Special care should betaken when driving PNP RF transistors.

    PWM

    Enter Program Mode

    (Data)

    (Clock)

    Note 1: Unused button inputs to be held to ground during the entire programming sequence.

    Bit 0 Bit 1 Bit 2 Bit 3 Bit 14 Bit 15 Bit 16 Bit 17

    TPH1

    TPBW

    TPS

    Repeat for each word (12 times)TPH2

    TCLKH

    TCLKL

    TWCTDS

    S2 (S3)

    Data for Word 0 (KEY_0) Data for Word 1

    TDH

    2: The VDD pin must be taken to ground after a Program/Verify cycle.

    PWM

    (Clock)

    (Data)

    Note: If a Verify operation is to be done, then it must immediately follow the Program cycle.

    End of Programming Cycle Beginning of Verify Cycle

    Bit 1 Bit 2 Bit 3 Bit 15Bit 14 Bit 16 Bit 17 Bit190 Bit191

    TWC

    Data from Word 0

    TDVS2 (S3)

    Bit 0Bit191Bit190

    © 2011 Microchip Technology Inc. DS21143C-page 13

  • HCS301

    TABLE 6-1: PROGRAMMING/VERIFY TIMING REQUIREMENTS

    Note 1: Typical values - not tested in production.

    VDD = 5.0V ± 10%, 25 °C ± 5 °CParameter Symbol Min. Max. Units

    Program mode setup time TPS 3.5 4.5 msHold time 1 TPH1 3.5 — msHold time 2 TPH2 50 — μsBulk Write time TPBW 4.0 — msProgram delay time TPROG 4.0 — msProgram cycle time TWC 50 — msClock low time TCLKL 50 — μsClock high time TCLKH 50 — μsData setup time TDS 0 — μs(1)

    Data hold time TDH 30 — μs(1)

    Data out valid time TDV — 30 μs(1)

    DS21143C-page 14 © 2011 Microchip Technology Inc.

  • HCS301

    7.0 INTEGRATING THE HCS301 INTO A SYSTEM

    Use of the HCS301 in a system requires a compatibledecoder. This decoder is typically a microcontroller withcompatible firmware. Microchip will provide (via alicense agreement) firmware routines that accepttransmissions from the HCS301 and decrypt thehopping code portion of the data stream. Theseroutines provide system designers the means todevelop their own decoding system.

    7.1 Learning a Transmitter to a Receiver

    A transmitter must first be 'learned' by a decoder beforeits use is allowed in the system. Several learning strat-egies are possible, Figure 7-1 details a typical learnsequence. Core to each, the decoder must minimallystore each learned transmitter's serial number and cur-rent synchronization counter value in EEPROM. Addi-tionally, the decoder typically stores each transmitter'sunique crypt key. The maximum number of learnedtransmitters will therefore be relative to the availableEEPROM.

    A transmitter's serial number is transmitted in the clearbut the synchronization counter only exists in the codeword's encrypted portion. The decoder obtains thecounter value by decrypting using the same key usedto encrypt the information. The KEELOQ algorithm is asymmetrical block cipher so the encryption and decryp-tion keys are identical and referred to generally as thecrypt key. The encoder receives its crypt key duringmanufacturing. The decoder is programmed with theability to generate a crypt key as well as all but onerequired input to the key generation routine; typicallythe transmitter's serial number.

    Figure 7-1 summarizes a typical learn sequence. Thedecoder receives and authenticates a first transmis-sion; first button press. Authentication involves gener-ating the appropriate crypt key, decrypting, validatingthe correct key usage via the discrimination bits andbuffering the counter value. A second transmission isreceived and authenticated. A final check verifies thecounter values were sequential; consecutive buttonpresses. If the learn sequence is successfully com-plete, the decoder stores the learned transmitter'sserial number, current synchronization counter valueand appropriate crypt key. From now on the crypt keywill be retrieved from EEPROM during normal opera-tion instead of recalculating it for each transmissionreceived.

    Certain learning strategies have been patented andcare must be taken not to infringe.

    FIGURE 7-1: TYPICAL LEARN SEQUENCE

    Enter LearnMode

    Wait for Receptionof a Valid Code

    Generate Keyfrom Serial Number

    Use Generated Keyto Decrypt

    Compare DiscriminationValue with Fixed Value

    Equal

    Wait for Receptionof Second Valid Code

    Compare DiscriminationValue with Fixed Value

    Use Generated Key to Decrypt

    Equal

    Counters

    Encryption keySerial number

    Synchronization counter

    Sequential?

    ?

    ?

    Exit

    Learn successful Store: LearnUnsuccessful

    No

    No

    No

    Yes

    Yes

    Yes

    © 2011 Microchip Technology Inc. DS21143C-page 15

  • HCS301

    7.2 Decoder OperationFigure 7-2 summarizes normal decoder operation. Thedecoder waits until a transmission is received. Thereceived serial number is compared to the EEPROMtable of learned transmitters to first determine if thistransmitter's use is allowed in the system. If from alearned transmitter, the transmission is decryptedusing the stored crypt key and authenticated via thediscrimination bits for appropriate crypt key usage. Ifthe decryption was valid the synchronization value isevaluated.

    FIGURE 7-2: TYPICAL DECODER OPERATION

    7.3 Synchronization with Decoder (Evaluating the Counter)

    The KEELOQ technology patent scope includes asophisticated synchronization technique that does notrequire the calculation and storage of future codes. Thetechnique securely blocks invalid transmissions whileproviding transparent resynchronization to transmittersinadvertently activated away from the receiver.

    Figure 7-3 shows a 3-partition, rotating synchronizationwindow. The size of each window is optional but thetechnique is fundamental. Each time a transmission isauthenticated, the intended function is executed andthe transmission's synchronization counter value isstored in EEPROM. From the currently stored countervalue there is an initial "Single Operation" forward win-dow of 16 codes. If the difference between a receivedsynchronization counter and the last stored counter iswithin 16, the intended function will be executed on thesingle button press and the new synchronization coun-ter will be stored. Storing the new synchronizationcounter value effectively rotates the entire synchroniza-tion window.

    A "Double Operation" (resynchronization) window fur-ther exists from the Single Operation window up to 32Kcodes forward of the currently stored counter value. Itis referred to as "Double Operation" because a trans-mission with synchronization counter value in this win-dow will require an additional, sequential countertransmission prior to executing the intended function.Upon receiving the sequential transmission thedecoder executes the intended function and stores thesynchronization counter value. This resynchronizationoccurs transparently to the user as it is human natureto press the button a second time if the first was unsuc-cessful.

    The third window is a "Blocked Window" ranging fromthe double operation window to the currently storedsynchronization counter value. Any transmission withsynchronization counter value within this window willbe ignored. This window excludes previously used,perhaps code-grabbed transmissions from accessingthe system.

    ?

    TransmissionReceived

    DoesSerial Number

    Match?

    Decrypt Transmission

    IsDecryption

    Valid?

    IsCounter

    Within 16?

    IsCounter

    Within 32K?

    UpdateCounter

    ExecuteCommand

    Save Counterin Temp Location

    Start

    No

    No

    No

    No

    Yes

    Yes

    Yes

    Yes

    Yes

    No

    andNo

    Note: The synchronization method described inthis section is only a typical implementationand because it is usually implemented infirmware, it can be altered to fit the needsof a particular system.

    DS21143C-page 16 © 2011 Microchip Technology Inc.

  • HCS301

    FIGURE 7-3: SYNCHRONIZATION WINDOW

    Blocked

    Entire Window rotates to eliminateuse of previouslyused codes

    Single OperationWindow

    Window(32K Codes)

    (16 Codes)

    Double Operation(resynchronization)

    Window (32K Codes)

    StoredSynchronizationCounter Value

    © 2011 Microchip Technology Inc. DS21143C-page 17

  • HCS301

    8.0 DEVELOPMENT SUPPORTThe PIC® microcontrollers and dsPIC® digital signalcontrollers are supported with a full range of softwareand hardware development tools:

    • Integrated Development Environment- MPLAB® IDE Software

    • Compilers/Assemblers/Linkers- MPLAB C Compiler for Various Device

    Families- HI-TECH C for Various Device Families- MPASMTM Assembler- MPLINKTM Object Linker/

    MPLIBTM Object Librarian- MPLAB Assembler/Linker/Librarian for

    Various Device Families• Simulators

    - MPLAB SIM Software Simulator• Emulators

    - MPLAB REAL ICE™ In-Circuit Emulator• In-Circuit Debuggers

    - MPLAB ICD 3- PICkit™ 3 Debug Express

    • Device Programmers- PICkit™ 2 Programmer- MPLAB PM3 Device Programmer

    • Low-Cost Demonstration/Development Boards, Evaluation Kits, and Starter Kits

    8.1 MPLAB Integrated Development Environment Software

    The MPLAB IDE software brings an ease of softwaredevelopment previously unseen in the 8/16/32-bitmicrocontroller market. The MPLAB IDE is a Windows®operating system-based application that contains:

    • A single graphical interface to all debugging tools- Simulator- Programmer (sold separately)- In-Circuit Emulator (sold separately)- In-Circuit Debugger (sold separately)

    • A full-featured editor with color-coded context• A multiple project manager• Customizable data windows with direct edit of

    contents• High-level source code debugging• Mouse over variable inspection• Drag and drop variables from source to watch

    windows• Extensive on-line help• Integration of select third party tools, such as

    IAR C Compilers

    The MPLAB IDE allows you to:

    • Edit your source files (either C or assembly)• One-touch compile or assemble, and download to

    emulator and simulator tools (automatically updates all project information)

    • Debug using:- Source files (C or assembly)- Mixed C and assembly- Machine code

    MPLAB IDE supports multiple debugging tools in asingle development paradigm, from the cost-effectivesimulators, through low-cost in-circuit debuggers, tofull-featured emulators. This eliminates the learningcurve when upgrading to tools with increased flexibilityand power.

    DS21143C-page 18 © 2011 Microchip Technology Inc.

  • HCS301

    8.2 MPLAB C Compilers for Various

    Device FamiliesThe MPLAB C Compiler code development systemsare complete ANSI C compilers for Microchip’s PIC18,PIC24 and PIC32 families of microcontrollers and thedsPIC30 and dsPIC33 families of digital signal control-lers. These compilers provide powerful integrationcapabilities, superior code optimization and ease ofuse.

    For easy source level debugging, the compilers providesymbol information that is optimized to the MPLAB IDEdebugger.

    8.3 HI-TECH C for Various Device Families

    The HI-TECH C Compiler code development systemsare complete ANSI C compilers for Microchip’s PICfamily of microcontrollers and the dsPIC family of digitalsignal controllers. These compilers provide powerfulintegration capabilities, omniscient code generationand ease of use.

    For easy source level debugging, the compilers providesymbol information that is optimized to the MPLAB IDEdebugger.

    The compilers include a macro assembler, linker, pre-processor, and one-step driver, and can run on multipleplatforms.

    8.4 MPASM AssemblerThe MPASM Assembler is a full-featured, universalmacro assembler for PIC10/12/16/18 MCUs.

    The MPASM Assembler generates relocatable objectfiles for the MPLINK Object Linker, Intel® standard HEXfiles, MAP files to detail memory usage and symbolreference, absolute LST files that contain source linesand generated machine code and COFF files fordebugging.

    The MPASM Assembler features include:

    • Integration into MPLAB IDE projects• User-defined macros to streamline

    assembly code• Conditional assembly for multi-purpose

    source files• Directives that allow complete control over the

    assembly process

    8.5 MPLINK Object Linker/MPLIB Object Librarian

    The MPLINK Object Linker combines relocatableobjects created by the MPASM Assembler and theMPLAB C18 C Compiler. It can link relocatable objectsfrom precompiled libraries, using directives from alinker script.

    The MPLIB Object Librarian manages the creation andmodification of library files of precompiled code. Whena routine from a library is called from a source file, onlythe modules that contain that routine will be linked inwith the application. This allows large libraries to beused efficiently in many different applications.

    The object linker/library features include:

    • Efficient linking of single libraries instead of many smaller files

    • Enhanced code maintainability by grouping related modules together

    • Flexible creation of libraries with easy module listing, replacement, deletion and extraction

    8.6 MPLAB Assembler, Linker and Librarian for Various Device Families

    MPLAB Assembler produces relocatable machinecode from symbolic assembly language for PIC24,PIC32 and dsPIC devices. MPLAB C Compiler usesthe assembler to produce its object file. The assemblergenerates relocatable object files that can then bearchived or linked with other relocatable object files andarchives to create an executable file. Notable featuresof the assembler include:

    • Support for the entire device instruction set• Support for fixed-point and floating-point data• Command line interface• Rich directive set• Flexible macro language• MPLAB IDE compatibility

    © 2011 Microchip Technology Inc. DS21143C-page 19

  • HCS301

    8.7 MPLAB SIM Software SimulatorThe MPLAB SIM Software Simulator allows codedevelopment in a PC-hosted environment by simulat-ing the PIC MCUs and dsPIC® DSCs on an instructionlevel. On any given instruction, the data areas can beexamined or modified and stimuli can be applied froma comprehensive stimulus controller. Registers can belogged to files for further run-time analysis. The tracebuffer and logic analyzer display extend the power ofthe simulator to record and track program execution,actions on I/O, most peripherals and internal registers.

    The MPLAB SIM Software Simulator fully supportssymbolic debugging using the MPLAB C Compilers,and the MPASM and MPLAB Assemblers. The soft-ware simulator offers the flexibility to develop anddebug code outside of the hardware laboratory envi-ronment, making it an excellent, economical softwaredevelopment tool.

    8.8 MPLAB REAL ICE In-Circuit Emulator System

    MPLAB REAL ICE In-Circuit Emulator System isMicrochip’s next generation high-speed emulator forMicrochip Flash DSC and MCU devices. It debugs andprograms PIC® Flash MCUs and dsPIC® Flash DSCswith the easy-to-use, powerful graphical user interface ofthe MPLAB Integrated Development Environment (IDE),included with each kit.

    The emulator is connected to the design engineer’s PCusing a high-speed USB 2.0 interface and is connectedto the target with either a connector compatible with in-circuit debugger systems (RJ11) or with the new high-speed, noise tolerant, Low-Voltage Differential Signal(LVDS) interconnection (CAT5).

    The emulator is field upgradable through future firmwaredownloads in MPLAB IDE. In upcoming releases ofMPLAB IDE, new devices will be supported, and newfeatures will be added. MPLAB REAL ICE offerssignificant advantages over competitive emulatorsincluding low-cost, full-speed emulation, run-timevariable watches, trace analysis, complex breakpoints, aruggedized probe interface and long (up to three meters)interconnection cables.

    8.9 MPLAB ICD 3 In-Circuit Debugger System

    MPLAB ICD 3 In-Circuit Debugger System is Micro-chip's most cost effective high-speed hardwaredebugger/programmer for Microchip Flash Digital Sig-nal Controller (DSC) and microcontroller (MCU)devices. It debugs and programs PIC® Flash microcon-trollers and dsPIC® DSCs with the powerful, yet easy-to-use graphical user interface of MPLAB IntegratedDevelopment Environment (IDE).

    The MPLAB ICD 3 In-Circuit Debugger probe is con-nected to the design engineer's PC using a high-speedUSB 2.0 interface and is connected to the target with aconnector compatible with the MPLAB ICD 2 or MPLABREAL ICE systems (RJ-11). MPLAB ICD 3 supports allMPLAB ICD 2 headers.

    8.10 PICkit 3 In-Circuit Debugger/Programmer and PICkit 3 Debug Express

    The MPLAB PICkit 3 allows debugging and program-ming of PIC® and dsPIC® Flash microcontrollers at amost affordable price point using the powerful graphicaluser interface of the MPLAB Integrated DevelopmentEnvironment (IDE). The MPLAB PICkit 3 is connectedto the design engineer's PC using a full speed USBinterface and can be connected to the target via anMicrochip debug (RJ-11) connector (compatible withMPLAB ICD 3 and MPLAB REAL ICE). The connectoruses two device I/O pins and the reset line to imple-ment in-circuit debugging and In-Circuit Serial Pro-gramming™.

    The PICkit 3 Debug Express include the PICkit 3, demoboard and microcontroller, hookup cables and CDROMwith user’s guide, lessons, tutorial, compiler andMPLAB IDE software.

    DS21143C-page 20 © 2011 Microchip Technology Inc.

  • HCS301

    8.11 PICkit 2 Development

    Programmer/Debugger and PICkit 2 Debug Express

    The PICkit™ 2 Development Programmer/Debugger isa low-cost development tool with an easy to use inter-face for programming and debugging Microchip’s Flashfamilies of microcontrollers. The full featuredWindows® programming interface supports baseline(PIC10F, PIC12F5xx, PIC16F5xx), midrange(PIC12F6xx, PIC16F), PIC18F, PIC24, dsPIC30,dsPIC33, and PIC32 families of 8-bit, 16-bit, and 32-bitmicrocontrollers, and many Microchip Serial EEPROMproducts. With Microchip’s powerful MPLAB IntegratedDevelopment Environment (IDE) the PICkit™ 2enables in-circuit debugging on most PIC® microcon-trollers. In-Circuit-Debugging runs, halts and singlesteps the program while the PIC microcontroller isembedded in the application. When halted at a break-point, the file registers can be examined and modified.

    The PICkit 2 Debug Express include the PICkit 2, demoboard and microcontroller, hookup cables and CDROMwith user’s guide, lessons, tutorial, compiler andMPLAB IDE software.

    8.12 MPLAB PM3 Device ProgrammerThe MPLAB PM3 Device Programmer is a universal,CE compliant device programmer with programmablevoltage verification at VDDMIN and VDDMAX formaximum reliability. It features a large LCD display(128 x 64) for menus and error messages and a modu-lar, detachable socket assembly to support variouspackage types. The ICSP™ cable assembly is includedas a standard item. In Stand-Alone mode, the MPLABPM3 Device Programmer can read, verify and programPIC devices without a PC connection. It can also setcode protection in this mode. The MPLAB PM3connects to the host PC via an RS-232 or USB cable.The MPLAB PM3 has high-speed communications andoptimized algorithms for quick programming of largememory devices and incorporates an MMC card for filestorage and data applications.

    8.13 Demonstration/Development Boards, Evaluation Kits, and Starter Kits

    A wide variety of demonstration, development andevaluation boards for various PIC MCUs and dsPICDSCs allows quick application development on fully func-tional systems. Most boards include prototyping areas foradding custom circuitry and provide application firmwareand source code for examination and modification.

    The boards support a variety of features, including LEDs,temperature sensors, switches, speakers, RS-232interfaces, LCD displays, potentiometers and additionalEEPROM memory.

    The demonstration and development boards can beused in teaching environments, for prototyping customcircuits and for learning about various microcontrollerapplications.

    In addition to the PICDEM™ and dsPICDEM™ demon-stration/development board series of circuits, Microchiphas a line of evaluation kits and demonstration softwarefor analog filter design, KEELOQ® security ICs, CAN,IrDA®, PowerSmart battery management, SEEVAL®evaluation system, Sigma-Delta ADC, flow ratesensing, plus many more.

    Also available are starter kits that contain everythingneeded to experience the specified device. This usuallyincludes a single application and debug capability, allon one board.

    Check the Microchip web page (www.microchip.com)for the complete list of demonstration, developmentand evaluation kits.

    © 2011 Microchip Technology Inc. DS21143C-page 21

    http://www.microchip.com

  • HCS301

    9.0 ELECTRICAL CHARACTERISTICS

    TABLE 9-1: ABSOLUTE MAXIMUM RATINGS

    TABLE 9-2: DC CHARACTERISTICS

    Symbol Item Rating Units

    VDD Supply voltage -0.3 to 13.3 V

    VIN Input voltage -0.3 to 13.3 V

    VOUT Output voltage -0.3 to VDD + 0.3 V

    IOUT Max output current 25 mA

    TSTG Storage temperature -55 to +125 °C (Note)

    TLSOL Lead soldering temp 300 °C (Note)

    VESD ESD rating 4000 V

    Note: Stresses above those listed under “ABSOLUTE MAXIMUM RATINGS” may cause permanent damage tothe device.

    Commercial (C): Tamb = 0 °C to +70 °CIndustrial (I): Tamb = -40 °C to +85 °C

    3.5V < VDD < 13.0V

    Parameter Sym. Min Typ* Max Unit Conditions

    Operating current (avg) ICC 0.61.58.0

    1.03.012.0

    mAVDD = 3.5VVDD = 6.6V

    VDD = 13.0V(Figure 9-1)

    Standby current ICCS 1 10 μA

    High level Input voltage VIH 0.4 VDD VDD+0.3

    V

    Low level input voltage VIL -0.3 0.15 VDD V

    High level output voltage VOH 0.5 VDD V IOH = -2 mA

    Low level output voltage VOL 0.08 VDD V IOL = 2 mA

    LED sink current ILED 3.52.7

    4.73.7

    5.94.6

    mA VDD = 6.6V, VLOW source = 0VDD = 13.0V, VLOW source = 1

    Pull-down Resistance; S0-S3

    RS0-3 40 60 80 kΩ VIN = 4.0V

    Pull-down Resistance;PWM

    RPWM 80 120 160 kΩ VIN = 4.0V

    Note: Typical values are at 25 °C.

    DS21143C-page 22 © 2011 Microchip Technology Inc.

  • HCS301

    FIGURE 9-1: TYPICAL ICC CURVE OF HCS301 WITH EXTERNAL RESISTORS

    2 3 4 5 6 7 8 9 11 12 1310

    mA

    0.0

    2.0

    4.0

    6.0

    8.0

    10.0

    12.0

    VBAT [V]

    2 3 4 5 6 7 8 9 11 12 1310

    mA

    0.0

    2.0

    4.0

    6.0

    8.0

    10.0

    12.0

    VBAT [V]

    2 3 4 5 6 7 8 9 11 12 1310

    mA

    0.0

    2.0

    4.0

    6.0

    8.0

    10.0

    12.0

    VBAT [V]

    50Ω External

    1kΩ External

    2 kΩ External

    TypicalMaximumMinimum

    LEGEND

    © 2011 Microchip Technology Inc. DS21143C-page 23

  • HCS301

    FIGURE 9-2: POWER-UP AND TRANSMIT TIMING

    TABLE 9-3: POWER-UP AND TRANSMIT TIMING(2)

    FIGURE 9-3: CODE WORD FORMAT

    VDD = +3.5 to 13.0VCommercial(C): Tamb = 0°C to +70°CIndustrial(I): Tamb = -40°C to +85°C

    Symbol Parameter Min Max Unit RemarksTBP Time to second button press 10 + Code

    Word26 + Code

    Wordms (Note 1)

    TTD Transmit delay from button detect 10 26 msTDB Debounce Delay 6 15 msTTO Auto-shutoff time-out period 20 120 s

    Note 1: TBP is the time in which a second button can be pressed without completion of the first code word and theintention was to press the combination of buttons.

    2: Typical values - not tested in production.

    Button Press

    Sn

    Detect

    TDB

    Output

    TTD

    Multiple Code Word Transmission

    TTO

    CodeWord 1

    CodeWord 2

    CodeWord 3

    CodeWord n

    TBP

    CodeWord 4

    PWM

    InputButton

    LOGIC ‘0’

    LOGIC ‘1’

    Bit Period

    Preamble HeaderEncrypted Portion of Transmission

    Fixed Portion ofTransmission

    Guard Time

    TP TH THOP TFIX TG

    50% Duty Cycle

    TBP

    TETETE

    DS21143C-page 24 © 2011 Microchip Technology Inc.

  • HCS301

    FIGURE 9-4: CODE WORD FORMAT: PREAMBLE/HEADER PORTION

    FIGURE 9-5: CODE WORD FORMAT: DATA PORTION

    TABLE 9-4: CODE WORD TRANSMISSION TIMING REQUIREMENTS

    VDD = +2.0 to 6.0VCommercial(C):Tamb = 0 °C to +70 °CIndustrial(I):Tamb = -40 °C to +85 °C

    Code Words Transmitted

    All 1 out of 2 1 out of 4

    Symbol Characteristic Numberof TE Min. Typ. Max. Min. Typ. Max. Min. Typ. Max. Units

    TE Basic pulse element 1 260 400 660 130 200 330 65 100 165 μs

    TBP PWM bit pulse width 3 780 1200 1980 390 600 990 195 300 495 μs

    TP Preamble duration 23 6.0 9.2 15.2 3.0 4.6 7.6 1.5 2.3 3.8 ms

    TH Header duration 10 2.6 4.0 6.6 1.3 2.0 3.3 0.7 1.0 1.7 ms

    THOP Hopping code duration 96 25.0 38.4 63.4 12.5 19.2 31.7 6.2 9.6 15.8 ms

    TFIX Fixed code duration 102 26.5 40.8 67.3 13.3 20.4 33.7 6.6 10.2 16.8 ms

    TG Guard Time 39 10.1 15.6 25.7 5.1 7.8 12.9 2.5 3.9 6.4 ms

    — Total Transmit Time 270 70.2 108.0 178.2 35.1 54.0 89.1 17.6 27.0 44.6 ms

    — PWM data rate — 1282 833 505 2564 1667 1010 5128 3333 2020 bps

    Note: The timing parameters are not tested but derived from the oscillator clock.

    50% Duty Cycle Preamble Header

    P1 P12

    23 TE 10 TE Data Bits

    Bit 0 Bit 1

    Bit 0 Bit 1

    Header

    Bit 30 Bit 31 Bit 32 Bit 33 Bit 58 Bit 59

    Fixed PortionEncrypted Portion Guard

    LSBLSB MSB MSB S3 S0 S1 S2 VLOW RPT

    Time

    Serial Number Button Code Status

    Bit 60 Bit 61 Bit 62 Bit 63 Bit 64 Bit 65

    © 2011 Microchip Technology Inc. DS21143C-page 25

  • HCS301

    FIGURE 9-6: HCS301 TE VS. TEMP (BY CHARACTERIZATION ONLY)

    0.8

    1.7

    1.6

    1.5

    1.4

    1.3

    1.2

    1.1

    1.0

    0.9

    0.7

    -50 -40 -30 -20 -10 0 10 20 30 40 50 60 70 80 900.6

    TE Min.

    TE MAX.

    TE MAX.TE

    TEMPERATURE

    VDD = 3.5V

    VDD = 5.0V

    VDD = 5.0V

    VDD = 5.0V

    Typical

    DS21143C-page 26 © 2011 Microchip Technology Inc.

  • HCS301

    10.0 PACKAGING INFORMATION

    10.1 Package Marking Information8-Lead PDIP Example

    8-Lead SOIC Example

    XXXXXXXXXXXXXNNN

    YYWW

    HCS301XXXXXNNN

    0025

    XXXXXXXXXXYYWW

    NNN

    HCS301XXX0025

    NNN

    Legend: XX...X Customer specific information*Y Year code (last digit of calendar year)YY Year code (last 2 digits of calendar year)WW Week code (week of January 1 is week ‘01’)NNN Alphanumeric traceability code

    Note: In the event the full Microchip part number cannot be marked on one line, it willbe carried over to the next line thus limiting the number of available charactersfor customer specific information.

    * Standard PIC® MCU device marking consists of Microchip part number, year code, week code, andtraceability code. For PIC device marking beyond this, certain price adders apply. Please check with yourMicrochip Sales Office. For QTP devices, any special marking adders are included in QTP price.

    © 2011 Microchip Technology Inc. DS21143C-page 27

  • HCS301

    10.2 Package Details

    �������������������������������������������

    �������� ������ �!"�����#�$�%��&"��'��� ��(�)"&�'"!&�)�����&�#�*�&��&�����&���#������� +������%����&�,����&��!&���-� ��'��!��!�����#�.��#��&�����"#��'�#�%��!����&"!��!����#�%��!����&"!��!�!������&��$���#�����/����!�#���� ��'��!��������#�&���������������.�0������

    1�,2�1�!�����'��!�������&��������$��&� ��"��!�*��*�&�"&�&������!�

    ����� 3�&���'!&��"��&����4����#�*���!(�����!��!���&��������������4�����������%���&������&�#��&��&&�255***�'��������'5���4�����

    6��&! �7,8.���'��!���9�'�&! ��7 7:� ��;

    7"')��%����! 7 <��&�� � �����1�,

    ��&����&��������� � = = ������#�#����4�������4��!! �� ���� ��-� ����1�!��&����&��������� �� ���� = =��"�#��&���"�#��>�#&� . ���� �-�� �-����#�#����4����>�#&� .� ���� ���� ���#&� )� ���� ��?� ����9*��9��#�>�#&� ) ���� ���< ����: ������*����������+ �1 = = ��-�

    N

    E1

    NOTE 1

    D

    1 2 3

    A

    A1

    A2

    L

    b1b

    e

    E

    eB

    c

    ������� ������� ��*��� ,�����

  • HCS301

    Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging

    © 2011 Microchip Technology Inc. DS21143C-page 29

  • HCS301

    Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging

    DS21143C-page 30 © 2011 Microchip Technology Inc.

  • HCS301

    ������������ ��

    �!��

    ���� �������""�#$��%&����������� !�'�

    ����� 3�&���'!&��"��&����4����#�*���!(�����!��!���&��������������4�����������%���&������&�#��&��&&�255***�'��������'5���4�����

    © 2011 Microchip Technology Inc. DS21143C-page 31

  • HCS301

    APPENDIX A: ADDITIONAL INFORMATION

    Microchip’s Secure Data Products are covered bysome or all of the following:

    Code hopping encoder patents issued in Europeancountries and U.S.A.

    Secure learning patents issued in European countries,U.S.A. and R.S.A.

    REVISION HISTORY

    Revision C (June 2011)• Updated the following sections: Develoment Sup-

    port, The Microchip Web Site, Reader Response and HCS301 Product Identification System

    • Added new section Appendix A• Minor formatting and text changes were incorporated

    throughout the document

    DS21143C-page 32 © 2011 Microchip Technology Inc.

  • HCS301

    THE MICROCHIP WEB SITEMicrochip provides online support via our WWW site atwww.microchip.com. This web site is used as a meansto make files and information easily available tocustomers. Accessible by using your favorite Internetbrowser, the web site contains the followinginformation:

    • Product Support – Data sheets and errata, application notes and sample programs, design resources, user’s guides and hardware support documents, latest software releases and archived software

    • General Technical Support – Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing

    • Business of Microchip – Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

    CUSTOMER CHANGE NOTIFICATION SERVICEMicrochip’s customer notification service helps keepcustomers current on Microchip products. Subscriberswill receive e-mail notification whenever there arechanges, updates, revisions or errata related to aspecified product family or development tool of interest.

    To register, access the Microchip web site atwww.microchip.com. Under “Support”, click on“Customer Change Notification” and follow theregistration instructions.

    CUSTOMER SUPPORTUsers of Microchip products can receive assistancethrough several channels:

    • Distributor or Representative• Local Sales Office• Field Application Engineer (FAE)• Technical Support• Development Systems Information Line

    Customers should contact their distributor,representative or field application engineer (FAE) forsupport. Local sales offices are also available to helpcustomers. A listing of sales offices and locations isincluded in the back of this document.

    Technical support is available through the web siteat: http://microchip.com/support

    © 2011 Microchip Technology Inc. DS21143C-page 33

    http://www.microchip.comhttp://www.microchip.comhttp://www.microchip.comhttp://www.microchip.comhttp://www.microchip.comhttp://www.microchip.com

  • HCS301

    READER RESPONSEIt is our intention to provide you with the best documentation possible to ensure successful use of your Microchipproduct. If you wish to provide your comments on organization, clarity, subject matter, and ways in which ourdocumentation can better serve you, please FAX your comments to the Technical Publications Manager at(480) 792-4150.

    Please list the following information, and use this outline to provide us with your comments about this document.

    TO: Technical Publications ManagerRE: Reader Response

    Total Pages Sent ________

    From: Name

    CompanyAddressCity / State / ZIP / Country

    Telephone: (_______) _________ - _________

    Application (optional):

    Would you like a reply? Y N

    Device: Literature Number:

    Questions:

    FAX: (______) _________ - _________

    DS21143CHCS301

    1. What are the best features of this document?

    2. How does this document meet your hardware and software development needs?

    3. Do you find the organization of this document easy to follow? If not, why?

    4. What additions to the document do you think would enhance the structure and subject?

    5. What deletions from the document could be made without affecting the overall usefulness?

    6. Is there any incorrect or misleading information (what and where)?

    7. How would you improve this document?

    DS21143C-page 34 © 2011 Microchip Technology Inc.

  • HCS301

    HCS301 PRODUCT IDENTIFICATION SYSTEMTo order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office.

    Package: P = Plastic DIP (300 mil Body), 8-leadSN = Plastic SOIC (150 mil Body), 8-lead

    Temperature Blank = 0°C to +70°CRange: I = –40°C to +85°C

    Device: HCS301 = Code Hopping EncoderHCS301T = Code Hopping Encoder (Tape and Reel)

    HCS301 - /P

    © 2011 Microchip Technology Inc. DS21143C-page 35

  • HCS301

    NOTES:

    DS21143C-page 36 © 2011 Microchip Technology Inc.

  • Note the following details of the code protection feature on Microchip devices:• Microchip products meet the specification contained in their particular Microchip Data Sheet.

    • Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.

    • There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip’s Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.

    • Microchip is willing to work with the customer who is concerned about the integrity of their code.

    • Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as “unbreakable.”

    Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of ourproducts. Attempts to break Microchip’s code protection feature may be a violation of the Digital Millennium Copyright Act. If such actsallow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

    Information contained in this publication regarding deviceapplications and the like is provided only for your convenienceand may be superseded by updates. It is your responsibility toensure that your application meets with your specifications.MICROCHIP MAKES NO REPRESENTATIONS ORWARRANTIES OF ANY KIND WHETHER EXPRESS ORIMPLIED, WRITTEN OR ORAL, STATUTORY OROTHERWISE, RELATED TO THE INFORMATION,INCLUDING BUT NOT LIMITED TO ITS CONDITION,QUALITY, PERFORMANCE, MERCHANTABILITY ORFITNESS FOR PURPOSE. Microchip disclaims all liabilityarising from this information and its use. Use of Microchipdevices in life support and/or safety applications is entirely atthe buyer’s risk, and the buyer agrees to defend, indemnify andhold harmless Microchip from any and all damages, claims,suits, or expenses resulting from such use. No licenses areconveyed, implicitly or otherwise, under any Microchipintellectual property rights.

    © 2011 Microchip Technology Inc.

    Trademarks

    The Microchip name and logo, the Microchip logo, dsPIC, KEELOQ, KEELOQ logo, MPLAB, PIC, PICmicro, PICSTART, PIC32 logo, rfPIC and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

    FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor, MXDEV, MXLAB, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A.

    Analog-for-the-Digital Age, Application Maestro, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial Programming, ICSP, Mindi, MiWi, MPASM, MPLAB Certified logo, MPLIB, MPLINK, mTouch, Omniscient Code Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit, PICtail, REAL ICE, rfLAB, Select Mode, Total Endurance, TSHARC, UniWinDriver, WiperLock and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

    SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

    All other trademarks mentioned herein are property of their respective companies.

    © 2011, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

    Printed on recycled paper.

    ISBN: 978-1-61341-220-6

    DS21143C-page 37

    Microchip received ISO/TS-16949:2002 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company’s quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip’s quality system for the design and manufacture of development systems is ISO 9001:2000 certified.

  • DS21143C-page 38 © 2011 Microchip Technology Inc.

    AMERICASCorporate Office2355 West Chandler Blvd.Chandler, AZ 85224-6199Tel: 480-792-7200 Fax: 480-792-7277Technical Support: http://www.microchip.com/supportWeb Address: www.microchip.comAtlantaDuluth, GA Tel: 678-957-9614 Fax: 678-957-1455BostonWestborough, MA Tel: 774-760-0087 Fax: 774-760-0088ChicagoItasca, IL Tel: 630-285-0071 Fax: 630-285-0075ClevelandIndependence, OH Tel: 216-447-0464 Fax: 216-447-0643DallasAddison, TX Tel: 972-818-7423 Fax: 972-818-2924DetroitFarmington Hills, MI Tel: 248-538-2250Fax: 248-538-2260IndianapolisNoblesville, IN Tel: 317-773-8323Fax: 317-773-5453Los AngelesMission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608Santa ClaraSanta Clara, CA Tel: 408-961-6444Fax: 408-961-6445TorontoMississauga, Ontario, CanadaTel: 905-673-0699 Fax: 905-673-6509

    ASIA/PACIFICAsia Pacific OfficeSuites 3707-14, 37th FloorTower 6, The GatewayHarbour City, KowloonHong KongTel: 852-2401-1200Fax: 852-2401-3431Australia - SydneyTel: 61-2-9868-6733Fax: 61-2-9868-6755China - BeijingTel: 86-10-8569-7000 Fax: 86-10-8528-2104China - ChengduTel: 86-28-8665-5511Fax: 86-28-8665-7889China - ChongqingTel: 86-23-8980-9588Fax: 86-23-8980-9500China - HangzhouTel: 86-571-2819-3180 Fax: 86-571-2819-3189China - Hong Kong SARTel: 852-2401-1200 Fax: 852-2401-3431China - NanjingTel: 86-25-8473-2460Fax: 86-25-8473-2470China - QingdaoTel: 86-532-8502-7355Fax: 86-532-8502-7205China - ShanghaiTel: 86-21-5407-5533 Fax: 86-21-5407-5066China - ShenyangTel: 86-24-2334-2829Fax: 86-24-2334-2393China - ShenzhenTel: 86-755-8203-2660 Fax: 86-755-8203-1760China - WuhanTel: 86-27-5980-5300Fax: 86-27-5980-5118China - XianTel: 86-29-8833-7252Fax: 86-29-8833-7256China - XiamenTel: 86-592-2388138 Fax: 86-592-2388130China - ZhuhaiTel: 86-756-3210040 Fax: 86-756-3210049

    ASIA/PACIFICIndia - BangaloreTel: 91-80-3090-4444 Fax: 91-80-3090-4123India - New DelhiTel: 91-11-4160-8631Fax: 91-11-4160-8632India - PuneTel: 91-20-2566-1512Fax: 91-20-2566-1513Japan - YokohamaTel: 81-45-471- 6166 Fax: 81-45-471-6122Korea - DaeguTel: 82-53-744-4301Fax: 82-53-744-4302Korea - SeoulTel: 82-2-554-7200Fax: 82-2-558-5932 or 82-2-558-5934Malaysia - Kuala LumpurTel: 60-3-6201-9857Fax: 60-3-6201-9859Malaysia - PenangTel: 60-4-227-8870Fax: 60-4-227-4068Philippines - ManilaTel: 63-2-634-9065Fax: 63-2-634-9069SingaporeTel: 65-6334-8870Fax: 65-6334-8850Taiwan - Hsin ChuTel: 886-3-6578-300Fax: 886-3-6578-370Taiwan - KaohsiungTel: 886-7-213-7830Fax: 886-7-330-9305Taiwan - TaipeiTel: 886-2-2500-6610 Fax: 886-2-2508-0102Thailand - BangkokTel: 66-2-694-1351Fax: 66-2-694-1350

    EUROPEAustria - WelsTel: 43-7242-2244-39Fax: 43-7242-2244-393Denmark - CopenhagenTel: 45-4450-2828 Fax: 45-4485-2829France - ParisTel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79Germany - MunichTel: 49-89-627-144-0 Fax: 49-89-627-144-44Italy - Milan Tel: 39-0331-742611 Fax: 39-0331-466781Netherlands - DrunenTel: 31-416-690399 Fax: 31-416-690340Spain - MadridTel: 34-91-708-08-90Fax: 34-91-708-08-91UK - WokinghamTel: 44-118-921-5869Fax: 44-118-921-5820

    Worldwide Sales and Service

    05/02/11

    http://support.microchip.comhttp://www.microchip.com

    FeaturesSecurityOperatingOtherTypical Applications

    DescriptionPackage TypesHCS301 Block Diagram1.0 System OverviewFIGURE 1-1: Creation and Storage of crypt Key during productionFIGURE 1-2: building the Transmitted code word (encoder)FIGURE 1-3: basic operation of receiver (decoder)

    2.0 Device OperationFIGURE 2-1: typical CircuitsTABLE 2-1: PIN DescriptionsFIGURE 2-2: Encoder operation

    3.0 EEPROM Memory OrganizationTABLE 3-1: EEPROM Memory Map3.1 KEY_0 - KEY_3 (64-Bit Crypt Key)3.2 SYNC (Synchronization Counter)3.3 Reserved3.4 SER_0, SER_1 (Encoder Serial Number)3.4.1 Auto-shutoff timer ENABLE

    3.5 SEED_0, SEED_1 (Seed Word)3.6 CONFIG (Configuration Word)TABLE 3-2: Configuration Word3.6.1 Discrimination value (DISC0 to DISC9)3.6.2 Overflow bits (OVR0, OVR1)3.6.3 Baud raTe select Bits (BSL0, BSL1)

    TABLE 3-3: Baud rate Select3.6.4 low Voltage trip point Select

    FIGURE 3-1: Voltage Trip Points BY CHARACTERIZATION

    4.0 Transmitted Word4.1 Code Word Format4.2 Code Word OrganizationFIGURE 4-1: CODE WORD formatFIGURE 4-2: CODE Word ORGANIZATION4.3 Synchronous Transmission ModeFIGURE 4-3: Synchronous Transmission ModeFIGURE 4-4: CODE Word ORGANIZATION (Synchronous Transmission MOde)

    5.0 Special Features5.1 Code Word Completion5.2 LED Output Operation5.3 RPT: Repeat Indicator5.4 Vlow: Voltage LOW Indicator5.5 Auto-shutoff5.6 Seed TransmissionTABLE 5-1: Pin Activation Table5.7 Blank Alternate Code WordFIGURE 5-1: Blank Alternate Code Word (BACW)

    6.0 Programming The HCS301FIGURE 6-1: Programming WaveformsFIGURE 6-2: Verify WaveformsTABLE 6-1: Programming/verify Timing Requirements

    7.0 Integrating The HCS301 Into a System7.1 Learning a Transmitter to a ReceiverFIGURE 7-1: typical Learn Sequence7.2 Decoder OperationFIGURE 7-2: typical Decoder Operation7.3 Synchronization with Decoder (Evaluating the Counter)FIGURE 7-3: Synchronization Window

    8.0 Development Support8.1 MPLAB Integrated Development Environment Software8.2 MPLAB C Compilers for Various Device Families8.3 HI-TECH C for Various Device Families8.4 MPASM Assembler8.5 MPLINK Object Linker/ MPLIB Object Librarian8.6 MPLAB Assembler, Linker and Librarian for Various Device Families8.7 MPLAB SIM Software Simulator8.8 MPLAB REAL ICE In-Circuit Emulator System8.9 MPLAB ICD 3 In-Circuit Debugger System8.10 PICkit 3 In-Circuit Debugger/ Programmer and PICkit 3 Debug Express8.11 PICkit 2 Development Programmer/Debugger and PICkit 2 Debug Express8.12 MPLAB PM3 Device Programmer8.13 Demonstration/Development Boards, Evaluation Kits, and Starter Kits

    9.0 Electrical CharacteristicsTABLE 9-1: ABSOLUTE MAXIMUM RATINGSTABLE 9-2: DC CHARACTERISTICSFIGURE 9-1: TYPICAL ICC CURVE OF HCS301 WITH EXTERNAL RESISTORSFIGURE 9-2: Power-up and transmit timingTABLE 9-3: power-up and transmit timing(2)FIGURE 9-3: Code word formatFIGURE 9-4: code word format: Preamble/Header portionFIGURE 9-5: code Word format: data portionTABLE 9-4: Code Word Transmission timing requirementsFIGURE 9-6: HCS301 Te vs. Temp (by characterization only)

    10.0 Packaging Information10.1 Package Marking Information10.2 Package Details

    Appendix A: Additional InformationRevision HistoryRevision C (June 2011)

    The Microchip Web SiteCustomer Change Notification ServiceCustomer SupportReader ResponseHCS301 Product Identification SystemKeeLoq® Code Hopping EncoderWorldwide Sales and Service

    /ColorImageDict > /JPEG2000ColorACSImageDict > /JPEG2000ColorImageDict > /AntiAliasGrayImages false /CropGrayImages true /GrayImageMinResolution 300 /GrayImageMinResolutionPolicy /OK /DownsampleGrayImages true /GrayImageDownsampleType /Bicubic /GrayImageResolution 300 /GrayImageDepth -1 /GrayImageMinDownsampleDepth 2 /GrayImageDownsampleThreshold 1.50000 /EncodeGrayImages true /GrayImageFilter /DCTEncode /AutoFilterGrayImages true /GrayImageAutoFilterStrategy /JPEG /GrayACSImageDict > /GrayImageDict > /JPEG2000GrayACSImageDict > /JPEG2000GrayImageDict > /AntiAliasMonoImages false /CropMonoImages true /MonoImageMinResolution 1200 /MonoImageMinResolutionPolicy /OK /DownsampleMonoImages true /MonoImageDownsampleType /Bicubic /MonoImageResolution 1200 /MonoImageDepth -1 /MonoImageDownsampleThreshold 1.50000 /EncodeMonoImages true /MonoImageFilter /CCITTFaxEncode /MonoImageDict > /AllowPSXObjects false /CheckCompliance [ /None ] /PDFX1aCheck false /PDFX3Check false /PDFXCompliantPDFOnly false /PDFXNoTrimBoxError true /PDFXTrimBoxToMediaBoxOffset [ 0.00000 0.00000 0.00000 0.00000 ] /PDFXSetBleedBoxToMediaBox true /PDFXBleedBoxToTrimBoxOffset [ 0.00000 0.00000 0.00000 0.00000 ] /PDFXOutputIntentProfile () /PDFXOutputConditionIdentifier () /PDFXOutputCondition () /PDFXRegistryName () /PDFXTrapped /False

    /CreateJDFFile false /Description > /Namespace [ (Adobe) (Common) (1.0) ] /OtherNamespaces [ > /FormElements false /GenerateStructure false /IncludeBookmarks false /IncludeHyperlinks false /IncludeInteractive false /IncludeLayers false /IncludeProfiles false /MultimediaHandling /UseObjectSettings /Namespace [ (Adobe) (CreativeSuite) (2.0) ] /PDFXOutputIntentProfileSelector /DocumentCMYK /PreserveEditing true /UntaggedCMYKHandling /LeaveUntagged /UntaggedRGBHandling /UseDocumentProfile /UseDocumentBleed false >> ]>> setdistillerparams> setpagedevice