1 /**************************************************************************/
4 @author K. Townsend (microBuilder.eu)
6 @brief Code to execute for cmd_chibi_addr in the 'core/cmd'
7 command-line interpretter.
11 Software License Agreement (BSD License)
13 Copyright (c) 2010, microBuilder SARL
16 Redistribution and use in source and binary forms, with or without
17 modification, are permitted provided that the following conditions are met:
18 1. Redistributions of source code must retain the above copyright
19 notice, this list of conditions and the following disclaimer.
20 2. Redistributions in binary form must reproduce the above copyright
21 notice, this list of conditions and the following disclaimer in the
22 documentation and/or other materials provided with the distribution.
23 3. Neither the name of the copyright holders nor the
24 names of its contributors may be used to endorse or promote products
25 derived from this software without specific prior written permission.
27 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ''AS IS'' AND ANY
28 EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
29 WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
30 DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY
31 DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
32 (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
33 LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
34 ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
35 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
36 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
38 /**************************************************************************/
41 #include "projectconfig.h"
42 #include "core/cmd/cmd.h"
43 #include "project/commands.h" // Generic helper functions
46 #include "drivers/chibi/chb.h"
47 #include "drivers/chibi/chb_drvr.h"
49 /**************************************************************************/
51 Gets or sets the 16-bit sensor node address. This value can be
52 anything between 1-65534 (0x0001-0xFFFE), and in decimal or
53 hexadecimal notation. All hexadecimal values must be preceded by
54 '0x' or '0X' to be properly interpreted (ex. 0x009F).
56 /**************************************************************************/
57 void cmd_chibi_addr(uint8_t argc
, char **argv
)
61 // Try to convert supplied value to an integer
63 getNumber (argv
[0], &addr
);
65 // Check for invalid values (getNumber may complain about this as well)
66 if (addr
<= 0 || addr
> 0xFFFF)
68 printf("Invalid Address: 1-65534 or 0x0001-0xFFFE required.%s", CFG_PRINTF_NEWLINE
);
73 printf("Invalid Address: 0xFFFF reserved for broadcast.%s", CFG_PRINTF_NEWLINE
);
77 // Write address to EEPROM and update peripheral control block
78 chb_set_short_addr((uint16_t)addr
);
79 chb_pcb_t
*pcb
= chb_get_pcb();
80 printf("Address set to: 0x%04X%s", pcb
->src_addr
, CFG_PRINTF_NEWLINE
);
84 // Display the current address
85 chb_pcb_t
*pcb
= chb_get_pcb();
86 printf("0x%04X%s", pcb
->src_addr
, CFG_PRINTF_NEWLINE
);
This page took 0.049534 seconds and 5 git commands to generate.