Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | gsm0808: Import unaligned mem access fix from on-waves/bsc-master | Holger Hans Peter Freyther | 2010-07-23 | 2 | -5/+10 |
| | |||||
* | gsm_utils: Move the gsm_7bit_alphabet into the impl and make it static | Holger Hans Peter Freyther | 2010-07-23 | 2 | -28/+27 |
| | |||||
* | msgb: Check for available headroom/tailroom and abort() if we violate it | Harald Welte | 2010-07-22 | 1 | -4/+31 |
| | |||||
* | gsm_04_12.h: Add beginning of structs for SMS CB | Holger Hans Peter Freyther | 2010-07-21 | 2 | -1/+33 |
| | | | | | I am trying to understand the RSL and GSM 04.12 spec to implement CBS for OpenBSC... | ||||
* | gsm_7bit_decode: rtext does not hold a null byte, reduce the size | Holger Hans Peter Freyther | 2010-07-21 | 1 | -1/+1 |
| | | | | | I have added the + 1 as I thought rtext will hold a terminating null byte but it will not. | ||||
* | tests: don't hardcode length values of expected encoding gsm_7bit_encode: | Nico Golde | 2010-07-21 | 2 | -15/+16 |
| | | | | | | | | | make sure to return the number of actually written bytes gsm_7bit_decode: calculate length of resulting septets from input length before decoding The input length to gsm_7bit_decode reflects the number of encoded bytes to be decoded. As the decoding is done on the input in septetes we need to take this into account and recalculate the length. | ||||
* | gsm_7bit_decode: Handle the case of the last charachter being an escape | Holger Hans Peter Freyther | 2010-07-20 | 1 | -1/+1 |
| | | | | | If i + 1 == length and it is an escape charachter we would try to read rtext[length] which is one after the field we have allocated. | ||||
* | tests: Separate encoding/decoding test to verify them independly | Holger Hans Peter Freyther | 2010-07-20 | 1 | -17/+78 |
| | | | | | | Use the current test result as test data for future regression testing. The encode function appears to add too many zeros to the text. | ||||
* | * rewrite GSM 7bit default encoding/decoding based on a lookup table as the ↵ | Nico Golde | 2010-07-20 | 3 | -21/+123 |
| | | | | previous code produced wrong encodings for certain characters. | ||||
* | Added crc16 from linux kernel. | Ingo Albrecht | 2010-07-15 | 4 | -2/+98 |
| | |||||
* | [VTY] add support for numeric ranges with negative numbers | Andreas Eversberg | 2010-07-13 | 1 | -31/+67 |
| | | | | This enables us to do something like <-128-127> as a numeric range. | ||||
* | [RSL] split rsl_rll_push_l3() L3 LV pushign and rsl_rll_push_hdr() | Harald Welte | 2010-07-13 | 3 | -10/+40 |
| | | | | | This allows us to generate RSLms messages that have some non-standard IEs between the RSL/RLL common header and the L3 INFO IE. | ||||
* | Add 3-digit MNC support to gsm48_generate_lai() | Andreas Eversberg | 2010-07-12 | 1 | -7/+7 |
| | |||||
* | Added new IE definitions to gsm_04_08.h of libosmocore. | Andreas Eversberg | 2010-07-12 | 3 | -21/+554 |
| | | | | | | Also added RR and MM TLV tables to gsm48.c [import from accidential commit to osmocom-bb.git] | ||||
* | Added single octet TV (type + value) to libosmocore. | Andreas Eversberg | 2010-07-12 | 2 | -0/+9 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In case of a single octet, the upper nibble is the type, the lower nibble carries the value. [import from accidentially committed changes to osmocom-bb.git] diff --git a/src/shared/libosmocore/include/osmocore/tlv.h b/src/shared/libosmocore/include/osmocore/tlv.h index c733dbc..4cfce87 100644 --- a/src/shared/libosmocore/include/osmocore/tlv.h +++ b/src/shared/libosmocore/include/osmocore/tlv.h @@ -212,6 +212,7 @@ enum tlv_type { TLV_TYPE_TLV, TLV_TYPE_TL16V, TLV_TYPE_TvLV, + TLV_TYPE_SINGLE_TV }; struct tlv_def { diff --git a/src/shared/libosmocore/src/tlv_parser.c b/src/shared/libosmocore/src/tlv_parser.c index 407e57a..bbef7a9 100644 --- a/src/shared/libosmocore/src/tlv_parser.c +++ b/src/shared/libosmocore/src/tlv_parser.c @@ -36,6 +36,14 @@ int tlv_parse_one(uint8_t *o_tag, uint16_t *o_len, const uint8_t **o_val, tag = *buf; *o_tag = tag; + /* single octet TV IE */ + if (def->def[tag & 0xf0].type == TLV_TYPE_SINGLE_TV) { + *o_tag = tag & 0xf0; + *o_val = buf; + *o_len = 1; + return 1; + } + /* FIXME: use tables for knwon IEI */ switch (def->def[tag].type) { case TLV_TYPE_T: | ||||
* | gsm_utils: Fix typo in gsm band name | Sylvain Munaut | 2010-07-04 | 1 | -1/+1 |
| | | | | | | thanks to horizon for noticing :p Signed-off-by: Sylvain Munaut <tnt@246tNt.com> | ||||
* | GPRS: Add 'input' generator functions for GPRS cipher algorithm | Harald Welte | 2010-06-30 | 2 | -0/+20 |
| | |||||
* | Add support for plugins (and specifically GPRS encryption plugins) | Harald Welte | 2010-06-30 | 9 | -3/+222 |
| | |||||
* | [gsmtap] add new gsmtap_makemsg() function | Harald Welte | 2010-06-29 | 2 | -8/+28 |
| | | | | | This generates a gsmtap message without actually enqueueing to a bsc_select style queue. | ||||
* | Add gsmtap utility functions to libosmocore | Harald Welte | 2010-06-29 | 4 | -2/+203 |
| | | | | This is imported from OsmocomBB/Layer23 | ||||
* | Fix typo in configure script regarding --disable-vty | Harald Welte | 2010-06-25 | 1 | -1/+1 |
| | |||||
* | [RSL] Added special RSL message types for mobile side | Andreas Eversberg | 2010-06-25 | 1 | -0/+4 |
| | | | | | | - suspension DL - resume DL - re-establish DL | ||||
* | [gsm48] fix typo in struct gsm48_req_ref | Andreas Eversberg | 2010-06-25 | 1 | -1/+1 |
| | |||||
* | [GSM 04.08] add more RR IEIs | Harald Welte | 2010-06-15 | 1 | -0/+9 |
| | |||||
* | gsm48: Add authentication response message | Sylvain Munaut | 2010-06-10 | 1 | -0/+5 |
| | | | | Signed-off-by: Sylvain Munaut <tnt@246tNt.com> | ||||
* | gsm_utils: Add a fn to test A5(x) support given a classmark2 | Sylvain Munaut | 2010-06-09 | 1 | -0/+12 |
| | | | | Signed-off-by: Sylvain Munaut <tnt@246tNt.com> | ||||
* | vty: Mark app info strings as const char*. | Holger Hans Peter Freyther | 2010-06-08 | 1 | -3/+3 |
| | |||||
* | Merge remote branch 'origin/master' | Harald Welte | 2010-06-01 | 3 | -42/+22 |
|\ | |||||
| * | add new new gprs_tmsi2tlli() function | Harald Welte | 2010-06-01 | 2 | -1/+20 |
| | | |||||
| * | [VTY] Remove all application specific VTY node definitions from enum | Harald Welte | 2010-05-31 | 1 | -41/+2 |
| | | |||||
* | | add configure option '--disable-vty' to prevent building libosmovty | Harald Welte | 2010-05-29 | 3 | -0/+10 |
|/ | |||||
* | [VTY] Introduce "struct vty_app_info" for vty_init() function | Harald Welte | 2010-05-25 | 4 | -19/+22 |
| | |||||
* | rename log_info to osmo_log_info to avoid namespace clash with app | Harald Welte | 2010-05-25 | 2 | -17/+17 |
| | |||||
* | fix typo resultin in dist/distcheck problem | Harald Welte | 2010-05-25 | 1 | -1/+1 |
| | |||||
* | Add pkgconfig for libosmovty | Harald Welte | 2010-05-25 | 3 | -1/+13 |
| | |||||
* | make sure we actually install the vty headers | Harald Welte | 2010-05-25 | 1 | -2/+4 |
| | |||||
* | Create libosmovty as library from OpenBSC VTY functions | Harald Welte | 2010-05-25 | 20 | -2/+6893 |
| | |||||
* | rate_ctr: Make the struct rate_ctr_group_desc members const | Holger Hans Peter Freyther | 2010-05-23 | 1 | -4/+4 |
| | |||||
* | Added some "get"-functions to bitvec of libosmocore. | Andreas.Eversberg | 2010-05-19 | 2 | -0/+59 |
| | | | | | - Getting Low or High value from current postion - Getting unsigned interger from current postion | ||||
* | gsm0808: Add API to wrap a GSM48 msg with a BSSMAP/DTAP msg. | Holger Hans Peter Freyther | 2010-05-16 | 2 | -0/+10 |
| | |||||
* | gsm48: Add paging response header | Holger Hans Peter Freyther | 2010-05-15 | 1 | -0/+9 |
| | |||||
* | gsm0808: Add TLV entries for types used by the Compl Layer3 Information | Holger Hans Peter Freyther | 2010-05-14 | 1 | -0/+3 |
| | |||||
* | [rate_ctr] always 'overflow' in next larger inetrval when interval ends | Harald Welte | 2010-05-13 | 1 | -0/+6 |
| | | | | | | | | | | | If a second ends, we add the number of events in that just-ended second to the number of events in the currently running minute. The same happens at the end of a minute: We add the number of events in that just-ended minute into the number of events of the still-running hour, etc. This gives a much more meaningful numbers and we don't end up with "12 events per second, but 0 events per minute" kind of situations anymore. | ||||
* | [rate_ctr] Rename group_prefix_fmt to group_name_prefix | Harald Welte | 2010-05-13 | 1 | -2/+2 |
| | |||||
* | rate_counters: Remove group-name-sprintf-with-idx string | Harald Welte | 2010-05-13 | 2 | -5/+1 |
| | |||||
* | rate_ctr: Store the numeric index as part of 'rate_ctr_group' | Harald Welte | 2010-05-13 | 2 | -0/+2 |
| | |||||
* | Add new 'rate counter' implementation to libosmocore | Harald Welte | 2010-05-13 | 4 | -2/+207 |
| | | | | | | | | | | | A 'rate counter' is a counter that counts events but also keeps track of the rate of events (per second, minute, hour and day). 'rate counters' are generally abstracted in 'rate counter groups', which are instances of a 'rate counter group description'. This way we can have e.g. a description describing what kind of counters a BTS (or TRX) has - and we can then create one instance of that group for every BTS or TRX that exists. | ||||
* | logging: add log_vty_{level,category}_string() | Harald Welte | 2010-05-11 | 2 | -0/+50 |
| | |||||
* | logging: introuduce log_level_str() to obtain the name of a log level | Harald Welte | 2010-05-11 | 2 | -0/+6 |
| | |||||
* | msgb: initialize cb[] to zero during msgb_reset() | Harald Welte | 2010-05-01 | 1 | -0/+2 |
| |