Moved USB API for manipulating RF chip registers into separate files.
This commit is contained in:
@ -34,6 +34,7 @@ SRC = $(BINARY).c \
|
|||||||
usb_device.c \
|
usb_device.c \
|
||||||
usb_endpoint.c \
|
usb_endpoint.c \
|
||||||
usb_api_cpld.c \
|
usb_api_cpld.c \
|
||||||
|
usb_api_register.c \
|
||||||
usb_api_spiflash.c \
|
usb_api_spiflash.c \
|
||||||
../common/usb_queue.c \
|
../common/usb_queue.c \
|
||||||
../common/fault_handler.c \
|
../common/fault_handler.c \
|
||||||
|
@ -30,10 +30,8 @@
|
|||||||
#include <libopencm3/lpc43xx/sgpio.h>
|
#include <libopencm3/lpc43xx/sgpio.h>
|
||||||
|
|
||||||
#include <hackrf_core.h>
|
#include <hackrf_core.h>
|
||||||
#include <si5351c.h>
|
|
||||||
#include <max5864.h>
|
#include <max5864.h>
|
||||||
#include <max2837.h>
|
#include <max2837.h>
|
||||||
#include <rffc5071.h>
|
|
||||||
#include <w25q80bv.h>
|
#include <w25q80bv.h>
|
||||||
#include <sgpio.h>
|
#include <sgpio.h>
|
||||||
#include <rom_iap.h>
|
#include <rom_iap.h>
|
||||||
@ -48,6 +46,7 @@
|
|||||||
#include "usb_device.h"
|
#include "usb_device.h"
|
||||||
#include "usb_endpoint.h"
|
#include "usb_endpoint.h"
|
||||||
#include "usb_api_cpld.h"
|
#include "usb_api_cpld.h"
|
||||||
|
#include "usb_api_register.h"
|
||||||
#include "usb_api_spiflash.h"
|
#include "usb_api_spiflash.h"
|
||||||
|
|
||||||
#include "rf_path.h"
|
#include "rf_path.h"
|
||||||
@ -139,81 +138,6 @@ usb_request_status_t usb_vendor_request_set_transceiver_mode(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
usb_request_status_t usb_vendor_request_write_max2837(
|
|
||||||
usb_endpoint_t* const endpoint,
|
|
||||||
const usb_transfer_stage_t stage
|
|
||||||
) {
|
|
||||||
if( stage == USB_TRANSFER_STAGE_SETUP ) {
|
|
||||||
if( endpoint->setup.index < MAX2837_NUM_REGS ) {
|
|
||||||
if( endpoint->setup.value < MAX2837_DATA_REGS_MAX_VALUE ) {
|
|
||||||
max2837_reg_write(endpoint->setup.index, endpoint->setup.value);
|
|
||||||
usb_transfer_schedule_ack(endpoint->in);
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return USB_REQUEST_STATUS_STALL;
|
|
||||||
} else {
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
usb_request_status_t usb_vendor_request_read_max2837(
|
|
||||||
usb_endpoint_t* const endpoint,
|
|
||||||
const usb_transfer_stage_t stage
|
|
||||||
) {
|
|
||||||
if( stage == USB_TRANSFER_STAGE_SETUP ) {
|
|
||||||
if( endpoint->setup.index < MAX2837_NUM_REGS ) {
|
|
||||||
const uint16_t value = max2837_reg_read(endpoint->setup.index);
|
|
||||||
endpoint->buffer[0] = value & 0xff;
|
|
||||||
endpoint->buffer[1] = value >> 8;
|
|
||||||
usb_transfer_schedule_block(endpoint->in, &endpoint->buffer, 2,
|
|
||||||
NULL, NULL);
|
|
||||||
usb_transfer_schedule_ack(endpoint->out);
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
return USB_REQUEST_STATUS_STALL;
|
|
||||||
} else {
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
usb_request_status_t usb_vendor_request_write_si5351c(
|
|
||||||
usb_endpoint_t* const endpoint,
|
|
||||||
const usb_transfer_stage_t stage
|
|
||||||
) {
|
|
||||||
if( stage == USB_TRANSFER_STAGE_SETUP ) {
|
|
||||||
if( endpoint->setup.index < 256 ) {
|
|
||||||
if( endpoint->setup.value < 256 ) {
|
|
||||||
si5351c_write_single(endpoint->setup.index, endpoint->setup.value);
|
|
||||||
usb_transfer_schedule_ack(endpoint->in);
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return USB_REQUEST_STATUS_STALL;
|
|
||||||
} else {
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
usb_request_status_t usb_vendor_request_read_si5351c(
|
|
||||||
usb_endpoint_t* const endpoint,
|
|
||||||
const usb_transfer_stage_t stage
|
|
||||||
) {
|
|
||||||
if( stage == USB_TRANSFER_STAGE_SETUP ) {
|
|
||||||
if( endpoint->setup.index < 256 ) {
|
|
||||||
const uint8_t value = si5351c_read_single(endpoint->setup.index);
|
|
||||||
endpoint->buffer[0] = value;
|
|
||||||
usb_transfer_schedule_block(endpoint->in, &endpoint->buffer, 1,
|
|
||||||
NULL, NULL);
|
|
||||||
usb_transfer_schedule_ack(endpoint->out);
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
return USB_REQUEST_STATUS_STALL;
|
|
||||||
} else {
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
usb_request_status_t usb_vendor_request_set_baseband_filter_bandwidth(
|
usb_request_status_t usb_vendor_request_set_baseband_filter_bandwidth(
|
||||||
usb_endpoint_t* const endpoint,
|
usb_endpoint_t* const endpoint,
|
||||||
const usb_transfer_stage_t stage
|
const usb_transfer_stage_t stage
|
||||||
@ -230,46 +154,6 @@ usb_request_status_t usb_vendor_request_set_baseband_filter_bandwidth(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
usb_request_status_t usb_vendor_request_write_rffc5071(
|
|
||||||
usb_endpoint_t* const endpoint,
|
|
||||||
const usb_transfer_stage_t stage
|
|
||||||
) {
|
|
||||||
if( stage == USB_TRANSFER_STAGE_SETUP )
|
|
||||||
{
|
|
||||||
if( endpoint->setup.index < RFFC5071_NUM_REGS )
|
|
||||||
{
|
|
||||||
rffc5071_reg_write(endpoint->setup.index, endpoint->setup.value);
|
|
||||||
usb_transfer_schedule_ack(endpoint->in);
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
return USB_REQUEST_STATUS_STALL;
|
|
||||||
} else {
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
usb_request_status_t usb_vendor_request_read_rffc5071(
|
|
||||||
usb_endpoint_t* const endpoint,
|
|
||||||
const usb_transfer_stage_t stage
|
|
||||||
) {
|
|
||||||
uint16_t value;
|
|
||||||
if( stage == USB_TRANSFER_STAGE_SETUP )
|
|
||||||
{
|
|
||||||
if( endpoint->setup.index < RFFC5071_NUM_REGS )
|
|
||||||
{
|
|
||||||
value = rffc5071_reg_read(endpoint->setup.index);
|
|
||||||
endpoint->buffer[0] = value & 0xff;
|
|
||||||
endpoint->buffer[1] = value >> 8;
|
|
||||||
usb_transfer_schedule_block(endpoint->in, &endpoint->buffer, 2,
|
|
||||||
NULL, NULL);
|
|
||||||
usb_transfer_schedule_ack(endpoint->out);
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
return USB_REQUEST_STATUS_STALL;
|
|
||||||
} else {
|
|
||||||
return USB_REQUEST_STATUS_OK;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
usb_request_status_t usb_vendor_request_read_board_id(
|
usb_request_status_t usb_vendor_request_read_board_id(
|
||||||
usb_endpoint_t* const endpoint, const usb_transfer_stage_t stage)
|
usb_endpoint_t* const endpoint, const usb_transfer_stage_t stage)
|
||||||
{
|
{
|
||||||
|
147
firmware/hackrf_usb/usb_api_register.c
Normal file
147
firmware/hackrf_usb/usb_api_register.c
Normal file
@ -0,0 +1,147 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012 Jared Boone
|
||||||
|
* Copyright 2013 Benjamin Vernoux
|
||||||
|
*
|
||||||
|
* This file is part of HackRF.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2, or (at your option)
|
||||||
|
* any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; see the file COPYING. If not, write to
|
||||||
|
* the Free Software Foundation, Inc., 51 Franklin Street,
|
||||||
|
* Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "usb_api_register.h"
|
||||||
|
|
||||||
|
#include <usb_queue.h>
|
||||||
|
#include <max2837.h>
|
||||||
|
#include <si5351c.h>
|
||||||
|
#include <rffc5071.h>
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
usb_request_status_t usb_vendor_request_write_max2837(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
) {
|
||||||
|
if( stage == USB_TRANSFER_STAGE_SETUP ) {
|
||||||
|
if( endpoint->setup.index < MAX2837_NUM_REGS ) {
|
||||||
|
if( endpoint->setup.value < MAX2837_DATA_REGS_MAX_VALUE ) {
|
||||||
|
max2837_reg_write(endpoint->setup.index, endpoint->setup.value);
|
||||||
|
usb_transfer_schedule_ack(endpoint->in);
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return USB_REQUEST_STATUS_STALL;
|
||||||
|
} else {
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
usb_request_status_t usb_vendor_request_read_max2837(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
) {
|
||||||
|
if( stage == USB_TRANSFER_STAGE_SETUP ) {
|
||||||
|
if( endpoint->setup.index < MAX2837_NUM_REGS ) {
|
||||||
|
const uint16_t value = max2837_reg_read(endpoint->setup.index);
|
||||||
|
endpoint->buffer[0] = value & 0xff;
|
||||||
|
endpoint->buffer[1] = value >> 8;
|
||||||
|
usb_transfer_schedule_block(endpoint->in, &endpoint->buffer, 2,
|
||||||
|
NULL, NULL);
|
||||||
|
usb_transfer_schedule_ack(endpoint->out);
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
return USB_REQUEST_STATUS_STALL;
|
||||||
|
} else {
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
usb_request_status_t usb_vendor_request_write_si5351c(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
) {
|
||||||
|
if( stage == USB_TRANSFER_STAGE_SETUP ) {
|
||||||
|
if( endpoint->setup.index < 256 ) {
|
||||||
|
if( endpoint->setup.value < 256 ) {
|
||||||
|
si5351c_write_single(endpoint->setup.index, endpoint->setup.value);
|
||||||
|
usb_transfer_schedule_ack(endpoint->in);
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return USB_REQUEST_STATUS_STALL;
|
||||||
|
} else {
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
usb_request_status_t usb_vendor_request_read_si5351c(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
) {
|
||||||
|
if( stage == USB_TRANSFER_STAGE_SETUP ) {
|
||||||
|
if( endpoint->setup.index < 256 ) {
|
||||||
|
const uint8_t value = si5351c_read_single(endpoint->setup.index);
|
||||||
|
endpoint->buffer[0] = value;
|
||||||
|
usb_transfer_schedule_block(endpoint->in, &endpoint->buffer, 1,
|
||||||
|
NULL, NULL);
|
||||||
|
usb_transfer_schedule_ack(endpoint->out);
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
return USB_REQUEST_STATUS_STALL;
|
||||||
|
} else {
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
usb_request_status_t usb_vendor_request_write_rffc5071(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
) {
|
||||||
|
if( stage == USB_TRANSFER_STAGE_SETUP )
|
||||||
|
{
|
||||||
|
if( endpoint->setup.index < RFFC5071_NUM_REGS )
|
||||||
|
{
|
||||||
|
rffc5071_reg_write(endpoint->setup.index, endpoint->setup.value);
|
||||||
|
usb_transfer_schedule_ack(endpoint->in);
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
return USB_REQUEST_STATUS_STALL;
|
||||||
|
} else {
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
usb_request_status_t usb_vendor_request_read_rffc5071(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
) {
|
||||||
|
uint16_t value;
|
||||||
|
if( stage == USB_TRANSFER_STAGE_SETUP )
|
||||||
|
{
|
||||||
|
if( endpoint->setup.index < RFFC5071_NUM_REGS )
|
||||||
|
{
|
||||||
|
value = rffc5071_reg_read(endpoint->setup.index);
|
||||||
|
endpoint->buffer[0] = value & 0xff;
|
||||||
|
endpoint->buffer[1] = value >> 8;
|
||||||
|
usb_transfer_schedule_block(endpoint->in, &endpoint->buffer, 2,
|
||||||
|
NULL, NULL);
|
||||||
|
usb_transfer_schedule_ack(endpoint->out);
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
return USB_REQUEST_STATUS_STALL;
|
||||||
|
} else {
|
||||||
|
return USB_REQUEST_STATUS_OK;
|
||||||
|
}
|
||||||
|
}
|
54
firmware/hackrf_usb/usb_api_register.h
Normal file
54
firmware/hackrf_usb/usb_api_register.h
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012 Jared Boone
|
||||||
|
* Copyright 2013 Benjamin Vernoux
|
||||||
|
*
|
||||||
|
* This file is part of HackRF.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2, or (at your option)
|
||||||
|
* any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; see the file COPYING. If not, write to
|
||||||
|
* the Free Software Foundation, Inc., 51 Franklin Street,
|
||||||
|
* Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __USB_API_REGISTER_H__
|
||||||
|
#define __USB_API_REGISTER_H__
|
||||||
|
|
||||||
|
#include <usb_type.h>
|
||||||
|
#include <usb_request.h>
|
||||||
|
|
||||||
|
usb_request_status_t usb_vendor_request_write_max2837(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
);
|
||||||
|
usb_request_status_t usb_vendor_request_read_max2837(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
);
|
||||||
|
usb_request_status_t usb_vendor_request_write_si5351c(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
);
|
||||||
|
usb_request_status_t usb_vendor_request_read_si5351c(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
);
|
||||||
|
usb_request_status_t usb_vendor_request_write_rffc5071(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
);
|
||||||
|
usb_request_status_t usb_vendor_request_read_rffc5071(
|
||||||
|
usb_endpoint_t* const endpoint,
|
||||||
|
const usb_transfer_stage_t stage
|
||||||
|
);
|
||||||
|
|
||||||
|
#endif /* end of include guard: __USB_API_REGISTER_H__ */
|
Reference in New Issue
Block a user