blob: 2940b910b3043750d6941cca4263e4b3d3352668 [file] [log] [blame]
/*
* Copyright 2018-present Open Networking Foundation
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __VENDOR_H__
#define __VENDOR_H__
#include "device.h"
#define VENDOR_ID "Radisys"
#define RLT1600GW
#define MODEL_ID "rlt-1600g-w"
#define MAX_SUPPORTED_PON 16
#define ONU_BIT_TRANSMISSION_DELAY 0.8038585/1000 /* unit: ns to us */
#define MINIMUM_ONU_RESPONSE_RANGING_TIME 198075 /* hardcore: this is ranging time for the shortest distance, typically 35us */
#define DEFAULT_MAC_SYSTEM_MODE BCMOLT_SYSTEM_MODE_GPON__16_X
//#define DEFAULT_MAC_SYSTEM_MODE BCMOLT_SYSTEM_MODE_XGS__2_X
#define DEFAULT_PON_MODE BCMOLT_PON_TYPE_GPON
// #define DEFAULT_PON_MODE BCMOLT_PON_TYPE_XGPON
// DeviceInfo definitions
#define ONU_ID_START 1
#define ONU_ID_END 32
#define MAX_ONUS_PER_PON (ONU_ID_END - ONU_ID_START + 1)
#define MAX_ALLOC_ID_PER_ONU 4
#define ALLOC_ID_START 256
#define ALLOC_ID_END (ALLOC_ID_START + MAX_ONUS_PER_PON * MAX_ALLOC_ID_PER_ONU)
#define GEM_PORT_ID_PER_ALLOC_ID 8
#define GEM_PORT_ID_START 256
#define GEM_PORT_ID_END (GEM_PORT_ID_START + MAX_ONUS_PER_PON * MAX_ALLOC_ID_PER_ONU * GEM_PORT_ID_PER_ALLOC_ID)
#define FLOW_ID_START 1
#define FLOW_ID_END 65535
#define MAX_FLOW_ID FLOW_ID_END
#define INVALID_FLOW_ID 0
#define MAC_DEVICE_ACTIVATION_DELAY 200000 // in microseconds
#define TOTAL_PON_TRX_PORTS 16 // total PON transceiver ports
#define TOTAL_PON_PORTS 16 // total PON ports (we could have up to 2 PON ports on the OLT MAC mapped to the external PON Trx)
const int trx_port_to_pon_port_map[TOTAL_PON_TRX_PORTS][TOTAL_PON_PORTS/TOTAL_PON_TRX_PORTS]={{0},{1},{2},{3},{4},{5},{6},{7},{8},{9},{10},
{11},{12},{13},{14},{15}};
#define PONS_PER_TRX (TOTAL_PON_TRX_PORTS/TOTAL_PON_PORTS) // if there are more than one OLT MAC device,
// they all have to be of the same type for this to work.
// FIXME: These may not be correct for this platform
const int bus_index[TOTAL_PON_TRX_PORTS] = {
41, 42, 56, 55, 43, 44, 54, 53,
45, 46, 52, 51, 47, 48, 50, 49
};
// FIXME: Check the correctness of the below constants for this platform
#define PORT_ADDRESS 50
#define NAME_EEPROM "eeprom"
#define EEPROM_VENDOR_NAME_START_IDX 20
#define EEPROM_VENDOR_NAME_LENGTH 16
#define EEPROM_VENDOR_OUI_START_IDX 37
#define EEPROM_VENDOR_OUI_LENGTH 3
#define EEPROM_VENDOR_PART_NUMBER_START_IDX 40
#define EEPROM_VENDOR_PART_NUMBER_LENGTH 16
#define EEPROM_VENDOR_REVISION_START_IDX 56
#define EEPROM_VENDOR_REVISION_LENGTH 4
#define EEPROM_DOWNSTREAM_WAVELENGTH_START_IDX 60
#define EEPROM_DOWNSTREAM_WAVELENGTH_LENGTH 2
#define EEPROM_WAVELENGTH_RESOLUTION 1
// Define valid values below in case of Combo PON Trx is supported
// #define EEPROM_DOWNSTREAM_SECONDARY_WAVELENGTH_START_IDX 120
// #define EEPROM_DOWNSTREAM_SECONDARY_WAVELENGTH_LENGTH 2
class PonTrx: public PonTrxBase {
// override the base member functions if you need a different implementation
};
#endif