beautypg.com

Accelerated rom search example, Table 21-2. transmit/receive byte sequence – Maxim Integrated High-Speed Microcontroller Users Guide: Network Microcontroller Supplement User Manual

Page 171

background image

High-Speed Microcontroller User’s

Guide: Network Microcontroller

Supplement

171

Table 21-2. Transmit/Receive Byte Sequence

r

n

= decision discrepancy data (write time slot selection data if ID discrepancy)

ID

n

= selected ROM ID bit (r

n

if discrepancy occurred, otherwise read time slot 1)

d

n

= discrepancy detected flag (ID discrepancy or no response)

x

= don’t care data

The CPU must send and receive 16 bytes of data to complete a single search ROM pass on the 1-Wire bus. To perform a search ROM

sequence one starts with all decision discrepancy bits (rn) being 0. In case of bus error, all subsequent response bits IDn are 1s until

the search accelerator is deactivated by clearing the SRA bit in the command register. Thus, if ID63 and d63 are both 1, an error has

occurred during the search process and the last sequence has to be repeated. Otherwise, ID63:0 is the ROM code of the device that

has been found and addressed. For the next search ROM sequence one reuses the previous set r

n

(for n = 0:63), changing to 1 only

that bit position where the highest discrepancy was detected (dn flags). This process is repeated until the highest discrepancy occurs

in the same bit position for two passes, then the next lower discrepancy flag is used for next search. When the search ROM process is

completed, the SRA bit should be cleared in order to release the 1-Wire master from search ROM Accelerator mode.

Accelerated ROM Search Example

The following example should provide a better understanding of how the search ROM Accelerator functionality allows the 1-Wire mas-

ter to identify four different devices on the 1-Wire bus. The ROM contents of the devices is as shown (LSB first):

ROM1 = 00110101....

ROM2 = 10101010....

ROM3 = 11110101....

ROM4 = 00010001....

1.

The host issues a reset pulse by writing 01h to the command register. All slave devices respond simultaneously with a presence

detect.

2.

The host issues a search ROM command by writing 0Fh to the transmit buffer.

3.

The host places the 1-Wire master in search ROM Accelerator mode by writing 02h to the command register.

4.

The host writes 00h to transmit buffer and reads the return data from the receive buffer. This process is repeated for total of 16

bytes. The data read contains ROM4 in the ID bit locations and the discrepancy flags d0 and d2 are set. This can easily be seen

by examining the ROM IDs bit by bit. The first discrepancy occurs in bit position 0 (d0). The bus master write time slot contains a

0, thus deselecting ROM2 and ROM3. A discrepancy between ROM1 and ROM4 then occurs in bit position 2 (d2), leaving only

ROM4 in the search. The receive data is as follows: (d0ID0 d1ID1 d2ID2 d3ID3 d4ID4 d5ID5 d6ID6 d7ID7 ….):

5.

Receive Data = 10 00 10 01 00 00 00 01....

6.

The host then deinterleaves the data to arrive at a ROM ID of 00010001... and discrepancy data (bold) of 10100000…. with the last

discrepancy at location d2.

7.

The host writes 0x00h to the command register to exit accelerator mode. The host is now free to send a command or read data

directly from this device.

8.

Steps 1 to 6 are now repeated to find the next device on the bus. The 16 bytes of data transmitted this time are identical to ROM4

up until the last discrepancy flag (d2 in this case), which is inverted and all higher order decision discrepancy data bits are set to

0 as shown: r0r1r2r3r4r5…. = 001000….. . For this search iteration, the receive data contains ROM1 in the ID bit locations, again

with discrepancy flags d0 and d2 set. Receive Data = 10 00 11 01 00 01 00 01….

BYTE

BIT 7

BIT 6

BIT 5

BIT 4

BIT 3

BIT 2

BIT 1

BIT 0

Byte 1

Transmit Buffer

r

3

x

r

2

x

r

1

x

r

0

x

Receive Buffer

ID

3

d

3

ID

2

d

2

ID

1

d

1

ID

0

d

0

Byte 2

Transmit Buffer

r

7

x

r

6

x

r

5

x

r

4

x

Receive Buffer

ID

7

d

7

ID

6

d

6

ID

5

d

5

ID

4

d

4

. . . .

Byte 16

Transmit Buffer

r

63

x

r

62

x

r

61

x

r

60

x

Receive Buffer

ID

63

d

63

ID

62

d

62

ID

61

d

61

ID

60

d

60

Maxim Integrated