diff options
author | Stefan Richter <stefanr@s5r6.in-berlin.de> | 2008-05-24 10:41:09 -0400 |
---|---|---|
committer | Stefan Richter <stefanr@s5r6.in-berlin.de> | 2008-07-14 07:06:03 -0400 |
commit | e534fe16b987780744da351acece2a4699783096 (patch) | |
tree | fdeafe1851b2b40b3def1f4135a7fc847deb595a /drivers/firewire/fw-transaction.c | |
parent | 435f972697fcd4c424db941f0ea8f2e38eda2b39 (diff) |
firewire: implement broadcast_channel CSR for 1394a compliance
See IEEE 1394a clause 8.3.2.3.11.
Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Diffstat (limited to 'drivers/firewire/fw-transaction.c')
-rw-r--r-- | drivers/firewire/fw-transaction.c | 20 |
1 files changed, 17 insertions, 3 deletions
diff --git a/drivers/firewire/fw-transaction.c b/drivers/firewire/fw-transaction.c index 03ae8a77c479..2f11ed1acf01 100644 --- a/drivers/firewire/fw-transaction.c +++ b/drivers/firewire/fw-transaction.c | |||
@@ -817,12 +817,13 @@ handle_registers(struct fw_card *card, struct fw_request *request, | |||
817 | int reg = offset & ~CSR_REGISTER_BASE; | 817 | int reg = offset & ~CSR_REGISTER_BASE; |
818 | unsigned long long bus_time; | 818 | unsigned long long bus_time; |
819 | __be32 *data = payload; | 819 | __be32 *data = payload; |
820 | int rcode = RCODE_COMPLETE; | ||
820 | 821 | ||
821 | switch (reg) { | 822 | switch (reg) { |
822 | case CSR_CYCLE_TIME: | 823 | case CSR_CYCLE_TIME: |
823 | case CSR_BUS_TIME: | 824 | case CSR_BUS_TIME: |
824 | if (!TCODE_IS_READ_REQUEST(tcode) || length != 4) { | 825 | if (!TCODE_IS_READ_REQUEST(tcode) || length != 4) { |
825 | fw_send_response(card, request, RCODE_TYPE_ERROR); | 826 | rcode = RCODE_TYPE_ERROR; |
826 | break; | 827 | break; |
827 | } | 828 | } |
828 | 829 | ||
@@ -831,7 +832,17 @@ handle_registers(struct fw_card *card, struct fw_request *request, | |||
831 | *data = cpu_to_be32(bus_time); | 832 | *data = cpu_to_be32(bus_time); |
832 | else | 833 | else |
833 | *data = cpu_to_be32(bus_time >> 25); | 834 | *data = cpu_to_be32(bus_time >> 25); |
834 | fw_send_response(card, request, RCODE_COMPLETE); | 835 | break; |
836 | |||
837 | case CSR_BROADCAST_CHANNEL: | ||
838 | if (tcode == TCODE_READ_QUADLET_REQUEST) | ||
839 | *data = cpu_to_be32(card->broadcast_channel); | ||
840 | else if (tcode == TCODE_WRITE_QUADLET_REQUEST) | ||
841 | card->broadcast_channel = | ||
842 | (be32_to_cpu(*data) & BROADCAST_CHANNEL_VALID) | | ||
843 | BROADCAST_CHANNEL_INITIAL; | ||
844 | else | ||
845 | rcode = RCODE_TYPE_ERROR; | ||
835 | break; | 846 | break; |
836 | 847 | ||
837 | case CSR_BUS_MANAGER_ID: | 848 | case CSR_BUS_MANAGER_ID: |
@@ -850,10 +861,13 @@ handle_registers(struct fw_card *card, struct fw_request *request, | |||
850 | 861 | ||
851 | case CSR_BUSY_TIMEOUT: | 862 | case CSR_BUSY_TIMEOUT: |
852 | /* FIXME: Implement this. */ | 863 | /* FIXME: Implement this. */ |
864 | |||
853 | default: | 865 | default: |
854 | fw_send_response(card, request, RCODE_ADDRESS_ERROR); | 866 | rcode = RCODE_ADDRESS_ERROR; |
855 | break; | 867 | break; |
856 | } | 868 | } |
869 | |||
870 | fw_send_response(card, request, rcode); | ||
857 | } | 871 | } |
858 | 872 | ||
859 | static struct fw_address_handler registers = { | 873 | static struct fw_address_handler registers = { |