linux/drivers/media/usb/dvb-usb-v2/mxl111sf-i2c.c
<<
>>
Prefs
   1/*
   2 *  mxl111sf-i2c.c - driver for the MaxLinear MXL111SF
   3 *
   4 *  Copyright (C) 2010-2014 Michael Krufky <mkrufky@linuxtv.org>
   5 *
   6 *  This program is free software; you can redistribute it and/or modify
   7 *  it under the terms of the GNU General Public License as published by
   8 *  the Free Software Foundation; either version 2 of the License, or
   9 *  (at your option) any later version.
  10 *
  11 *  This program is distributed in the hope that it will be useful,
  12 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  13 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  14 *  GNU General Public License for more details.
  15 */
  16
  17#include "mxl111sf-i2c.h"
  18#include "mxl111sf.h"
  19
  20/* SW-I2C ----------------------------------------------------------------- */
  21
  22#define SW_I2C_ADDR             0x1a
  23#define SW_I2C_EN               0x02
  24#define SW_SCL_OUT              0x04
  25#define SW_SDA_OUT              0x08
  26#define SW_SDA_IN               0x04
  27
  28#define SW_I2C_BUSY_ADDR        0x2f
  29#define SW_I2C_BUSY             0x02
  30
  31static int mxl111sf_i2c_bitbang_sendbyte(struct mxl111sf_state *state,
  32                                         u8 byte)
  33{
  34        int i, ret;
  35        u8 data = 0;
  36
  37        mxl_i2c("(0x%02x)", byte);
  38
  39        ret = mxl111sf_read_reg(state, SW_I2C_BUSY_ADDR, &data);
  40        if (mxl_fail(ret))
  41                goto fail;
  42
  43        for (i = 0; i < 8; i++) {
  44
  45                data = (byte & (0x80 >> i)) ? SW_SDA_OUT : 0;
  46
  47                ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
  48                                         0x10 | SW_I2C_EN | data);
  49                if (mxl_fail(ret))
  50                        goto fail;
  51
  52                ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
  53                                         0x10 | SW_I2C_EN | data | SW_SCL_OUT);
  54                if (mxl_fail(ret))
  55                        goto fail;
  56
  57                ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
  58                                         0x10 | SW_I2C_EN | data);
  59                if (mxl_fail(ret))
  60                        goto fail;
  61        }
  62
  63        /* last bit was 0 so we need to release SDA */
  64        if (!(byte & 1)) {
  65                ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
  66                                         0x10 | SW_I2C_EN | SW_SDA_OUT);
  67                if (mxl_fail(ret))
  68                        goto fail;
  69        }
  70
  71        /* CLK high for ACK readback */
  72        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
  73                                 0x10 | SW_I2C_EN | SW_SCL_OUT | SW_SDA_OUT);
  74        if (mxl_fail(ret))
  75                goto fail;
  76
  77        ret = mxl111sf_read_reg(state, SW_I2C_BUSY_ADDR, &data);
  78        if (mxl_fail(ret))
  79                goto fail;
  80
  81        /* drop the CLK after getting ACK, SDA will go high right away */
  82        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
  83                                 0x10 | SW_I2C_EN | SW_SDA_OUT);
  84        if (mxl_fail(ret))
  85                goto fail;
  86
  87        if (data & SW_SDA_IN)
  88                ret = -EIO;
  89fail:
  90        return ret;
  91}
  92
  93static int mxl111sf_i2c_bitbang_recvbyte(struct mxl111sf_state *state,
  94                                         u8 *pbyte)
  95{
  96        int i, ret;
  97        u8 byte = 0;
  98        u8 data = 0;
  99
 100        mxl_i2c("()");
 101
 102        *pbyte = 0;
 103
 104        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 105                                 0x10 | SW_I2C_EN | SW_SDA_OUT);
 106        if (mxl_fail(ret))
 107                goto fail;
 108
 109        for (i = 0; i < 8; i++) {
 110                ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 111                                         0x10 | SW_I2C_EN |
 112                                         SW_SCL_OUT | SW_SDA_OUT);
 113                if (mxl_fail(ret))
 114                        goto fail;
 115
 116                ret = mxl111sf_read_reg(state, SW_I2C_BUSY_ADDR, &data);
 117                if (mxl_fail(ret))
 118                        goto fail;
 119
 120                if (data & SW_SDA_IN)
 121                        byte |= (0x80 >> i);
 122
 123                ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 124                                         0x10 | SW_I2C_EN | SW_SDA_OUT);
 125                if (mxl_fail(ret))
 126                        goto fail;
 127        }
 128        *pbyte = byte;
 129fail:
 130        return ret;
 131}
 132
 133static int mxl111sf_i2c_start(struct mxl111sf_state *state)
 134{
 135        int ret;
 136
 137        mxl_i2c("()");
 138
 139        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 140                                 0x10 | SW_I2C_EN | SW_SCL_OUT | SW_SDA_OUT);
 141        if (mxl_fail(ret))
 142                goto fail;
 143
 144        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 145                                 0x10 | SW_I2C_EN | SW_SCL_OUT);
 146        if (mxl_fail(ret))
 147                goto fail;
 148
 149        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 150                                 0x10 | SW_I2C_EN); /* start */
 151        mxl_fail(ret);
 152fail:
 153        return ret;
 154}
 155
 156static int mxl111sf_i2c_stop(struct mxl111sf_state *state)
 157{
 158        int ret;
 159
 160        mxl_i2c("()");
 161
 162        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 163                                 0x10 | SW_I2C_EN); /* stop */
 164        if (mxl_fail(ret))
 165                goto fail;
 166
 167        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 168                                 0x10 | SW_I2C_EN | SW_SCL_OUT);
 169        if (mxl_fail(ret))
 170                goto fail;
 171
 172        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 173                                 0x10 | SW_I2C_EN | SW_SCL_OUT | SW_SDA_OUT);
 174        if (mxl_fail(ret))
 175                goto fail;
 176
 177        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 178                                 0x10 | SW_SCL_OUT | SW_SDA_OUT);
 179        mxl_fail(ret);
 180fail:
 181        return ret;
 182}
 183
 184static int mxl111sf_i2c_ack(struct mxl111sf_state *state)
 185{
 186        int ret;
 187        u8 b = 0;
 188
 189        mxl_i2c("()");
 190
 191        ret = mxl111sf_read_reg(state, SW_I2C_BUSY_ADDR, &b);
 192        if (mxl_fail(ret))
 193                goto fail;
 194
 195        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 196                                 0x10 | SW_I2C_EN);
 197        if (mxl_fail(ret))
 198                goto fail;
 199
 200        /* pull SDA low */
 201        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 202                                 0x10 | SW_I2C_EN | SW_SCL_OUT);
 203        if (mxl_fail(ret))
 204                goto fail;
 205
 206        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 207                                 0x10 | SW_I2C_EN | SW_SDA_OUT);
 208        mxl_fail(ret);
 209fail:
 210        return ret;
 211}
 212
 213static int mxl111sf_i2c_nack(struct mxl111sf_state *state)
 214{
 215        int ret;
 216
 217        mxl_i2c("()");
 218
 219        /* SDA high to signal last byte read from slave */
 220        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 221                                 0x10 | SW_I2C_EN | SW_SCL_OUT | SW_SDA_OUT);
 222        if (mxl_fail(ret))
 223                goto fail;
 224
 225        ret = mxl111sf_write_reg(state, SW_I2C_ADDR,
 226                                 0x10 | SW_I2C_EN | SW_SDA_OUT);
 227        mxl_fail(ret);
 228fail:
 229        return ret;
 230}
 231
 232/* ------------------------------------------------------------------------ */
 233
 234static int mxl111sf_i2c_sw_xfer_msg(struct mxl111sf_state *state,
 235                                    struct i2c_msg *msg)
 236{
 237        int i, ret;
 238
 239        mxl_i2c("()");
 240
 241        if (msg->flags & I2C_M_RD) {
 242
 243                ret = mxl111sf_i2c_start(state);
 244                if (mxl_fail(ret))
 245                        goto fail;
 246
 247                ret = mxl111sf_i2c_bitbang_sendbyte(state,
 248                                                    (msg->addr << 1) | 0x01);
 249                if (mxl_fail(ret)) {
 250                        mxl111sf_i2c_stop(state);
 251                        goto fail;
 252                }
 253
 254                for (i = 0; i < msg->len; i++) {
 255                        ret = mxl111sf_i2c_bitbang_recvbyte(state,
 256                                                            &msg->buf[i]);
 257                        if (mxl_fail(ret)) {
 258                                mxl111sf_i2c_stop(state);
 259                                goto fail;
 260                        }
 261
 262                        if (i < msg->len - 1)
 263                                mxl111sf_i2c_ack(state);
 264                }
 265
 266                mxl111sf_i2c_nack(state);
 267
 268                ret = mxl111sf_i2c_stop(state);
 269                if (mxl_fail(ret))
 270                        goto fail;
 271
 272        } else {
 273
 274                ret = mxl111sf_i2c_start(state);
 275                if (mxl_fail(ret))
 276                        goto fail;
 277
 278                ret = mxl111sf_i2c_bitbang_sendbyte(state,
 279                                                    (msg->addr << 1) & 0xfe);
 280                if (mxl_fail(ret)) {
 281                        mxl111sf_i2c_stop(state);
 282                        goto fail;
 283                }
 284
 285                for (i = 0; i < msg->len; i++) {
 286                        ret = mxl111sf_i2c_bitbang_sendbyte(state,
 287                                                            msg->buf[i]);
 288                        if (mxl_fail(ret)) {
 289                                mxl111sf_i2c_stop(state);
 290                                goto fail;
 291                        }
 292                }
 293
 294                /* FIXME: we only want to do this on the last transaction */
 295                mxl111sf_i2c_stop(state);
 296        }
 297fail:
 298        return ret;
 299}
 300
 301/* HW-I2C ----------------------------------------------------------------- */
 302
 303#define USB_WRITE_I2C_CMD     0x99
 304#define USB_READ_I2C_CMD      0xdd
 305#define USB_END_I2C_CMD       0xfe
 306
 307#define USB_WRITE_I2C_CMD_LEN   26
 308#define USB_READ_I2C_CMD_LEN    24
 309
 310#define I2C_MUX_REG           0x30
 311#define I2C_CONTROL_REG       0x00
 312#define I2C_SLAVE_ADDR_REG    0x08
 313#define I2C_DATA_REG          0x0c
 314#define I2C_INT_STATUS_REG    0x10
 315
 316static int mxl111sf_i2c_send_data(struct mxl111sf_state *state,
 317                                  u8 index, u8 *wdata)
 318{
 319        int ret = mxl111sf_ctrl_msg(state->d, wdata[0],
 320                                    &wdata[1], 25, NULL, 0);
 321        mxl_fail(ret);
 322
 323        return ret;
 324}
 325
 326static int mxl111sf_i2c_get_data(struct mxl111sf_state *state,
 327                                 u8 index, u8 *wdata, u8 *rdata)
 328{
 329        int ret = mxl111sf_ctrl_msg(state->d, wdata[0],
 330                                    &wdata[1], 25, rdata, 24);
 331        mxl_fail(ret);
 332
 333        return ret;
 334}
 335
 336static u8 mxl111sf_i2c_check_status(struct mxl111sf_state *state)
 337{
 338        u8 status = 0;
 339        u8 buf[26];
 340
 341        mxl_i2c_adv("()");
 342
 343        buf[0] = USB_READ_I2C_CMD;
 344        buf[1] = 0x00;
 345
 346        buf[2] = I2C_INT_STATUS_REG;
 347        buf[3] = 0x00;
 348        buf[4] = 0x00;
 349
 350        buf[5] = USB_END_I2C_CMD;
 351
 352        mxl111sf_i2c_get_data(state, 0, buf, buf);
 353
 354        if (buf[1] & 0x04)
 355                status = 1;
 356
 357        return status;
 358}
 359
 360static u8 mxl111sf_i2c_check_fifo(struct mxl111sf_state *state)
 361{
 362        u8 status = 0;
 363        u8 buf[26];
 364
 365        mxl_i2c("()");
 366
 367        buf[0] = USB_READ_I2C_CMD;
 368        buf[1] = 0x00;
 369
 370        buf[2] = I2C_MUX_REG;
 371        buf[3] = 0x00;
 372        buf[4] = 0x00;
 373
 374        buf[5] = I2C_INT_STATUS_REG;
 375        buf[6] = 0x00;
 376        buf[7] = 0x00;
 377        buf[8] = USB_END_I2C_CMD;
 378
 379        mxl111sf_i2c_get_data(state, 0, buf, buf);
 380
 381        if (0x08 == (buf[1] & 0x08))
 382                status = 1;
 383
 384        if ((buf[5] & 0x02) == 0x02)
 385                mxl_i2c("(buf[5] & 0x02) == 0x02"); /* FIXME */
 386
 387        return status;
 388}
 389
 390static int mxl111sf_i2c_readagain(struct mxl111sf_state *state,
 391                                  u8 count, u8 *rbuf)
 392{
 393        u8 i2c_w_data[26];
 394        u8 i2c_r_data[24];
 395        u8 i = 0;
 396        u8 fifo_status = 0;
 397        int status = 0;
 398
 399        mxl_i2c("read %d bytes", count);
 400
 401        while ((fifo_status == 0) && (i++ < 5))
 402                fifo_status = mxl111sf_i2c_check_fifo(state);
 403
 404        i2c_w_data[0] = 0xDD;
 405        i2c_w_data[1] = 0x00;
 406
 407        for (i = 2; i < 26; i++)
 408                i2c_w_data[i] = 0xFE;
 409
 410        for (i = 0; i < count; i++) {
 411                i2c_w_data[2+(i*3)] = 0x0C;
 412                i2c_w_data[3+(i*3)] = 0x00;
 413                i2c_w_data[4+(i*3)] = 0x00;
 414        }
 415
 416        mxl111sf_i2c_get_data(state, 0, i2c_w_data, i2c_r_data);
 417
 418        /* Check for I2C NACK status */
 419        if (mxl111sf_i2c_check_status(state) == 1) {
 420                mxl_i2c("error!");
 421        } else {
 422                for (i = 0; i < count; i++) {
 423                        rbuf[i] = i2c_r_data[(i*3)+1];
 424                        mxl_i2c("%02x\t %02x",
 425                                i2c_r_data[(i*3)+1],
 426                                i2c_r_data[(i*3)+2]);
 427                }
 428
 429                status = 1;
 430        }
 431
 432        return status;
 433}
 434
 435#define HWI2C400 1
 436static int mxl111sf_i2c_hw_xfer_msg(struct mxl111sf_state *state,
 437                                    struct i2c_msg *msg)
 438{
 439        int i, k, ret = 0;
 440        u16 index = 0;
 441        u8 buf[26];
 442        u8 i2c_r_data[24];
 443        u16 block_len;
 444        u16 left_over_len;
 445        u8 rd_status[8];
 446        u8 ret_status;
 447        u8 readbuff[26];
 448
 449        mxl_i2c("addr: 0x%02x, read buff len: %d, write buff len: %d",
 450                msg->addr, (msg->flags & I2C_M_RD) ? msg->len : 0,
 451                (!(msg->flags & I2C_M_RD)) ? msg->len : 0);
 452
 453        for (index = 0; index < 26; index++)
 454                buf[index] = USB_END_I2C_CMD;
 455
 456        /* command to indicate data payload is destined for I2C interface */
 457        buf[0] = USB_WRITE_I2C_CMD;
 458        buf[1] = 0x00;
 459
 460        /* enable I2C interface */
 461        buf[2] = I2C_MUX_REG;
 462        buf[3] = 0x80;
 463        buf[4] = 0x00;
 464
 465        /* enable I2C interface */
 466        buf[5] = I2C_MUX_REG;
 467        buf[6] = 0x81;
 468        buf[7] = 0x00;
 469
 470        /* set Timeout register on I2C interface */
 471        buf[8] = 0x14;
 472        buf[9] = 0xff;
 473        buf[10] = 0x00;
 474#if 0
 475        /* enable Interrupts on I2C interface */
 476        buf[8] = 0x24;
 477        buf[9] = 0xF7;
 478        buf[10] = 0x00;
 479#endif
 480        buf[11] = 0x24;
 481        buf[12] = 0xF7;
 482        buf[13] = 0x00;
 483
 484        ret = mxl111sf_i2c_send_data(state, 0, buf);
 485
 486        /* write data on I2C bus */
 487        if (!(msg->flags & I2C_M_RD) && (msg->len > 0)) {
 488                mxl_i2c("%d\t%02x", msg->len, msg->buf[0]);
 489
 490                /* control register on I2C interface to initialize I2C bus */
 491                buf[2] = I2C_CONTROL_REG;
 492                buf[3] = 0x5E;
 493                buf[4] = (HWI2C400) ? 0x03 : 0x0D;
 494
 495                /* I2C Slave device Address */
 496                buf[5] = I2C_SLAVE_ADDR_REG;
 497                buf[6] = (msg->addr);
 498                buf[7] = 0x00;
 499                buf[8] = USB_END_I2C_CMD;
 500                ret = mxl111sf_i2c_send_data(state, 0, buf);
 501
 502                /* check for slave device status */
 503                if (mxl111sf_i2c_check_status(state) == 1) {
 504                        mxl_i2c("NACK writing slave address %02x",
 505                                msg->addr);
 506                        /* if NACK, stop I2C bus and exit */
 507                        buf[2] = I2C_CONTROL_REG;
 508                        buf[3] = 0x4E;
 509                        buf[4] = (HWI2C400) ? 0x03 : 0x0D;
 510                        ret = -EIO;
 511                        goto exit;
 512                }
 513
 514                /* I2C interface can do I2C operations in block of 8 bytes of
 515                   I2C data. calculation to figure out number of blocks of i2c
 516                   data required to program */
 517                block_len = (msg->len / 8);
 518                left_over_len = (msg->len % 8);
 519                index = 0;
 520
 521                mxl_i2c("block_len %d, left_over_len %d",
 522                        block_len, left_over_len);
 523
 524                for (index = 0; index < block_len; index++) {
 525                        for (i = 0; i < 8; i++) {
 526                                /* write data on I2C interface */
 527                                buf[2+(i*3)] = I2C_DATA_REG;
 528                                buf[3+(i*3)] = msg->buf[(index*8)+i];
 529                                buf[4+(i*3)] = 0x00;
 530                        }
 531
 532                        ret = mxl111sf_i2c_send_data(state, 0, buf);
 533
 534                        /* check for I2C NACK status */
 535                        if (mxl111sf_i2c_check_status(state) == 1) {
 536                                mxl_i2c("NACK writing slave address %02x",
 537                                        msg->addr);
 538
 539                                /* if NACK, stop I2C bus and exit */
 540                                buf[2] = I2C_CONTROL_REG;
 541                                buf[3] = 0x4E;
 542                                buf[4] = (HWI2C400) ? 0x03 : 0x0D;
 543                                ret = -EIO;
 544                                goto exit;
 545                        }
 546
 547                }
 548
 549                if (left_over_len) {
 550                        for (k = 0; k < 26; k++)
 551                                buf[k] = USB_END_I2C_CMD;
 552
 553                        buf[0] = 0x99;
 554                        buf[1] = 0x00;
 555
 556                        for (i = 0; i < left_over_len; i++) {
 557                                buf[2+(i*3)] = I2C_DATA_REG;
 558                                buf[3+(i*3)] = msg->buf[(index*8)+i];
 559                                mxl_i2c("index = %d %d data %d",
 560                                        index, i, msg->buf[(index*8)+i]);
 561                                buf[4+(i*3)] = 0x00;
 562                        }
 563                        ret = mxl111sf_i2c_send_data(state, 0, buf);
 564
 565                        /* check for I2C NACK status */
 566                        if (mxl111sf_i2c_check_status(state) == 1) {
 567                                mxl_i2c("NACK writing slave address %02x",
 568                                        msg->addr);
 569
 570                                /* if NACK, stop I2C bus and exit */
 571                                buf[2] = I2C_CONTROL_REG;
 572                                buf[3] = 0x4E;
 573                                buf[4] = (HWI2C400) ? 0x03 : 0x0D;
 574                                ret = -EIO;
 575                                goto exit;
 576                        }
 577
 578                }
 579
 580                /* issue I2C STOP after write */
 581                buf[2] = I2C_CONTROL_REG;
 582                buf[3] = 0x4E;
 583                buf[4] = (HWI2C400) ? 0x03 : 0x0D;
 584
 585        }
 586
 587        /* read data from I2C bus */
 588        if ((msg->flags & I2C_M_RD) && (msg->len > 0)) {
 589                mxl_i2c("read buf len %d", msg->len);
 590
 591                /* command to indicate data payload is
 592                   destined for I2C interface */
 593                buf[2] = I2C_CONTROL_REG;
 594                buf[3] = 0xDF;
 595                buf[4] = (HWI2C400) ? 0x03 : 0x0D;
 596
 597                /* I2C xfer length */
 598                buf[5] = 0x14;
 599                buf[6] = (msg->len & 0xFF);
 600                buf[7] = 0;
 601
 602                /* I2C slave device Address */
 603                buf[8] = I2C_SLAVE_ADDR_REG;
 604                buf[9] = msg->addr;
 605                buf[10] = 0x00;
 606                buf[11] = USB_END_I2C_CMD;
 607                ret = mxl111sf_i2c_send_data(state, 0, buf);
 608
 609                /* check for I2C NACK status */
 610                if (mxl111sf_i2c_check_status(state) == 1) {
 611                        mxl_i2c("NACK reading slave address %02x",
 612                                msg->addr);
 613
 614                        /* if NACK, stop I2C bus and exit */
 615                        buf[2] = I2C_CONTROL_REG;
 616                        buf[3] = 0xC7;
 617                        buf[4] = (HWI2C400) ? 0x03 : 0x0D;
 618                        ret = -EIO;
 619                        goto exit;
 620                }
 621
 622                /* I2C interface can do I2C operations in block of 8 bytes of
 623                   I2C data. calculation to figure out number of blocks of
 624                   i2c data required to program */
 625                block_len = ((msg->len) / 8);
 626                left_over_len = ((msg->len) % 8);
 627                index = 0;
 628
 629                mxl_i2c("block_len %d, left_over_len %d",
 630                        block_len, left_over_len);
 631
 632                /* command to read data from I2C interface */
 633                buf[0] = USB_READ_I2C_CMD;
 634                buf[1] = 0x00;
 635
 636                for (index = 0; index < block_len; index++) {
 637                        /* setup I2C read request packet on I2C interface */
 638                        for (i = 0; i < 8; i++) {
 639                                buf[2+(i*3)] = I2C_DATA_REG;
 640                                buf[3+(i*3)] = 0x00;
 641                                buf[4+(i*3)] = 0x00;
 642                        }
 643
 644                        ret = mxl111sf_i2c_get_data(state, 0, buf, i2c_r_data);
 645
 646                        /* check for I2C NACK status */
 647                        if (mxl111sf_i2c_check_status(state) == 1) {
 648                                mxl_i2c("NACK reading slave address %02x",
 649                                        msg->addr);
 650
 651                                /* if NACK, stop I2C bus and exit */
 652                                buf[2] = I2C_CONTROL_REG;
 653                                buf[3] = 0xC7;
 654                                buf[4] = (HWI2C400) ? 0x03 : 0x0D;
 655                                ret = -EIO;
 656                                goto exit;
 657                        }
 658
 659                        /* copy data from i2c data payload to read buffer */
 660                        for (i = 0; i < 8; i++) {
 661                                rd_status[i] = i2c_r_data[(i*3)+2];
 662
 663                                if (rd_status[i] == 0x04) {
 664                                        if (i < 7) {
 665                                                mxl_i2c("i2c fifo empty! @ %d",
 666                                                        i);
 667                                                msg->buf[(index*8)+i] =
 668                                                        i2c_r_data[(i*3)+1];
 669                                                /* read again */
 670                                                ret_status =
 671                                                        mxl111sf_i2c_readagain(
 672                                                                state, 8-(i+1),
 673                                                                readbuff);
 674                                                if (ret_status == 1) {
 675                                                        for (k = 0;
 676                                                             k < 8-(i+1);
 677                                                             k++) {
 678
 679                                        msg->buf[(index*8)+(k+i+1)] =
 680                                                readbuff[k];
 681                                        mxl_i2c("read data: %02x\t %02x",
 682                                                msg->buf[(index*8)+(k+i)],
 683                                                (index*8)+(k+i));
 684                                        mxl_i2c("read data: %02x\t %02x",
 685                                                msg->buf[(index*8)+(k+i+1)],
 686                                                readbuff[k]);
 687
 688                                                        }
 689                                                        goto stop_copy;
 690                                                } else {
 691                                                        mxl_i2c("readagain ERROR!");
 692                                                }
 693                                        } else {
 694                                                msg->buf[(index*8)+i] =
 695                                                        i2c_r_data[(i*3)+1];
 696                                        }
 697                                } else {
 698                                        msg->buf[(index*8)+i] =
 699                                                i2c_r_data[(i*3)+1];
 700                                }
 701                        }
 702stop_copy:
 703                        ;
 704
 705                }
 706
 707                if (left_over_len) {
 708                        for (k = 0; k < 26; k++)
 709                                buf[k] = USB_END_I2C_CMD;
 710
 711                        buf[0] = 0xDD;
 712                        buf[1] = 0x00;
 713
 714                        for (i = 0; i < left_over_len; i++) {
 715                                buf[2+(i*3)] = I2C_DATA_REG;
 716                                buf[3+(i*3)] = 0x00;
 717                                buf[4+(i*3)] = 0x00;
 718                        }
 719                        ret = mxl111sf_i2c_get_data(state, 0, buf,
 720                                                    i2c_r_data);
 721
 722                        /* check for I2C NACK status */
 723                        if (mxl111sf_i2c_check_status(state) == 1) {
 724                                mxl_i2c("NACK reading slave address %02x",
 725                                        msg->addr);
 726
 727                                /* if NACK, stop I2C bus and exit */
 728                                buf[2] = I2C_CONTROL_REG;
 729                                buf[3] = 0xC7;
 730                                buf[4] = (HWI2C400) ? 0x03 : 0x0D;
 731                                ret = -EIO;
 732                                goto exit;
 733                        }
 734
 735                        for (i = 0; i < left_over_len; i++) {
 736                                msg->buf[(block_len*8)+i] =
 737                                        i2c_r_data[(i*3)+1];
 738                                mxl_i2c("read data: %02x\t %02x",
 739                                        i2c_r_data[(i*3)+1],
 740                                        i2c_r_data[(i*3)+2]);
 741                        }
 742                }
 743
 744                /* indicate I2C interface to issue NACK
 745                   after next I2C read op */
 746                buf[0] = USB_WRITE_I2C_CMD;
 747                buf[1] = 0x00;
 748
 749                /* control register */
 750                buf[2] = I2C_CONTROL_REG;
 751                buf[3] = 0x17;
 752                buf[4] = (HWI2C400) ? 0x03 : 0x0D;
 753
 754                buf[5] = USB_END_I2C_CMD;
 755                ret = mxl111sf_i2c_send_data(state, 0, buf);
 756
 757                /* control register */
 758                buf[2] = I2C_CONTROL_REG;
 759                buf[3] = 0xC7;
 760                buf[4] = (HWI2C400) ? 0x03 : 0x0D;
 761
 762        }
 763exit:
 764        /* STOP and disable I2C MUX */
 765        buf[0] = USB_WRITE_I2C_CMD;
 766        buf[1] = 0x00;
 767
 768        /* de-initilize I2C BUS */
 769        buf[5] = USB_END_I2C_CMD;
 770        mxl111sf_i2c_send_data(state, 0, buf);
 771
 772        /* Control Register */
 773        buf[2] = I2C_CONTROL_REG;
 774        buf[3] = 0xDF;
 775        buf[4] = 0x03;
 776
 777        /* disable I2C interface */
 778        buf[5] = I2C_MUX_REG;
 779        buf[6] = 0x00;
 780        buf[7] = 0x00;
 781
 782        /* de-initilize I2C BUS */
 783        buf[8] = USB_END_I2C_CMD;
 784        mxl111sf_i2c_send_data(state, 0, buf);
 785
 786        /* disable I2C interface */
 787        buf[2] = I2C_MUX_REG;
 788        buf[3] = 0x81;
 789        buf[4] = 0x00;
 790
 791        /* disable I2C interface */
 792        buf[5] = I2C_MUX_REG;
 793        buf[6] = 0x00;
 794        buf[7] = 0x00;
 795
 796        /* disable I2C interface */
 797        buf[8] = I2C_MUX_REG;
 798        buf[9] = 0x00;
 799        buf[10] = 0x00;
 800
 801        buf[11] = USB_END_I2C_CMD;
 802        mxl111sf_i2c_send_data(state, 0, buf);
 803
 804        return ret;
 805}
 806
 807/* ------------------------------------------------------------------------ */
 808
 809int mxl111sf_i2c_xfer(struct i2c_adapter *adap,
 810                      struct i2c_msg msg[], int num)
 811{
 812        struct dvb_usb_device *d = i2c_get_adapdata(adap);
 813        struct mxl111sf_state *state = d->priv;
 814        int hwi2c = (state->chip_rev > MXL111SF_V6);
 815        int i, ret;
 816
 817        if (mutex_lock_interruptible(&d->i2c_mutex) < 0)
 818                return -EAGAIN;
 819
 820        for (i = 0; i < num; i++) {
 821                ret = (hwi2c) ?
 822                        mxl111sf_i2c_hw_xfer_msg(state, &msg[i]) :
 823                        mxl111sf_i2c_sw_xfer_msg(state, &msg[i]);
 824                if (mxl_fail(ret)) {
 825                        mxl_debug_adv("failed with error %d on i2c transaction %d of %d, %sing %d bytes to/from 0x%02x",
 826                                      ret, i+1, num,
 827                                      (msg[i].flags & I2C_M_RD) ?
 828                                      "read" : "writ",
 829                                      msg[i].len, msg[i].addr);
 830
 831                        break;
 832                }
 833        }
 834
 835        mutex_unlock(&d->i2c_mutex);
 836
 837        return i == num ? num : -EREMOTEIO;
 838}
 839