Sunday, 5 April 2020

Rexon RDM150D Retrofit ESTOP Stage 2

Summary
This blog details the second stage retrofit of a Rexon RDM150D drill press. The second stage added movement monitoring of the spindle and a requirement to  deactivate the drill press run switch after triggering the ESTOP. The first stage retrofit blog contained details relating to controller design and the drill press wiring.

Electrical Wiring - Stage 1
The first stage changes to the drill press electrical, which included the ESTOP button and controller, are shown in the image below.


Rexon RDM150D Stage 1 Electrical
Rexon RDM150D Stage 1 Electrical

Electrical Wiring - Stage 2
For the second stage retrofit, a proximity switch and a relay were added to the design. Both the new devices were connected to the controller.


Rexon RDM150D Stage 2 Electrical
Rexon RDM150D Stage 2 Electrical
Inductive Sensor
For detection of rotational movement in the pulley responsible for driving the spindle, an inductive sensor was selected.

MCPIP-T12L-001 Courtesy Multicomp
      MCPIP-T12L-001 Courtesy Multicomp

The sensor was manufactured by Multicomp, part MCPIP-T12L-001, which features a PNP output, M12 thread and a 2mm sensing distance.


Inductive Sensor PNP Electrical Connections
Inductive Sensor PNP Electrical Connections
DIN Relay
A relay was added to detect when the manual switch (DPDT) was in the ON state. Providing the manual switch state to the controller served two purposes, firstly the controller could determine when the spindle was active and secondly the same feedback signal could be used to ensure that the manual switch was OFF before the contactor was reactivated.


DIN Relay 2909526 Courtesy Phoenix Contact
DIN Relay 2909526 Courtesy Phoenix Contact

The relay used was a DIN style, 240V input, from Phoenix Contact.

As shown in the second stage electrical drawing above, the input to the relay was driven from the equipment side of the manual ON OFF switch. The pair of secondary side relay Normally Open connections were individually connected to 24V and the Spindle Active input of the controller.


Sensor Hardware and Mounting
An oversight with the Multicomp sensor installation was the devices body length which prevented the sensor being mounted between two pulleys.


Sensor Mounting Bracket
Sensor Mounting Bracket
To mount the sensor inside the top housing of the drill press, a repurposed wall bracket was drilled to the required hole size (M12). Loctite 243 was used on the sensor thread. The bracket was fitted at an angle as shown in the above image. This prevented use of the lowest belt position between the spindle and middle pulleys. A shorter sensor, placed parallel to the belts, would be recommended for those implementing this design.

Triggering the sensor was achieved using a small steel angle fitted to the pulley. For a speed of 3000 RPM, best results were achieved when the length of the steel angle was 20 mm. Two M3 bolts with Loctite 243 and internal star washers were used to fix the steel bracket in position.


Sensor Steel Pulley Bracket
Sensor Steel Pulley Bracket

Sensor Test Measurement
With the Multicomp sensor powered and an Oscilloscope fitted to the Out connection, one measurement was taken at a slow RPM and the second measurement at the fastest RPM.

Slow RPM Sensor Measurement
Slow RPM Sensor Measurement

Fast RPM Sensor Measurement
Fast RPM Sensor Measurement

Relay Mounting
The DIN relay was mounted between the contactor and the controller, as pictured below.

Electrical Enclosure DIN Relay Mounting
Electrical Enclosure DIN Relay Mounting

PSoC Inputs
The spindle and spindle active inputs to the PSoC controller were provisioned in the first stage controller design. Connections were made according to the updated inputs detailed in the section below.

PSoC Inductive Spindle Input
PSoC Inductive Spindle Input

Controller Wiring
A correction was required to the controller PCB overlay. The capture below shows the updated overlay reflecting the controller connections.

Retrofit Rexon Controller Updated PCB Overlay
Retrofit Rexon Controller Updated PCB Overlay

Controller Option
To identify new features were added to the controller, one of the option resistors was populated on the controller PCB.


Enabling Controller Option on PCB
Enabling Controller Option on PCB

PSoC Code Changes
The principal change to the PSoC was the addition of logic for counting pulses from the inductive sensor.


PSoC Windowed Pulse Counter
PSoC Windowed Pulse Counter

A timer solution was implemented fifty percent duty cycle with a period of 499 ms. During the On time the Timer_Spindle component accumulated counts from the Spindle input. At the end of the capture the isr_Spindle fires allowing the count value to be retrieved. For the remainder of the period no counting was performed. The Sync component was used to synchronise the slower PWM_Spindle clock with the Timer_Spindle clock.

Monitoring of the spindle active input and spindle speed was moved into a basic state machine, extract listed below.


/**
* @brief Basic State Machine for handling ESTOP and Spindle signals
*/

void State_Mach_Mon(void) 
{
    switch (Spindle_Monitor_State)
    {
    case (state_m_idle):
        if (Status_ESTOP_Read() == 1u)
        {
            Spindle_Monitor_State = state_m_es_deact;
        }
    break;

   case (state_m_es_deact):
        Control_ESTOP_Write(0x1); 
        if (Status_ESTOP_Read() == 0u)
        {
            Spindle_Monitor_State = state_m_reset;
        }

        if (Spindle_Active_Read() == true)
        {
            PWM_Spindle_Start();
            Timer_Spindle_Start();
            Spindle_Monitor_State = state_m_es_sp_act;
            Spindle_Started = true;
            Spindle_Timer = 100u; 
        }
    break;

    case (state_m_es_sp_act):
        Spindle_Count_Update();
        if (Status_ESTOP_Read() == 0u)
        {
            Spindle_Monitor_State = state_m_es_reset;
        }

        if (Spindle_Active_Read() == false)
        {
            Spindle_Monitor_State = state_m_reset;
        }

        if ((Spindle_Counts == 0) && (Spindle_Timer == 0))
        {
           Spindle_Monitor_State = state_m_es_reset;
        }
    break;

    case (state_m_es_reset):
        PWM_Spindle_Stop();
        Timer_Spindle_Stop();
        Control_ESTOP_Write(0x0); 
        Spindle_Started = false;
        if (Spindle_Active_Read() == false)
        {
            Spindle_Monitor_State = state_m_idle;
        }
    break;       

    case (state_m_reset):
        Control_ESTOP_Write(0x0);
        PWM_Spindle_Stop();
        Timer_Spindle_Stop();
        Spindle_Monitor_State = state_m_idle; 
    break;
    } 
}

Additional changes were made in the code to read pulses measured by the spindle sensor counter and also to determine the configuration of the PCB version (function) resistors.

Option Resistors
Notes for the code option resistors was into the PSoC project.


PSoC Notes for Option Resistors
PSoC Notes for Option Resistors

In the PSoC code, the various resistor combinations were used to define the controller operation.

/**
* @brief Board Options
*/
void Board_Options(void)
{
    if ((Option0_Read() == false) && (Option1_Read() == false))
    {
        System_Flags.Option_None = true;
        UART_UartPutString("No option\r\n");
    }
    else if ((Option0_Read() == true) && (Option1_Read() == false))
    {
        System_Flags.Option_Spd_Mon = true;
        UART_UartPutString("Speed monitor option\r\n"); 
    }
    else if (((Option0_Read() == true) && (Option1_Read() == true)) || ((Option0_Read() == false) && (Option1_Read() == true)))
    {
        UART_UartPutString("Unknown option\r\n"); 
    }
}

Sensor Counts
As the pulse counter configuration provided a 250 ms sampling window, the multiplier for the number of counts was set to 240.

/**
* @brief Read Spindle Counts and Report
*/
void Spindle_Count_Update(void) 
{
    if ((Spindle_Data_Ready == true) && (Spindle_Started == true))
    { 
        Spindle_Counts = Spindle_Raw*240u;
        Spindle_Data_Ready = false;
        ReportData();
    }
    Flag_Timer = false;
}

The Report Data function was used to provide the spindle speed in RPM. Data was output on a UART as shown in the capture below from TeraTerm.



Controller Spindle Speed Output in TeraTerm
Controller Spindle Speed Output in TeraTerm

A timer, defined by variable Spindle_Timer, ensured that when the spindle was not spinning for one second, the drill press motor would be switched off using the contactor.

Final Thoughts
The controller in this blog could be adapted for other workshop machinery, which was not originally manufactured with a method to stop that machinery in a controlled manner. Features such as the spindle rotation monitoring could be removed or disabled and other features added to suit the machine setup.

Downloads


ESTOP v1.1 BOM XLS
ESTOP v1.1 BOM XLS
ESTOP v1.1 Schematics PDF
ESTOP v1.1 Schematics PDF
ESTOP v1.1 PCB PDF
ESTOP v1.1 PCB PDF
ESTOP v1.1 Gerbers
ESTOP v1.1 Gerbers
ESTOP  v1.1 PSoC Doxygen
ESTOP  v1.1 PSoC Doxygen
ESTOP v1.1 PSoC 4.3 Project
ESTOP v1.1 PSoC 4.3 Project
ESTOP Module PSoC Creator Top Design PDF

Saturday, 14 March 2020

PSoC Creator gitignore update

Summary
This blog expands on listings shown in several posts which provide details for GIT ignore files for PSoC Creator. When using GIT with an IDE such as PSoC Creator, the .gitignore file defines which files are required for the project and which files can be ignored. Details regarding the use of the ignore feature is available in numerous places, Atlassion being one of them.

Examples shown in this blog cover PSoC 4 and PSoC 6 projects.

Existing Solutions
Below are the links to a few existing GIT ignore solutions for use with PSoC Creator and standard PSoC4 projects.

https://github.com/SorenHN/PSoC-gitignore/blob/master/.gitignore
https://github.com/github/gitignore/pull/2086/commits/7ffe05303d632f226d091f46079f1aa9cff933e9
https://git.2li.ch/various/gitignore/commit/5a355ed010640b689e06c589e38019bff81c9a15

Ignore File Additions
For Bootloadable PSoC 4/5 or PSoC6 projects, some additions were required to the existing ignore files.

# PSoC Creator 4.3
# Updated by  : GregL
# Dated   : 12/03/2020
# Details   : Place this ignore file together with cywrk or alter directories to match the required structure

# PSoC Creator Folders to ignore (PSoC4/5)
*Archive/
*Backup/
*codegentemp/
*CortexM0/
*CortexM3/
*Export/
*Generated_Source/

# PSoC Creator Folders to ignore (PSoC6)
*armgcc/
*CortexM0p/
*CortexM4/
*iar/
*mdk/

# PSoC Creator Non-Bootloadable project files to ignore (PSoC4/5)
*_timing.html
# Bootloadable project files to ignore
**.cydsn/*timing.html
*.svd
*.rpt
*.cyfit
*.cycdx
*.log
*.tmp
*.txt

# PSoC Creator Non-Bootloadable project files to ignore (PSoC6)
*.icf
*.ld
*.scat

# Option for .ctl files used in some PSoC Creator examples
#*.ctl

# Option for .pdf files supplied by some PSoC Creator examples or those specifically created from Creator
#*.pdf
#*_datasheet.pdf

# Optional PSoC Creator Files to ignore (Export to IDE feature)
*.mk
makefile

# PSoC Creator User Files to ignore
*.cyprj.*
*.cywrk.*

# For external editors such as NotePad+++
*.bak

As with many ignore files, some level of customisation is usually required to suit the project.
gitignore file
Testing Summary
To confirm the ignore file operation with PSoC Creator 4.3, three example projects were used from Code Examples in PSoC Creator. Two of the examples were PSoC 4 projects, one a standard application and the other a bootloader bootloadable application. The third test used a PSoC6 example.

Testing with SourceTree (PSoC4)
For a standard PSoC4 project the top folder in Windows may be similar to the example shown below.


Example PSoC4 Project Top Folder
Example PSoC4 Project Top Folder
Inside the project design folder are generated files and source folders. There are specific files required for PSoC Creator projects as detailed by Cypress.


Example PSoC4 Project Design Folder
Example PSoC4 Project Design Folder
Using the ignore file with PSoC4 project in SourceTree yields the result displayed below.


Example PSoC4 Project in SourceTree using gitignore
Example PSoC4 Project in SourceTree using gitignore
Testing with SourceTree (PSoC4 Bootloadable)
For a PSoC4 project with bootloader and bootloadable application, the top folder in Windows may be similar to the example shown below.


Example PSoC4 Bootloader Project Top Folder
Example PSoC4 Bootloader Project Top Folder
Inside the project Bootloader design folder are generated files and source folders.


Example PSoC4 Project Bootloader Design Folder
Example PSoC4 Project Bootloader Design Folder
This is the same for the Bootloadable design folder.


Example PSoC4 Project Bootloadable Design Folder
Example PSoC4 Project Bootloadable Design Folder
Using the ignore file with PSoC4 project in SourceTree yields the result displayed below.


Example PSoC4 Bootloader Project in SourceTree using gitignore
Example PSoC4 Bootloader Project in SourceTree using gitignore
Testing with SourceTree (PSoC6)
For a standard PSoC6 project the top folder in Windows may be similar to the example shown below.


Example PSoC6 Project Top Folder
Example PSoC6 Project Top Folder
Inside the project design folder are generated files and source folders.


Example PSoC6 Project Design Folder
Example PSoC6 Project Design Folder
Using the ignore file mentioned in the previous section with PSoC6 project in SourceTree yields the result displayed below.


Example PSoC6 Project in SourceTree using gitignore
Example PSoC6 Project in SourceTree using gitignore
Final Thoughts
Using an ignore file with version control software such as GIT can ensure that only pertinent files to build a project are retained. The ignore file configuration however should be reviewed when projects change and if a new release of the associated IDE software replaces a prior release.

The ignore file provided in this blog for GIT projects is therefore always a work in progress!

Friday, 13 March 2020

Bosch Dishwasher Test Program SMS63M08

Summary
This blog details how the test program for a Bosch dishwasher model SMS63M08 is started. It should be stated that content in this post was derived from a video on similar Bosch dishwashers. All credit to SamuraiRepairman for details in the video.

Enabling Bosch Test Program
With the Bosch dishwasher switched off press any two wash programs then the ON/OFF power button, as shown by green in the image below.


Bosch SMS63M08
Bosch SMS63M08
The display on the Bosch will flash on for a moment then display P0. Two of the LEDs should be illuminated, as displayed below.


Bosch SMS63M08 Test Program (P0)
Bosch SMS63M08 Test Program (P0)
Press the button Pots/Pans and the display will change to P1. One LED will remain illuminated.


Bosch SMS63M08 Test Program (P1)
Bosch SMS63M08 Test Program (P1)
Press the button Pre-rinse and the test program will begin. The display shows an S with a number which appears to be a timer.


Bosch SMS63M08 Running Test Program
Bosch SMS63M08 Running Test Program
The test program runs for over 20 minutes after which any errors are displayed.


Bosch SMS63M08 Test Program End
Bosch SMS63M08 Test Program End
For a description of any error code see sites such as Bosch Dishwasher Error Codes.

Sunday, 16 February 2020

PCB Design for Repair

Summary
This blog presents a range of amendments for schematics or Printed Circuit Boards (PCB) with a focus on Design for Repair (DFR), which may also be referred to as Design for Service (DFS).

Principle
The principle behind Design for Repair (DFR) can be described as the approach or technique of designing for repair or serviceability.

DFR Examples
There is content online which mentions DFR, such as Machine DesignAltium blog and Altium resource. Even though this content mentions DFR, examples showing changes to schematics or PCB design is exiguous. Lack of examples is unsurprising considering the uniqueness of each PCB design. Nonetheless, some examples detailed in this blog should be relevant across a variety of situations.

It should be stipulated that for commercial PCB designs the examples expressed in this blog may not apply for reasons relating to protection of intellectual property.

Schematic Net Naming
A large number of websites state the importance of naming nets and here it is reiterated. The naming of schematic nets should be effected to provide the least ambiguous information, whether the schematic detail is used during development, service or repair.

In the capture below from the Altium Connect Cube project, a common JTAG signal harness was used for soft and hard JTAG programming connections.

The two connections are differentiated in the schematic with the prefix HARD_ or SOFT_.



Extract Harness Connected Cube. Courtesy Altium Ltd
Extract Harness Connected Cube. Courtesy Altium Ltd

When viewing the net connections on the PCB, the type of the net is clear and understandable.

PCB Extract Connected Cube. Courtesy Altium Ltd
PCB Extract Connected Cube. Courtesy Altium Ltd

Schematic Component Designators
The naming of schematic components remains a debated topic. This section of the blog does not debate whether a microcontroller designator should be prefixed with "IC", "U" or "DD". Instead, designator naming should aim to use as few alphanumeric characters and be discernible on the PCB.

Certainly, there are exceptions when displaying PCB designators, especially when there are space restrictions or specific commercial equipment. For example, the Samsung S8 motherboard shown in the image below has little to no component designators.


Samsung S8 Motherboard
Samsung S8 Motherboard

It is commonplace for PCB design software to offer multi-channel part designator naming or the addition of suffixes to the component designator to identify specific schematic sheets or functions. These features are appropriate when component spacing allows for placement of longer designators.


PCB Extract Spirit Level with Designator Suffix Included. Courtesy Altium Ltd
PCB Extract Spirit Level with Designator Suffix Included. Courtesy Altium Ltd

In space-restricted designs, where the PCB component to board area density increases above forty percent, a compact designator name allows for more valuable use of PCB real estate.

The designators shown in the above image have a suffix 'P' added to identify power supply components. While the addition of the suffix could be advantageous, this must be weighed up against the straightforward designator naming of the original PCB shown below.



PCB Extract Spirit Level with Original Designator. Courtesy Altium Ltd
PCB Extract Spirit Level with Original Designator. Courtesy Altium Ltd

Component Orientation

In the PCB displayed below, consider the orientation of component U1 with respect to removal through desoldering. It is most likely that the two surrounding relays would require removal to access the component.


Example Component Orientation Preventing Repair
Example Component Orientation Preventing Repair

Orientating component U1 as shown in the image below would provide an improved prospect of desoldering.


Improved Component Orientation for Repair
Improved Component Orientation for Repair

Optimising the orientation of a component for repair at the time of PCB routing will commonly yield a labour-saving result.

Component Placement
Following on from the previous section, placement of components and spacing to adjacent components can cause issues for repair when separation distances are small.

Example Component Placement Limiting Repair
Example Component Placement Limiting Repair

For the example PCB presented above, component U1 is shown fitted between two relays. In the event that U1 requires replacement, twin soldering irons or micro tweezers may be able to remove the component although.

Another placement option could be taken which would result in the component in a more accessible position for service equipment.



Example Component Placement Aiding Repair
Example Component Placement Aiding Repair

PCB Access Points
When designing a PCB to fit inside an enclosure, with a focus on maximising useable space, this can present issues when tolerances are marginal. Consider the small plug-in style PCB pictured below. No facility has been provided to remove or replace the PCB.



Plug-in PCB Without Access Points for Removal
Plug-in PCB Without Access Points for Removal

If room on the PCB permits, the addition of access or pull points can significantly improve the ability to remove the PCB.

Plug-in PCB With Access Points for Removal
Plug-in PCB With Access Points for Removal

PCB Current Shunt Option
For designs containing power supplies, the unassuming current shunt can be a benefit to repair personnel.



PCB Current Shunt Option
PCB Current Shunt Option

Designs which use a short-circuited current shunt have no component physically loaded on the PCB. The footprint could be considered a placeholder. If a need arises to isolate a supply rail or measure the current in that rail, the copper shorting the resistor is removed then the appropriate part fitted. This solution should also be considered when developing a prototype PCB.

PCB Plane Thermal Relief
External and internal copper planes often play a large role during PCB layout. During the repair process, the copper plane presents as a large heatsink for soldering and desoldering.

In the capture below, the two leftmost thru-hole pads are directly connected to the copper plane. While a single copper plane directly connected to the thru-hole pads can be soldered, several planes of directly connected copper tend to be a challenge.


PCB Direct Plane Connections
PCB Direct Plane Connections

A thermal relief can be applied to the thru-hole pad. Depending on the electrical specifications of the design the characteristics of the thermal relief which include air gap, conductor width and number of conductors should be thoroughly considered.

PCB Relief Plane Connections
PCB Relief Plane Connections

PCB Silkscreen Pin Identification
When a new PCB component is drafted, imported from the component manufacturer or taken from an existing design, a review is always sensible.


PCB Extract DT101 PCB. Courtesy Altium Ltd
PCB Extract DT101 PCB. Courtesy Altium Ltd

The picture above, from an Altium example project, shows a four-pin LED with the function of each pin indicated.

PCB Silkscreen Pin Function
Additions to the PCB silkscreen, such as the voltages for the test points in the image below, can deliver technical information without the need to consult project schematics.

PCB Extract DB31 PCB. Courtesy Altium Ltd
PCB Extract DB31 PCB. Courtesy Altium Ltd

Seen below is an extract the Altium Connect Cube with the function or port detailed on the silkscreen for each pin.


PCB Extract Connected Cube. Courtesy Altium Ltd
PCB Extract Connected Cube. Courtesy Altium Ltd

PCB Silkscreen Assembly Extras
At the beginning and end of a repair commonly involves removal of mounting hardware which can include screws, washers, bolts or standoffs.



PCB Showing No Mechanical Hardware Required or Assembly Information
PCB Showing No Mechanical Hardware Required or Assembly Information

In the image below the hardware associated with the mounting hole is made evident by the PCB silk screen.

PCB Showing Mechanical Hardware Required
PCB Showing Mechanical Hardware Required

The next image shows the hardware required and the torque setting for the standoff.

PCB Showing Mechanical Hardware Required and Torque Setting
PCB Showing Mechanical Hardware Required and Torque Setting

Final Thoughts
The examples in this blog are amendments that can improve the repairability of a PCB. Design for repair is another tool in the hobbyists or Engineers arsenal, which is no different than applying sound judgement to schematic layout and PCB routing, to produce optimal results.